x
Yes
No
Do you want to visit DriveHQ English website?
首页
产品服务
价格
免费试用
下载客户端
关于我们
云文件服务
|
云备份服务
|
FTP服务
|
企业邮箱服务
|
网站托管
|
客户端软件
云文件服务
云备份服务
FTP服务
企业级邮箱服务
网站托管
客户端软件
list_map_adaptor.hpp - Hosted on DriveHQ Cloud IT Platform
返回上层目录
上传
下载
共享
发布
新建文件夹
新建文件
复制
剪切
删除
粘贴
评论
升级服务
路径: \\game3dprogramming\materials\GameFactory\GameFactoryDemo\references\boost_1_35_0\boost\bimap\container_adaptor\list_map_adaptor.hpp
旋转
特效
属性
历史版本
// Boost.Bimap // // Copyright (c) 2006-2007 Matias Capeletto // // 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) /// \file container_adaptor/list_map_adaptor.hpp /// \brief Container adaptor. #ifndef BOOST_BIMAP_CONTAINER_ADAPTOR_LIST_MAP_ADAPTOR_HPP #define BOOST_BIMAP_CONTAINER_ADAPTOR_LIST_MAP_ADAPTOR_HPP #if defined(_MSC_VER) && (_MSC_VER>=1200) #pragma once #endif #include
#include
#include
#include
#include
#include
#include
#include
#include
#include
namespace boost { namespace bimaps { namespace container_adaptor { #ifndef BOOST_BIMAP_DOXYGEN_WILL_NOT_PROCESS_THE_FOLLOWING_LINES template < class Base, class Iterator, class ConstIterator, class ReverseIterator, class ConstReverseIterator, class IteratorToBaseConverter, class IteratorFromBaseConverter, class ReverseIteratorFromBaseConverter, class ValueToBaseConverter, class ValueFromBaseConverter, class KeyFromBaseValueConverter, class FunctorsFromDerivedClasses > struct list_map_adaptor_base { typedef list_adaptor < Base, Iterator, ConstIterator, ReverseIterator, ConstReverseIterator, IteratorToBaseConverter, IteratorFromBaseConverter, ReverseIteratorFromBaseConverter, ValueToBaseConverter, ValueFromBaseConverter, BOOST_DEDUCED_TYPENAME mpl::push_front< FunctorsFromDerivedClasses, BOOST_DEDUCED_TYPENAME mpl::if_< ::boost::mpl::is_na
, // { detail::key_from_pair_extractor < BOOST_DEDUCED_TYPENAME Iterator::value_type >, // } // else // { KeyFromBaseValueConverter // } >::type >::type > type; }; #endif // BOOST_BIMAP_DOXYGEN_WILL_NOT_PROCESS_THE_FOLLOWING_LINES /// \brief Container adaptor to easily build a list map container template < class Base, class Iterator, class ConstIterator, class ReverseIterator, class ConstReverseIterator, class IteratorToBaseConverter = ::boost::mpl::na, class IteratorFromBaseConverter = ::boost::mpl::na, class ReverseIteratorFromBaseConverter = ::boost::mpl::na, class ValueToBaseConverter = ::boost::mpl::na, class ValueFromBaseConverter = ::boost::mpl::na, class KeyFromBaseValueConverter = ::boost::mpl::na, class FunctorsFromDerivedClasses = mpl::vector<> > class list_map_adaptor : public list_map_adaptor_base < Base, Iterator, ConstIterator, ReverseIterator, ConstReverseIterator, IteratorToBaseConverter, IteratorFromBaseConverter, ReverseIteratorFromBaseConverter, ValueToBaseConverter, ValueFromBaseConverter, KeyFromBaseValueConverter, FunctorsFromDerivedClasses >::type { typedef BOOST_DEDUCED_TYPENAME list_map_adaptor_base < Base, Iterator, ConstIterator, ReverseIterator, ConstReverseIterator, IteratorToBaseConverter, IteratorFromBaseConverter, ReverseIteratorFromBaseConverter, ValueToBaseConverter, ValueFromBaseConverter, KeyFromBaseValueConverter, FunctorsFromDerivedClasses >::type base_; // MetaData ------------------------------------------------------------- public: typedef BOOST_DEDUCED_TYPENAME Iterator::value_type::first_type key_type; typedef BOOST_DEDUCED_TYPENAME Iterator::value_type::second_type data_type; protected: typedef BOOST_DEDUCED_TYPENAME mpl::if_< ::boost::mpl::is_na
, // { detail::key_from_pair_extractor< BOOST_DEDUCED_TYPENAME Iterator::value_type >, // } // else // { KeyFromBaseValueConverter // } >::type key_from_base_value; // Access ----------------------------------------------------------------- public: explicit list_map_adaptor(Base & c) : base_(c) {} protected: typedef list_map_adaptor list_map_adaptor_; // Functions ------------------------------------------------------------- public: // The following functions are overwritten in order to work // with key_type instead of value_type template< class Predicate > void remove_if(Predicate pred) { this->base().remove_if( ::boost::bimaps::container_adaptor::detail::unary_check_adaptor < Predicate, BOOST_DEDUCED_TYPENAME Base::value_type, key_from_base_value >( pred, this->template functor
() ) ); } void unique() { this->base().unique( ::boost::bimaps::container_adaptor::detail::comparison_adaptor < std::equal_to
, BOOST_DEDUCED_TYPENAME Base::value_type, key_from_base_value >( std::equal_to
(), this->template functor
() ) ); } template< class BinaryPredicate > void unique(BinaryPredicate binary_pred) { this->base().unique( ::boost::bimaps::container_adaptor::detail::comparison_adaptor < BinaryPredicate, BOOST_DEDUCED_TYPENAME Base::value_type, key_from_base_value >( binary_pred, this->template functor
() ) ); } void merge(list_map_adaptor & x) { this->base().merge(x.base(), ::boost::bimaps::container_adaptor::detail::comparison_adaptor < std::less
, BOOST_DEDUCED_TYPENAME Base::value_type, key_from_base_value >( std::less
(), this->template functor
() ) ); } template< class Compare > void merge(list_map_adaptor & x, Compare comp) { this->base().merge(x.base(), ::boost::bimaps::container_adaptor::detail::comparison_adaptor < Compare, BOOST_DEDUCED_TYPENAME Base::value_type, key_from_base_value >( comp, this->template functor
() ) ); } void sort() { this->base().sort( ::boost::bimaps::container_adaptor::detail::comparison_adaptor < std::less
, BOOST_DEDUCED_TYPENAME Base::value_type, key_from_base_value >( std::less
(), this->template functor
() ) ); } template< class Compare > void sort(Compare comp) { this->base().sort( ::boost::bimaps::container_adaptor::detail::comparison_adaptor < Compare, BOOST_DEDUCED_TYPENAME Base::value_type, key_from_base_value >( comp, this->template functor
() ) ); } }; } // namespace container_adaptor } // namespace bimaps } // namespace boost #endif // BOOST_BIMAP_CONTAINER_ADAPTOR_LIST_MAP_ADAPTOR_HPP
list_map_adaptor.hpp
网页地址
文件地址
上一页
4/17
下一页
下载
( 7 KB )
Comments
Total ratings:
0
Average rating:
无评论
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.