Remove dependency on Boost.Iterator

This commit is contained in:
Christian Mazakas 2022-06-17 15:52:07 -07:00
parent 1ed2a0a0f1
commit b1a9cde690
3 changed files with 203 additions and 51 deletions

View File

@ -18,7 +18,6 @@ target_link_libraries(boost_unordered
Boost::config Boost::config
Boost::container_hash Boost::container_hash
Boost::core Boost::core
Boost::iterator
Boost::move Boost::move
Boost::mp11 Boost::mp11
Boost::predef Boost::predef

View File

@ -124,25 +124,6 @@ to normal separate chaining implementations.
#include <boost/core/empty_value.hpp> #include <boost/core/empty_value.hpp>
#include <boost/core/no_exceptions_support.hpp> #include <boost/core/no_exceptions_support.hpp>
#include <boost/cstdint.hpp> #include <boost/cstdint.hpp>
// `iterator_facade` has transitive dependencies on Boost.MPL; one of the
// headers is generating a `-Wsign-conversion` warning which has an open PR to
// address the issue but merging does not seem likely so for now create a rote
// workaround.
//
// TODO: eventually remove this once MPL is fixed or we decide to migrate off of
// the Boost.Iterator dependency.
//
#if defined(BOOST_GCC)
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wsign-conversion"
#pragma GCC diagnostic ignored "-Wconversion"
#include <boost/iterator/iterator_facade.hpp>
#pragma GCC diagnostic pop
#else
#include <boost/iterator/iterator_facade.hpp>
#endif
#include <boost/move/core.hpp> #include <boost/move/core.hpp>
#include <boost/move/utility_core.hpp> #include <boost/move/utility_core.hpp>
#include <boost/preprocessor/seq/enum.hpp> #include <boost/preprocessor/seq/enum.hpp>
@ -153,6 +134,7 @@ to normal separate chaining implementations.
#include <boost/type_traits/alignment_of.hpp> #include <boost/type_traits/alignment_of.hpp>
#include <climits> #include <climits>
#include <iterator>
namespace boost { namespace boost {
namespace unordered { namespace unordered {
@ -472,10 +454,7 @@ namespace boost {
return ~(~(std::size_t(0)) >> (sizeof(std::size_t) * 8 - n)); return ~(~(std::size_t(0)) >> (sizeof(std::size_t) * 8 - n));
} }
template <class Bucket> template <class Bucket> struct grouped_bucket_iterator
struct grouped_bucket_iterator
: public boost::iterator_facade<grouped_bucket_iterator<Bucket>,
Bucket, boost::forward_traversal_tag>
{ {
public: public:
typedef typename Bucket::bucket_pointer bucket_pointer; typedef typename Bucket::bucket_pointer bucket_pointer;
@ -483,8 +462,12 @@ namespace boost {
typename boost::pointer_traits<bucket_pointer>::template rebind_to< typename boost::pointer_traits<bucket_pointer>::template rebind_to<
bucket_group<Bucket> >::type bucket_group_pointer; bucket_group<Bucket> >::type bucket_group_pointer;
typedef Bucket value_type;
typedef typename boost::pointer_traits<bucket_pointer>::difference_type typedef typename boost::pointer_traits<bucket_pointer>::difference_type
difference_type; difference_type;
typedef Bucket& reference;
typedef Bucket* pointer;
typedef std::forward_iterator_tag iterator_category;
private: private:
bucket_pointer p; bucket_pointer p;
@ -493,9 +476,38 @@ namespace boost {
public: public:
grouped_bucket_iterator() : p(), pbg() {} grouped_bucket_iterator() : p(), pbg() {}
private: reference operator*() const BOOST_NOEXCEPT { return dereference(); }
friend class boost::iterator_core_access; pointer operator->() const BOOST_NOEXCEPT
{
return boost::to_address(p);
}
grouped_bucket_iterator& operator++() BOOST_NOEXCEPT
{
increment();
return *this;
}
grouped_bucket_iterator operator++(int) BOOST_NOEXCEPT
{
grouped_bucket_iterator old = *this;
increment();
return old;
}
bool operator==(
grouped_bucket_iterator const& other) const BOOST_NOEXCEPT
{
return equal(other);
}
bool operator!=(
grouped_bucket_iterator const& other) const BOOST_NOEXCEPT
{
return !equal(other);
}
private:
template <typename, typename, typename> template <typename, typename, typename>
friend class grouped_bucket_array; friend class grouped_bucket_array;
@ -533,12 +545,8 @@ namespace boost {
template <class Node> struct const_grouped_local_bucket_iterator; template <class Node> struct const_grouped_local_bucket_iterator;
template <class Node> template <class Node> struct grouped_local_bucket_iterator
struct grouped_local_bucket_iterator
: public boost::iterator_facade<grouped_local_bucket_iterator<Node>,
typename Node::value_type, boost::forward_traversal_tag>
{ {
typedef typename Node::node_pointer node_pointer; typedef typename Node::node_pointer node_pointer;
public: public:
@ -551,9 +559,39 @@ namespace boost {
grouped_local_bucket_iterator() : p() {} grouped_local_bucket_iterator() : p() {}
private: reference operator*() const BOOST_NOEXCEPT { return dereference(); }
friend class boost::iterator_core_access;
pointer operator->() const BOOST_NOEXCEPT
{
return boost::to_address(p);
}
grouped_local_bucket_iterator& operator++() BOOST_NOEXCEPT
{
increment();
return *this;
}
grouped_local_bucket_iterator operator++(int) BOOST_NOEXCEPT
{
grouped_local_bucket_iterator old = *this;
increment();
return old;
}
bool operator==(
grouped_local_bucket_iterator const& other) const BOOST_NOEXCEPT
{
return equal(other);
}
bool operator!=(
grouped_local_bucket_iterator const& other) const BOOST_NOEXCEPT
{
return !equal(other);
}
private:
template <typename, typename, typename> template <typename, typename, typename>
friend class grouped_bucket_array; friend class grouped_bucket_array;
@ -573,11 +611,7 @@ namespace boost {
node_pointer p; node_pointer p;
}; };
template <class Node> template <class Node> struct const_grouped_local_bucket_iterator
struct const_grouped_local_bucket_iterator
: public boost::iterator_facade<
const_grouped_local_bucket_iterator<Node>,
typename Node::value_type const, boost::forward_traversal_tag>
{ {
typedef typename Node::node_pointer node_pointer; typedef typename Node::node_pointer node_pointer;
@ -596,9 +630,39 @@ namespace boost {
{ {
} }
private: reference operator*() const BOOST_NOEXCEPT { return dereference(); }
friend class boost::iterator_core_access;
pointer operator->() const BOOST_NOEXCEPT
{
return boost::to_address(p);
}
const_grouped_local_bucket_iterator& operator++() BOOST_NOEXCEPT
{
increment();
return *this;
}
const_grouped_local_bucket_iterator operator++(int) BOOST_NOEXCEPT
{
const_grouped_local_bucket_iterator old = *this;
increment();
return old;
}
bool operator==(
const_grouped_local_bucket_iterator const& other) const BOOST_NOEXCEPT
{
return equal(other);
}
bool operator!=(
const_grouped_local_bucket_iterator const& other) const BOOST_NOEXCEPT
{
return !equal(other);
}
private:
template <typename, typename, typename> template <typename, typename, typename>
friend class grouped_bucket_array; friend class grouped_bucket_array;

View File

@ -19,6 +19,7 @@
#include <boost/core/bit.hpp> #include <boost/core/bit.hpp>
#include <boost/core/no_exceptions_support.hpp> #include <boost/core/no_exceptions_support.hpp>
#include <boost/core/pointer_traits.hpp> #include <boost/core/pointer_traits.hpp>
#include <boost/detail/select_type.hpp>
#include <boost/limits.hpp> #include <boost/limits.hpp>
#include <boost/move/move.hpp> #include <boost/move/move.hpp>
#include <boost/preprocessor/arithmetic/inc.hpp> #include <boost/preprocessor/arithmetic/inc.hpp>
@ -1730,10 +1731,7 @@ namespace boost {
namespace iterator_detail { namespace iterator_detail {
template <class Node, class Bucket> class c_iterator; template <class Node, class Bucket> class c_iterator;
template <class Node, class Bucket> template <class Node, class Bucket> class iterator
class iterator
: public boost::iterator_facade<iterator<Node, Bucket>,
typename Node::value_type, boost::forward_traversal_tag>
{ {
public: public:
typedef typename Node::value_type value_type; typedef typename Node::value_type value_type;
@ -1745,6 +1743,50 @@ namespace boost {
iterator() : p(), itb(){}; iterator() : p(), itb(){};
reference operator*() const BOOST_NOEXCEPT { return dereference(); }
pointer operator->() const BOOST_NOEXCEPT
{
pointer x = boost::addressof(p->value());
return x;
}
iterator& operator++() BOOST_NOEXCEPT
{
increment();
return *this;
}
iterator operator++(int) BOOST_NOEXCEPT
{
iterator old = *this;
increment();
return old;
}
bool operator==(iterator const& other) const BOOST_NOEXCEPT
{
return equal(other);
}
bool operator!=(iterator const& other) const BOOST_NOEXCEPT
{
return !equal(other);
}
bool operator==(
boost::unordered::detail::iterator_detail::c_iterator<Node,
Bucket> const& other) const BOOST_NOEXCEPT
{
return equal(other);
}
bool operator!=(
boost::unordered::detail::iterator_detail::c_iterator<Node,
Bucket> const& other) const BOOST_NOEXCEPT
{
return !equal(other);
}
private: private:
typedef typename Node::node_pointer node_pointer; typedef typename Node::node_pointer node_pointer;
typedef grouped_bucket_iterator<Bucket> bucket_iterator; typedef grouped_bucket_iterator<Bucket> bucket_iterator;
@ -1754,7 +1796,6 @@ namespace boost {
template <class Types> friend struct boost::unordered::detail::table; template <class Types> friend struct boost::unordered::detail::table;
template <class N, class B> friend class c_iterator; template <class N, class B> friend class c_iterator;
friend class boost::iterator_core_access;
iterator(node_pointer p_, bucket_iterator itb_) : p(p_), itb(itb_) {} iterator(node_pointer p_, bucket_iterator itb_) : p(p_), itb(itb_) {}
@ -1765,6 +1806,13 @@ namespace boost {
return (p == x.p); return (p == x.p);
} }
bool equal(
const boost::unordered::detail::iterator_detail::c_iterator<Node,
Bucket>& x) const BOOST_NOEXCEPT
{
return (p == x.p);
}
void increment() BOOST_NOEXCEPT void increment() BOOST_NOEXCEPT
{ {
p = p->next; p = p->next;
@ -1774,10 +1822,7 @@ namespace boost {
} }
}; };
template <class Node, class Bucket> template <class Node, class Bucket> class c_iterator
class c_iterator
: public boost::iterator_facade<c_iterator<Node, Bucket>,
typename Node::value_type const, boost::forward_traversal_tag>
{ {
public: public:
typedef typename Node::value_type value_type; typedef typename Node::value_type value_type;
@ -1788,7 +1833,51 @@ namespace boost {
typedef std::forward_iterator_tag iterator_category; typedef std::forward_iterator_tag iterator_category;
c_iterator() : p(), itb(){}; c_iterator() : p(), itb(){};
c_iterator(iterator<Node, Bucket> it) : p(it.p), itb(it.itb){}; c_iterator(iterator<Node, Bucket> it) : p(it.p), itb(it.itb) {}
reference operator*() const BOOST_NOEXCEPT { return dereference(); }
pointer operator->() const BOOST_NOEXCEPT
{
pointer x = boost::addressof(p->value());
return x;
}
c_iterator& operator++() BOOST_NOEXCEPT
{
increment();
return *this;
}
c_iterator operator++(int) BOOST_NOEXCEPT
{
c_iterator old = *this;
increment();
return old;
}
bool operator==(c_iterator const& other) const BOOST_NOEXCEPT
{
return equal(other);
}
bool operator!=(c_iterator const& other) const BOOST_NOEXCEPT
{
return !equal(other);
}
bool operator==(
boost::unordered::detail::iterator_detail::iterator<Node,
Bucket> const& other) const BOOST_NOEXCEPT
{
return equal(other);
}
bool operator!=(
boost::unordered::detail::iterator_detail::iterator<Node,
Bucket> const& other) const BOOST_NOEXCEPT
{
return !equal(other);
}
private: private:
typedef typename Node::node_pointer node_pointer; typedef typename Node::node_pointer node_pointer;
@ -1798,7 +1887,7 @@ namespace boost {
bucket_iterator itb; bucket_iterator itb;
template <class Types> friend struct boost::unordered::detail::table; template <class Types> friend struct boost::unordered::detail::table;
friend class boost::iterator_core_access; template <class, class> friend class iterator;
c_iterator(node_pointer p_, bucket_iterator itb_) : p(p_), itb(itb_) c_iterator(node_pointer p_, bucket_iterator itb_) : p(p_), itb(itb_)
{ {