x
Yes
No
Do you want to visit DriveHQ English website?
首页
产品服务
价格
免费试用
下载客户端
关于我们
云文件服务
|
云备份服务
|
FTP服务
|
企业邮箱服务
|
网站托管
|
客户端软件
云文件服务
云备份服务
FTP服务
企业级邮箱服务
网站托管
客户端软件
compressed_pair.hpp - Hosted on DriveHQ Cloud IT Platform
返回上层目录
上传
下载
共享
发布
新建文件夹
新建文件
复制
剪切
删除
粘贴
评论
升级服务
路径: \\game3dprogramming\materials\GameFactory\GameFactoryDemo\references\boost_1_35_0\boost\detail\compressed_pair.hpp
旋转
特效
属性
历史版本
// (C) Copyright Steve Cleary, Beman Dawes, Howard Hinnant & John Maddock 2000. // Use, modification and distribution are subject to 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/utility for most recent version including documentation. // compressed_pair: pair that "compresses" empty members // (see libs/utility/compressed_pair.htm) // // JM changes 25 Jan 2004: // For the case where T1 == T2 and both are empty, then first() and second() // should return different objects. // JM changes 25 Jan 2000: // Removed default arguments from compressed_pair_switch to get // C++ Builder 4 to accept them // rewriten swap to get gcc and C++ builder to compile. // added partial specialisations for case T1 == T2 to avoid duplicate constructor defs. #ifndef BOOST_DETAIL_COMPRESSED_PAIR_HPP #define BOOST_DETAIL_COMPRESSED_PAIR_HPP #include
#include
#include
#include
#include
#ifdef BOOST_MSVC # pragma warning(push) # pragma warning(disable:4512) #endif namespace boost { template
class compressed_pair; // compressed_pair namespace details { // JM altered 26 Jan 2000: template
struct compressed_pair_switch; template
struct compressed_pair_switch
{static const int value = 0;}; template
struct compressed_pair_switch
{static const int value = 3;}; template
struct compressed_pair_switch
{static const int value = 1;}; template
struct compressed_pair_switch
{static const int value = 2;}; template
struct compressed_pair_switch
{static const int value = 4;}; template
struct compressed_pair_switch
{static const int value = 5;}; template
class compressed_pair_imp; #ifdef __GNUC__ // workaround for GCC (JM): using std::swap; #endif // // can't call unqualified swap from within classname::swap // as Koenig lookup rules will find only the classname::swap // member function not the global declaration, so use cp_swap // as a forwarding function (JM): template
inline void cp_swap(T& t1, T& t2) { #ifndef __GNUC__ using std::swap; #endif swap(t1, t2); } // 0 derive from neither template
class compressed_pair_imp
{ public: typedef T1 first_type; typedef T2 second_type; typedef typename call_traits
::param_type first_param_type; typedef typename call_traits
::param_type second_param_type; typedef typename call_traits
::reference first_reference; typedef typename call_traits
::reference second_reference; typedef typename call_traits
::const_reference first_const_reference; typedef typename call_traits
::const_reference second_const_reference; compressed_pair_imp() {} compressed_pair_imp(first_param_type x, second_param_type y) : first_(x), second_(y) {} compressed_pair_imp(first_param_type x) : first_(x) {} compressed_pair_imp(second_param_type y) : second_(y) {} first_reference first() {return first_;} first_const_reference first() const {return first_;} second_reference second() {return second_;} second_const_reference second() const {return second_;} void swap(::boost::compressed_pair
& y) { cp_swap(first_, y.first()); cp_swap(second_, y.second()); } private: first_type first_; second_type second_; }; // 1 derive from T1 template
class compressed_pair_imp
: protected ::boost::remove_cv
::type { public: typedef T1 first_type; typedef T2 second_type; typedef typename call_traits
::param_type first_param_type; typedef typename call_traits
::param_type second_param_type; typedef typename call_traits
::reference first_reference; typedef typename call_traits
::reference second_reference; typedef typename call_traits
::const_reference first_const_reference; typedef typename call_traits
::const_reference second_const_reference; compressed_pair_imp() {} compressed_pair_imp(first_param_type x, second_param_type y) : first_type(x), second_(y) {} compressed_pair_imp(first_param_type x) : first_type(x) {} compressed_pair_imp(second_param_type y) : second_(y) {} first_reference first() {return *this;} first_const_reference first() const {return *this;} second_reference second() {return second_;} second_const_reference second() const {return second_;} void swap(::boost::compressed_pair
& y) { // no need to swap empty base class: cp_swap(second_, y.second()); } private: second_type second_; }; // 2 derive from T2 template
class compressed_pair_imp
: protected ::boost::remove_cv
::type { public: typedef T1 first_type; typedef T2 second_type; typedef typename call_traits
::param_type first_param_type; typedef typename call_traits
::param_type second_param_type; typedef typename call_traits
::reference first_reference; typedef typename call_traits
::reference second_reference; typedef typename call_traits
::const_reference first_const_reference; typedef typename call_traits
::const_reference second_const_reference; compressed_pair_imp() {} compressed_pair_imp(first_param_type x, second_param_type y) : second_type(y), first_(x) {} compressed_pair_imp(first_param_type x) : first_(x) {} compressed_pair_imp(second_param_type y) : second_type(y) {} first_reference first() {return first_;} first_const_reference first() const {return first_;} second_reference second() {return *this;} second_const_reference second() const {return *this;} void swap(::boost::compressed_pair
& y) { // no need to swap empty base class: cp_swap(first_, y.first()); } private: first_type first_; }; // 3 derive from T1 and T2 template
class compressed_pair_imp
: protected ::boost::remove_cv
::type, protected ::boost::remove_cv
::type { public: typedef T1 first_type; typedef T2 second_type; typedef typename call_traits
::param_type first_param_type; typedef typename call_traits
::param_type second_param_type; typedef typename call_traits
::reference first_reference; typedef typename call_traits
::reference second_reference; typedef typename call_traits
::const_reference first_const_reference; typedef typename call_traits
::const_reference second_const_reference; compressed_pair_imp() {} compressed_pair_imp(first_param_type x, second_param_type y) : first_type(x), second_type(y) {} compressed_pair_imp(first_param_type x) : first_type(x) {} compressed_pair_imp(second_param_type y) : second_type(y) {} first_reference first() {return *this;} first_const_reference first() const {return *this;} second_reference second() {return *this;} second_const_reference second() const {return *this;} // // no need to swap empty bases: void swap(::boost::compressed_pair
&) {} }; // JM // 4 T1 == T2, T1 and T2 both empty // Originally this did not store an instance of T2 at all // but that led to problems beause it meant &x.first() == &x.second() // which is not true for any other kind of pair, so now we store an instance // of T2 just in case the user is relying on first() and second() returning // different objects (albeit both empty). template
class compressed_pair_imp
: protected ::boost::remove_cv
::type { public: typedef T1 first_type; typedef T2 second_type; typedef typename call_traits
::param_type first_param_type; typedef typename call_traits
::param_type second_param_type; typedef typename call_traits
::reference first_reference; typedef typename call_traits
::reference second_reference; typedef typename call_traits
::const_reference first_const_reference; typedef typename call_traits
::const_reference second_const_reference; compressed_pair_imp() {} compressed_pair_imp(first_param_type x, second_param_type y) : first_type(x), m_second(y) {} compressed_pair_imp(first_param_type x) : first_type(x), m_second(x) {} first_reference first() {return *this;} first_const_reference first() const {return *this;} second_reference second() {return m_second;} second_const_reference second() const {return m_second;} void swap(::boost::compressed_pair
&) {} private: T2 m_second; }; // 5 T1 == T2 and are not empty: //JM template
class compressed_pair_imp
{ public: typedef T1 first_type; typedef T2 second_type; typedef typename call_traits
::param_type first_param_type; typedef typename call_traits
::param_type second_param_type; typedef typename call_traits
::reference first_reference; typedef typename call_traits
::reference second_reference; typedef typename call_traits
::const_reference first_const_reference; typedef typename call_traits
::const_reference second_const_reference; compressed_pair_imp() {} compressed_pair_imp(first_param_type x, second_param_type y) : first_(x), second_(y) {} compressed_pair_imp(first_param_type x) : first_(x), second_(x) {} first_reference first() {return first_;} first_const_reference first() const {return first_;} second_reference second() {return second_;} second_const_reference second() const {return second_;} void swap(::boost::compressed_pair
& y) { cp_swap(first_, y.first()); cp_swap(second_, y.second()); } private: first_type first_; second_type second_; }; } // details template
class compressed_pair : private ::boost::details::compressed_pair_imp
::type, typename remove_cv
::type>::value, ::boost::is_empty
::value, ::boost::is_empty
::value>::value> { private: typedef details::compressed_pair_imp
::type, typename remove_cv
::type>::value, ::boost::is_empty
::value, ::boost::is_empty
::value>::value> base; public: typedef T1 first_type; typedef T2 second_type; typedef typename call_traits
::param_type first_param_type; typedef typename call_traits
::param_type second_param_type; typedef typename call_traits
::reference first_reference; typedef typename call_traits
::reference second_reference; typedef typename call_traits
::const_reference first_const_reference; typedef typename call_traits
::const_reference second_const_reference; compressed_pair() : base() {} compressed_pair(first_param_type x, second_param_type y) : base(x, y) {} explicit compressed_pair(first_param_type x) : base(x) {} explicit compressed_pair(second_param_type y) : base(y) {} first_reference first() {return base::first();} first_const_reference first() const {return base::first();} second_reference second() {return base::second();} second_const_reference second() const {return base::second();} void swap(compressed_pair& y) { base::swap(y); } }; // JM // Partial specialisation for case where T1 == T2: // template
class compressed_pair
: private details::compressed_pair_imp
::type, typename remove_cv
::type>::value, ::boost::is_empty
::value, ::boost::is_empty
::value>::value> { private: typedef details::compressed_pair_imp
::type, typename remove_cv
::type>::value, ::boost::is_empty
::value, ::boost::is_empty
::value>::value> base; public: typedef T first_type; typedef T second_type; typedef typename call_traits
::param_type first_param_type; typedef typename call_traits
::param_type second_param_type; typedef typename call_traits
::reference first_reference; typedef typename call_traits
::reference second_reference; typedef typename call_traits
::const_reference first_const_reference; typedef typename call_traits
::const_reference second_const_reference; compressed_pair() : base() {} compressed_pair(first_param_type x, second_param_type y) : base(x, y) {} #if !(defined(__SUNPRO_CC) && (__SUNPRO_CC <= 0x530)) explicit #endif compressed_pair(first_param_type x) : base(x) {} first_reference first() {return base::first();} first_const_reference first() const {return base::first();} second_reference second() {return base::second();} second_const_reference second() const {return base::second();} void swap(::boost::compressed_pair
& y) { base::swap(y); } }; template
inline void swap(compressed_pair
& x, compressed_pair
& y) { x.swap(y); } } // boost #ifdef BOOST_MSVC # pragma warning(pop) #endif #endif // BOOST_DETAIL_COMPRESSED_PAIR_HPP
compressed_pair.hpp
网页地址
文件地址
上一页
14/61
下一页
下载
( 16 KB )
Comments
Total ratings:
0
Average rating:
无评论
of 10
Would you like to comment?
Join now
, or
Logon
if you are already a member.