/* Copyright 2003-2005 Joaquín M López Muñoz. * 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_INDEX_PROXY_HPP #define BOOST_MULTI_INDEX_DETAIL_INDEX_PROXY_HPP #if defined(_MSC_VER)&&(_MSC_VER>=1200) #pragma once #endif #if defined(BOOST_MULTI_INDEX_ENABLE_SAFE_MODE) #include /* keep it first to prevent nasty warns in MSVC */ #include #if BOOST_WORKAROUND(BOOST_MSVC,<1300) #include #include #include namespace boost{ namespace multi_index{ namespace detail{ /* In safe mode, index iterators are derived from safe_iterator, * where Index is the type of the index where the iterator belongs. Due * to the long symbol names of indices, MSVC++ 6.0 often issues a * LNK1179 (duplicate comdat) error. To workaround this problem, * index_proxy is used instead. index_proxy acts as an index * over nodes of type Node in all aspects relevant to safe_iterator, and * its shorter symbol name makes life easier for MSVC++ 6.0. */ template class index_proxy:public safe_container > { protected: index_proxy(Node* header_):header(header_){} void swap(index_proxy& x) { std::swap(header,x.header); safe_container >::swap(x); } public: typedef index_iterator iterator; typedef index_iterator const_iterator; index_iterator begin()const { return index_iterator( Node::begin(header),const_cast(this)); } index_iterator end()const { return index_iterator( Node::end(header),const_cast(this)); } private: Node* header; }; } /* namespace multi_index::detail */ } /* namespace multi_index */ } /* namespace boost */ #endif /* workaround */ #endif /* BOOST_MULTI_INDEX_ENABLE_SAFE_MODE */ #endif