/* Copyright 2003-2023 Joaquin M Lopez Munoz. * Distributed under the Boost Software License, Version 1.0. * (See accompanying file LICENSE_1_0.txt or copy at * http://www.boost.org/LICENSE_1_0.txt) * * See http://www.boost.org/libs/multi_index for library home page. */ #ifndef BOOST_MULTI_INDEX_DETAIL_HASH_INDEX_ITERATOR_HPP #define BOOST_MULTI_INDEX_DETAIL_HASH_INDEX_ITERATOR_HPP #if defined(_MSC_VER) #pragma once #endif #include /* keep it first to prevent nasty warns in MSVC */ #include #if !defined(BOOST_MULTI_INDEX_DISABLE_SERIALIZATION) #include #endif namespace boost{ namespace multi_index{ namespace detail{ /* Iterator class for hashed indices. */ struct hashed_index_global_iterator_tag{}; struct hashed_index_local_iterator_tag{}; template< typename Node,typename BucketArray, typename IndexCategory,typename IteratorCategory > class hashed_index_iterator: public forward_iterator_helper< hashed_index_iterator, typename Node::value_type, typename Node::difference_type, const typename Node::value_type*, const typename Node::value_type&> { public: /* coverity[uninit_ctor]: suppress warning */ hashed_index_iterator(){} hashed_index_iterator(Node* node_):node(node_){} const typename Node::value_type& operator*()const { return node->value(); } hashed_index_iterator& operator++() { this->increment(IteratorCategory()); return *this; } #if !defined(BOOST_MULTI_INDEX_DISABLE_SERIALIZATION) /* Serialization. As for why the following is public, * see explanation in safe_mode_iterator notes in safe_mode.hpp. */ template void serialize(Archive& ar,const unsigned int version) { core::split_member(ar,*this,version); } typedef typename Node::base_type node_base_type; template void save(Archive& ar,const unsigned int)const { node_base_type* bnode=node; ar< void load(Archive& ar,const unsigned int version) { load(ar,version,IteratorCategory()); } template void load( Archive& ar,const unsigned int version,hashed_index_global_iterator_tag) { node_base_type* bnode; ar>>core::make_nvp("pointer",bnode); node=static_cast(bnode); if(version<1){ BucketArray* throw_away; /* consume unused ptr */ ar>>core::make_nvp("pointer",throw_away); } } template void load( Archive& ar,const unsigned int version,hashed_index_local_iterator_tag) { node_base_type* bnode; ar>>core::make_nvp("pointer",bnode); node=static_cast(bnode); if(version<1){ BucketArray* buckets; ar>>core::make_nvp("pointer",buckets); if(buckets&&node&&node->impl()==buckets->end()->prior()){ /* end local_iterators used to point to end node, now they are null */ node=0; } } } #endif /* get_node is not to be used by the user */ typedef Node node_type; Node* get_node()const{return node;} private: void increment(hashed_index_global_iterator_tag) { Node::template increment(node); } void increment(hashed_index_local_iterator_tag) { Node::template increment_local(node); } Node* node; }; template< typename Node,typename BucketArray, typename IndexCategory,typename IteratorCategory > bool operator==( const hashed_index_iterator< Node,BucketArray,IndexCategory,IteratorCategory>& x, const hashed_index_iterator< Node,BucketArray,IndexCategory,IteratorCategory>& y) { return x.get_node()==y.get_node(); } } /* namespace multi_index::detail */ } /* namespace multi_index */ #if !defined(BOOST_MULTI_INDEX_DISABLE_SERIALIZATION) /* class version = 1 : hashed_index_iterator does no longer serialize a bucket * array pointer. */ namespace serialization { template< typename Node,typename BucketArray, typename IndexCategory,typename IteratorCategory > struct version< boost::multi_index::detail::hashed_index_iterator< Node,BucketArray,IndexCategory,IteratorCategory > > { BOOST_STATIC_CONSTANT(int,value=1); }; } /* namespace serialization */ #endif } /* namespace boost */ #endif