| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460 | //-----------------------------------------------------------------------------// boost variant/variant.hpp header file// See http://www.boost.org for updates, documentation, and revision history.//-----------------------------------------------------------------------------//// Copyright (c) 2002-2003 Eric Friedman, Itay Maman// Copyright (c) 2012-2013 Antony Polukhin//// 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)// Thanks to Adam Romanek for providing patches for exception-disabled env.#ifndef BOOST_VARIANT_VARIANT_HPP#define BOOST_VARIANT_VARIANT_HPP#include <cstddef> // for std::size_t#include <new> // for placement new#if !defined(BOOST_NO_TYPEID)#include <typeinfo> // for typeid, std::type_info#endif // BOOST_NO_TYPEID#include "boost/variant/detail/config.hpp"#include "boost/mpl/aux_/config/eti.hpp"#include "boost/mpl/aux_/value_wknd.hpp"#include "boost/variant/variant_fwd.hpp"#include "boost/variant/detail/backup_holder.hpp"#include "boost/variant/detail/enable_recursive_fwd.hpp"#include "boost/variant/detail/forced_return.hpp"#include "boost/variant/detail/initializer.hpp"#include "boost/variant/detail/make_variant_list.hpp"#include "boost/variant/detail/over_sequence.hpp"#include "boost/variant/detail/visitation_impl.hpp"#include "boost/variant/detail/hash_variant.hpp"#include "boost/variant/detail/generic_result_type.hpp"#include "boost/variant/detail/move.hpp"#include "boost/detail/no_exceptions_support.hpp"#include "boost/detail/reference_content.hpp"#include "boost/aligned_storage.hpp"#include "boost/blank.hpp"#include "boost/math/common_factor_ct.hpp"#include "boost/static_assert.hpp"#include "boost/preprocessor/cat.hpp"#include "boost/preprocessor/repeat.hpp"#include "boost/type_traits/alignment_of.hpp"#include "boost/type_traits/add_const.hpp"#include "boost/type_traits/has_nothrow_constructor.hpp"#include "boost/type_traits/has_nothrow_copy.hpp"#include "boost/type_traits/is_nothrow_move_constructible.hpp"#include "boost/type_traits/is_const.hpp"#include "boost/type_traits/is_same.hpp"#include "boost/type_traits/is_rvalue_reference.hpp"#include "boost/utility/enable_if.hpp"#include "boost/utility/declval.hpp"#include "boost/variant/recursive_wrapper_fwd.hpp"#include "boost/variant/static_visitor.hpp"#include "boost/mpl/assert.hpp"#include "boost/mpl/begin_end.hpp"#include "boost/mpl/bool.hpp"#include "boost/mpl/deref.hpp"#include "boost/mpl/empty.hpp"#include "boost/mpl/eval_if.hpp"#include "boost/mpl/find_if.hpp"#include "boost/mpl/fold.hpp"#include "boost/mpl/front.hpp"#include "boost/mpl/identity.hpp"#include "boost/mpl/if.hpp"#include "boost/mpl/int.hpp"#include "boost/mpl/is_sequence.hpp"#include "boost/mpl/iterator_range.hpp"#include "boost/mpl/iter_fold_if.hpp"#include "boost/mpl/logical.hpp"#include "boost/mpl/max_element.hpp"#include "boost/mpl/next.hpp"#include "boost/mpl/not.hpp"#include "boost/mpl/pair.hpp"#include "boost/mpl/protect.hpp"#include "boost/mpl/push_front.hpp"#include "boost/mpl/same_as.hpp"#include "boost/mpl/size_t.hpp"#include "boost/mpl/sizeof.hpp"#include "boost/mpl/transform.hpp"///////////////////////////////////////////////////////////////////////////////// Implementation Macros://// BOOST_VARIANT_VISITATION_UNROLLING_LIMIT//   Defined in boost/variant/detail/visitation_impl.hpp.//// BOOST_VARIANT_MINIMIZE_SIZE//   When #defined, implementation employs all known means to minimize the//   size of variant obje   cts. However, often unsuccessful due to alignment//   issues, and potentially harmful to runtime speed, so not enabled by//   default. (TODO: Investigate further.)#if defined(BOOST_VARIANT_MINIMIZE_SIZE)#   include <climits> // for SCHAR_MAX#   include "boost/mpl/eval_if.hpp"#   include "boost/mpl/equal_to.hpp"#   include "boost/mpl/identity.hpp"#   include "boost/mpl/int.hpp"#   include "boost/mpl/if.hpp"#   include "boost/mpl/less.hpp"#   include "boost/mpl/long.hpp"#   include "boost/mpl/O1_size.hpp"#endifnamespace boost {namespace detail { namespace variant {///////////////////////////////////////////////////////////////////////////////// (detail) metafunction max_value//// Finds the maximum value of the unary metafunction F over Sequence.//template <typename Sequence, typename F>struct max_value{private: // helpers, for metafunction result (below)    typedef typename mpl::transform1<Sequence, F>::type transformed_;    typedef typename mpl::max_element<transformed_                  >::type max_it;public: // metafunction result    typedef typename mpl::deref<max_it>::type        type;};struct add_alignment{    template <typename State, typename Item>    struct apply        : mpl::size_t<              ::boost::math::static_lcm<                  BOOST_MPL_AUX_VALUE_WKND(State)::value                , ::boost::alignment_of<Item>::value                >::value            >    {};};///////////////////////////////////////////////////////////////////////////////// (detail) metafunction find_fallback_type//// Provides a fallback (i.e., nothrow default-constructible) type from the// specified sequence, or no_fallback_type if not found.//// This implementation is designed to prefer boost::blank over other potential// fallback types, regardless of its position in the specified sequence.//class no_fallback_type;struct find_fallback_type_pred{    template <typename Iterator>    struct apply    {    private:        typedef typename mpl::deref<Iterator>::type t_;    public:        typedef mpl::not_< has_nothrow_constructor<t_> > type;    };};template <typename Types>struct find_fallback_type{private: // helpers, for metafunction result (below)    typedef typename mpl::end<Types>::type end_it;    // [Find the first suitable fallback type...]    typedef typename mpl::iter_fold_if<          Types        , mpl::int_<0>, mpl::protect< mpl::next<> >        , mpl::protect< find_fallback_type_pred >        >::type first_result_;    typedef typename first_result_::first first_result_index;    typedef typename first_result_::second first_result_it;    // [...now search the rest of the sequence for boost::blank...]    typedef typename mpl::iter_fold_if<          mpl::iterator_range< first_result_it,end_it >        , first_result_index, mpl::protect< mpl::next<> >        , mpl::protect< mpl::not_same_as<boost::blank> >        >::type second_result_;    typedef typename second_result_::second second_result_it;public: // metafunction result    // [...and return the results of the search:]    typedef typename mpl::eval_if<          is_same< second_result_it,end_it >        , mpl::if_<              is_same< first_result_it,end_it >            , mpl::pair< no_fallback_type,no_fallback_type >            , first_result_            >        , mpl::identity< second_result_ >        >::type type;};#if defined(BOOST_MPL_CFG_MSVC_60_ETI_BUG)template<>struct find_fallback_type<int>{    typedef mpl::pair< no_fallback_type,no_fallback_type > type;};#endif // BOOST_MPL_CFG_MSVC_60_ETI_BUG workaround#ifndef BOOST_NO_CXX11_NOEXCEPT///////////////////////////////////////////////////////////////////////////////// (detail) metafunction is_variant_move_noexcept//// Returns true_type if all the types are nothrow move constructible.//template <class Types>struct is_variant_move_noexcept {    typedef typename boost::mpl::find_if<        Types, mpl::not_<boost::is_nothrow_move_constructible<boost::mpl::_1> >    >::type iterator_t;    typedef typename boost::mpl::end<Types>::type end_t;    typedef typename boost::is_same<        iterator_t, end_t    >::type type;};#endif // BOOST_NO_CXX11_NOEXCEPT///////////////////////////////////////////////////////////////////////////////// (detail) metafunction make_storage//// Provides an aligned storage type capable of holding any of the types// specified in the given type-sequence.//template <typename Types, typename NeverUsesBackupFlag>struct make_storage{private: // helpers, for metafunction result (below)    typedef typename mpl::eval_if<          NeverUsesBackupFlag        , mpl::identity< Types >        , mpl::push_front<              Types, backup_holder<void*>            >        >::type types;    typedef typename max_value<          types, mpl::sizeof_<mpl::_1>        >::type max_size;#if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x0551))    typedef typename mpl::fold<          types        , mpl::size_t<1>        , add_alignment        >::type max_alignment;#else // borland    // temporary workaround -- use maximal alignment    typedef mpl::size_t< -1 > max_alignment;#endif // borland workaroundpublic: // metafunction result#if !BOOST_WORKAROUND(BOOST_MSVC, <= 1300)    typedef ::boost::aligned_storage<          BOOST_MPL_AUX_VALUE_WKND(max_size)::value        , BOOST_MPL_AUX_VALUE_WKND(max_alignment)::value        > type;#else // MSVC7 and below    BOOST_STATIC_CONSTANT(std::size_t, msvc_max_size_c = max_size::value);    BOOST_STATIC_CONSTANT(std::size_t, msvc_max_alignment_c = max_alignment::value);    typedef ::boost::aligned_storage<          msvc_max_size_c        , msvc_max_alignment_c        > type;#endif // MSVC workaround};#if defined(BOOST_MPL_CFG_MSVC_60_ETI_BUG)template<>struct make_storage<int,int>{    typedef int type;};#endif // BOOST_MPL_CFG_MSVC_60_ETI_BUG workaround///////////////////////////////////////////////////////////////////////////////// (detail) class destroyer//// Internal visitor that destroys the value it visits.//struct destroyer    : public static_visitor<>{public: // visitor interfaces    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(T& operand, int) const    {        operand.~T();#if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x0551)) || \    BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1600))        operand; // suppresses warnings#endif        BOOST_VARIANT_AUX_RETURN_VOID;    }};///////////////////////////////////////////////////////////////////////////////// (detail) class template known_get//// Visitor that returns a reference to content of the specified type.//// Precondition: visited variant MUST contain logical content of type T.//template <typename T>class known_get    : public static_visitor<T&>{#if !BOOST_WORKAROUND(BOOST_MSVC, < 1300)public: // visitor interface    T& operator()(T& operand) const BOOST_NOEXCEPT    {        return operand;    }#if defined BOOST_MSVC # pragma warning( push ) # pragma warning( disable : 4702 ) // unreachable code #endif     template <typename U>    T& operator()(U&) const    {        // logical error to be here: see precondition above        BOOST_ASSERT(false);        return ::boost::detail::variant::forced_return< T& >();    }#if defined BOOST_MSVC # pragma warning( pop ) #endif#else // MSVC6private: // helpers, for visitor interface (below)    T& execute(T& operand, mpl::true_) const    {        return operand;    }    template <typename U>    T& execute(U& operand, mpl::false_) const    {        // logical error to be here: see precondition above        BOOST_ASSERT(false);        return ::boost::detail::variant::forced_return< T& >();    }public: // visitor interface    template <typename U>    T& operator()(U& operand) const    {        typedef typename is_same< U,T >::type            U_is_T;        return execute(operand, U_is_T());    }#endif // MSVC6 workaround};///////////////////////////////////////////////////////////////////////////////// (detail) class copy_into//// Internal visitor that copies the value it visits into the given buffer.//class copy_into    : public static_visitor<>{private: // representation    void* storage_;public: // structors    explicit copy_into(void* storage) BOOST_NOEXCEPT        : storage_(storage)    {    }public: // internal visitor interface    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(boost::detail::variant::backup_holder<T>& operand, long) const    {        new(storage_) T( operand.get() );        BOOST_VARIANT_AUX_RETURN_VOID;    }    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(const boost::detail::variant::backup_holder<T>& operand, long) const    {        new(storage_) T( operand.get() );        BOOST_VARIANT_AUX_RETURN_VOID;    }    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(const T& operand, int) const    {        new(storage_) T(operand);        BOOST_VARIANT_AUX_RETURN_VOID;    }};///////////////////////////////////////////////////////////////////////////////// (detail) class move_into//// Internal visitor that moves the value it visits into the given buffer.//#ifndef BOOST_NO_CXX11_RVALUE_REFERENCESclass move_into    : public static_visitor<>{private: // representation    void* storage_;public: // structors    explicit move_into(void* storage) BOOST_NOEXCEPT        : storage_(storage)    {    }public: // internal visitor interface    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(boost::detail::variant::backup_holder<T>& operand, long) const    {        new(storage_) T( ::boost::detail::variant::move(operand.get()) );        BOOST_VARIANT_AUX_RETURN_VOID;    }    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(T& operand, int) const BOOST_NOEXCEPT_IF(BOOST_NOEXCEPT_EXPR(T(boost::declval<T>())))    {        new(storage_) T(::boost::detail::variant::move(operand));        BOOST_VARIANT_AUX_RETURN_VOID;    }};#endif///////////////////////////////////////////////////////////////////////////////// (detail) class assign_storage//// Internal visitor that assigns the given storage (which must be a// constructed value of the same type) to the value it visits.//struct assign_storage    : public static_visitor<>{private: // representation    const void* rhs_storage_;public: // structors    explicit assign_storage(const void* rhs_storage) BOOST_NOEXCEPT        : rhs_storage_(rhs_storage)    {    }public: // internal visitor interfaces    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(backup_holder<T>& lhs_content, long) const    {        lhs_content.get()            = static_cast< const backup_holder<T>* >(rhs_storage_)->get();        BOOST_VARIANT_AUX_RETURN_VOID;    }    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(const backup_holder<T>& lhs_content, long) const    {        lhs_content.get()            = static_cast< const backup_holder<T>* >(rhs_storage_)->get();        BOOST_VARIANT_AUX_RETURN_VOID;    }    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(T& lhs_content, int) const    {        // NOTE TO USER :        // Compile error here indicates one of variant's bounded types does        // not meet the requirements of the Assignable concept. Thus,        // variant is not Assignable.        //        // Hint: Are any of the bounded types const-qualified or references?        //        lhs_content = *static_cast< const T* >(rhs_storage_);        BOOST_VARIANT_AUX_RETURN_VOID;    }};///////////////////////////////////////////////////////////////////////////////// (detail) class move_storage//// Internal visitor that moves the given storage (which must be a// constructed value of the same type) to the value it visits.//struct move_storage    : public static_visitor<>{private: // representation    void* rhs_storage_;public: // structors    explicit move_storage(void* rhs_storage) BOOST_NOEXCEPT        : rhs_storage_(rhs_storage)    {    }public: // internal visitor interfaces    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(backup_holder<T>& lhs_content, long) const    {        lhs_content.get()            = ::boost::detail::variant::move(static_cast<backup_holder<T>* >(rhs_storage_)->get());        BOOST_VARIANT_AUX_RETURN_VOID;    }    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(const backup_holder<T>& lhs_content, long) const    {        lhs_content.get()            = ::boost::detail::variant::move(static_cast<backup_holder<T>* >(rhs_storage_)->get());        BOOST_VARIANT_AUX_RETURN_VOID;    }    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(T& lhs_content, int) const    {        // NOTE TO USER :        // Compile error here indicates one of variant's bounded types does        // not meet the requirements of the Assignable concept. Thus,        // variant is not Assignable.        //        // Hint: Are any of the bounded types const-qualified or references?        //        lhs_content = ::boost::detail::variant::move(*static_cast<T* >(rhs_storage_));        BOOST_VARIANT_AUX_RETURN_VOID;    }};///////////////////////////////////////////////////////////////////////////////// (detail) class direct_assigner//// Generic static visitor that: if and only if the visited value is of the// specified type, assigns the given value to the visited value and returns// true; else returns false.//template <typename T>class direct_assigner    : public static_visitor<bool>{private: // representation    const T& rhs_;public: // structors    explicit direct_assigner(const T& rhs) BOOST_NOEXCEPT        : rhs_(rhs)    {    }#if !BOOST_WORKAROUND(BOOST_MSVC, < 1300)public: // visitor interface    bool operator()(T& lhs)    {        lhs = rhs_;        return true;    }    template <typename U>    bool operator()(U&) BOOST_NOEXCEPT    {        return false;    }#else // MSVC6private: // helpers, for visitor interface (below)    bool execute(T& lhs, mpl::true_)    {        lhs = rhs_;        return true;    }    template <typename U>    bool execute(U&, mpl::false_)    {        return false;    }public: // visitor interface    template <typename U>    bool operator()(U& lhs)    {        typedef typename is_same<U,T>::type U_is_T;        return execute(lhs, U_is_T());    }#endif // MSVC6 workaround#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1600))private:    // silence MSVC warning C4512: assignment operator could not be generated    direct_assigner& operator= (direct_assigner const&);#endif};///////////////////////////////////////////////////////////////////////////////// (detail) class direct_mover//// Generic static visitor that: if and only if the visited value is of the// specified type, move assigns the given value to the visited value and returns// true; else returns false.//template <typename T>class direct_mover    : public static_visitor<bool>{private: // representation    T& rhs_;public: // structors    explicit direct_mover(T& rhs) BOOST_NOEXCEPT        : rhs_(rhs)    {    }#if !BOOST_WORKAROUND(BOOST_MSVC, < 1300)public: // visitor interface    bool operator()(T& lhs)    {        lhs = ::boost::detail::variant::move(rhs_);        return true;    }    template <typename U>    bool operator()(U&) BOOST_NOEXCEPT    {        return false;    }#else // MSVC6public: // visitor interface    template <typename U>    bool operator()(U& lhs)    {        // MSVC6 can not use direct_mover class        return direct_assigner(rhs_)(lhs);    }#endif // MSVC6 workaround#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1600))private:    // silence MSVC warning C4512: assignment operator could not be generated    direct_mover& operator= (direct_mover const&);#endif};///////////////////////////////////////////////////////////////////////////////// (detail) class backup_assigner//// Internal visitor that "assigns" the given value to the visited value,// using backup to recover if the destroy-copy sequence fails.//// NOTE: This needs to be a friend of variant, as it needs access to// indicate_which, indicate_backup_which, etc.//template <typename Variant>class backup_assigner    : public static_visitor<>{private: // representation    Variant& lhs_;    int rhs_which_;    const void* rhs_content_;    void (*copy_rhs_content_)(void*, const void*);public: // structors    template<class RhsT>    backup_assigner(Variant& lhs, int rhs_which, const RhsT& rhs_content)        : lhs_(lhs)        , rhs_which_(rhs_which)        , rhs_content_(&rhs_content)        , copy_rhs_content_(&construct_impl<RhsT>)    {    }private: // helpers, for visitor interface (below)    template<class RhsT>    static void construct_impl(void* addr, const void* obj)    {        new(addr) RhsT(*static_cast<const RhsT*>(obj));    }    template <typename LhsT>    void backup_assign_impl(          LhsT& lhs_content        , mpl::true_ // is_nothrow_move_constructible        )    {        // Move lhs content to backup...        LhsT backup_lhs_content(              ::boost::detail::variant::move(lhs_content)            ); // nothrow        // ...destroy lhs content...        lhs_content.~LhsT(); // nothrow        BOOST_TRY        {            // ...and attempt to copy rhs content into lhs storage:            copy_rhs_content_(lhs_.storage_.address(), rhs_content_);        }        BOOST_CATCH (...)        {            // In case of failure, restore backup content to lhs storage...            new(lhs_.storage_.address())                LhsT(                      ::boost::detail::variant::move(backup_lhs_content)                    ); // nothrow            // ...and rethrow:            BOOST_RETHROW;        }        BOOST_CATCH_END        // In case of success, indicate new content type:        lhs_.indicate_which(rhs_which_); // nothrow    }    template <typename LhsT>    void backup_assign_impl(          LhsT& lhs_content        , mpl::false_ // is_nothrow_move_constructible        )    {        // Backup lhs content...        LhsT* backup_lhs_ptr = new LhsT(lhs_content);        // ...destroy lhs content...        lhs_content.~LhsT(); // nothrow        BOOST_TRY        {            // ...and attempt to copy rhs content into lhs storage:            copy_rhs_content_(lhs_.storage_.address(), rhs_content_);        }        BOOST_CATCH (...)        {            // In case of failure, copy backup pointer to lhs storage...            new(lhs_.storage_.address())                backup_holder<LhsT>( backup_lhs_ptr ); // nothrow            // ...indicate now using backup...            lhs_.indicate_backup_which( lhs_.which() ); // nothrow            // ...and rethrow:            BOOST_RETHROW;        }        BOOST_CATCH_END        // In case of success, indicate new content type...        lhs_.indicate_which(rhs_which_); // nothrow        // ...and delete backup:        delete backup_lhs_ptr; // nothrow    }public: // visitor interface    template <typename LhsT>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    internal_visit(LhsT& lhs_content, int)    {        typedef typename is_nothrow_move_constructible<LhsT>::type            nothrow_move;        backup_assign_impl( lhs_content, nothrow_move() );        BOOST_VARIANT_AUX_RETURN_VOID;    }#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1600))private:    // silence MSVC warning C4512: assignment operator could not be generated    backup_assigner& operator= (backup_assigner const&);#endif};///////////////////////////////////////////////////////////////////////////////// (detail) class swap_with//// Visitor that swaps visited value with content of given variant.//// Precondition: Given variant MUST have same logical type as visited value.//template <typename Variant>struct swap_with    : public static_visitor<>{private: // representation    Variant& toswap_;public: // structors    explicit swap_with(Variant& toswap)        : toswap_(toswap)    {    }public: // internal visitor interfaces    template <typename T>    void operator()(T& operand) const    {        // Since the precondition ensures types are same, get T...        known_get<T> getter;        T& other = toswap_.apply_visitor(getter);        // ...and swap:        ::boost::detail::variant::move_swap( operand, other );    }private:    swap_with& operator=(const swap_with&);};///////////////////////////////////////////////////////////////////////////////// (detail) class reflect//// Generic static visitor that performs a typeid on the value it visits.//#if !defined(BOOST_NO_TYPEID)class reflect    : public static_visitor<const std::type_info&>{public: // visitor interfaces    template <typename T>    const std::type_info& operator()(const T&) const BOOST_NOEXCEPT    {        return typeid(T);    }};#endif // BOOST_NO_TYPEID///////////////////////////////////////////////////////////////////////////////// (detail) class comparer//// Generic static visitor that compares the content of the given lhs variant// with the visited rhs content using Comp.//// Precondition: lhs.which() == rhs.which()//template <typename Variant, typename Comp>class comparer    : public static_visitor<bool>{private: // representation    const Variant& lhs_;public: // structors    explicit comparer(const Variant& lhs) BOOST_NOEXCEPT        : lhs_(lhs)    {    }public: // visitor interfaces    template <typename T>    bool operator()(const T& rhs_content) const    {        // Since the precondition ensures lhs and rhs types are same, get T...        known_get<const T> getter;        const T& lhs_content = lhs_.apply_visitor(getter);        // ...and compare lhs and rhs contents:        return Comp()(lhs_content, rhs_content);    }private:    comparer& operator=(const comparer&);};///////////////////////////////////////////////////////////////////////////////// (detail) class equal_comp//// Generic function object compares lhs with rhs using operator==.//struct equal_comp{    template <typename T>    bool operator()(const T& lhs, const T& rhs) const    {        return lhs == rhs;    }};///////////////////////////////////////////////////////////////////////////////// (detail) class less_comp//// Generic function object compares lhs with rhs using operator<.//struct less_comp{    template <typename T>    bool operator()(const T& lhs, const T& rhs) const    {        return lhs < rhs;    }};///////////////////////////////////////////////////////////////////////////////// (detail) class template invoke_visitor//// Internal visitor that invokes the given visitor using://  * for wrappers (e.g., recursive_wrapper), the wrapper's held value.//  * for all other values, the value itself.//template <typename Visitor>class invoke_visitor{private: // representation    Visitor& visitor_;public: // visitor typedefs    typedef typename Visitor::result_type        result_type;public: // structors    explicit invoke_visitor(Visitor& visitor) BOOST_NOEXCEPT        : visitor_(visitor)    {    }#if !defined(BOOST_NO_VOID_RETURNS)public: // internal visitor interfaces    template <typename T>    result_type internal_visit(T& operand, int)    {        return visitor_(operand);    }#   if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x0564))    template <typename T>    result_type internal_visit(const T& operand, int)    {        return visitor_(operand);    }#   endif#else // defined(BOOST_NO_VOID_RETURNS)private: // helpers, for internal visitor interfaces (below)    template <typename T>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(result_type)    visit_impl(T& operand, mpl::false_)    {        return visitor_(operand);    }    template <typename T>        BOOST_VARIANT_AUX_RETURN_VOID_TYPE    visit_impl(T& operand, mpl::true_)    {        visitor_(operand);        BOOST_VARIANT_AUX_RETURN_VOID;    }public: // internal visitor interfaces    template <typename T>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(result_type)    internal_visit(T& operand, int)    {        typedef typename is_same<result_type, void>::type            has_void_result_type;        return visit_impl(operand, has_void_result_type());    }#endif // BOOST_NO_VOID_RETURNS) workaroundpublic: // internal visitor interfaces, cont.    template <typename T>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(result_type)    internal_visit(boost::recursive_wrapper<T>& operand, long)    {        return internal_visit( operand.get(), 1L );    }    template <typename T>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(result_type)    internal_visit(const boost::recursive_wrapper<T>& operand, long)    {        return internal_visit( operand.get(), 1L );    }    template <typename T>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(result_type)    internal_visit(boost::detail::reference_content<T>& operand, long)    {        return internal_visit( operand.get(), 1L );    }    template <typename T>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(result_type)    internal_visit(const boost::detail::reference_content<T>& operand, long)    {        return internal_visit( operand.get(), 1L );    }    template <typename T>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(result_type)    internal_visit(boost::detail::variant::backup_holder<T>& operand, long)    {        return internal_visit( operand.get(), 1L );    }    template <typename T>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(result_type)    internal_visit(const boost::detail::variant::backup_holder<T>& operand, long)    {        return internal_visit( operand.get(), 1L );    }#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1600))private:    // silence MSVC warning C4512: assignment operator could not be generated    invoke_visitor& operator= (invoke_visitor const&);#endif};}} // namespace detail::variant///////////////////////////////////////////////////////////////////////////////// class template variant (concept inspired by Andrei Alexandrescu)//// See docs and boost/variant/variant_fwd.hpp for more information.//template <      typename T0_    , BOOST_VARIANT_ENUM_SHIFTED_PARAMS(typename T)    >class variant{private: // helpers, for typedefs (below)    typedef variant wknd_self_t;    struct is_recursive_        : detail::variant::is_recursive_flag<T0_>    {    };    typedef typename mpl::eval_if<          is_recursive_        , T0_        , mpl::identity< T0_ >        >::type unwrapped_T0_;    struct is_sequence_based_        : detail::variant::is_over_sequence<unwrapped_T0_>    {    };#if !defined(BOOST_VARIANT_NO_TYPE_SEQUENCE_SUPPORT)private: // helpers, for typedefs (below)    typedef typename mpl::eval_if<          is_sequence_based_        , unwrapped_T0_ // over_sequence<...>::type        , detail::variant::make_variant_list<              unwrapped_T0_            , BOOST_VARIANT_ENUM_SHIFTED_PARAMS(T)            >        >::type specified_types;    BOOST_STATIC_ASSERT((          ::boost::mpl::not_< mpl::empty<specified_types> >::value        ));    typedef typename mpl::eval_if<          is_recursive_        , mpl::transform<              specified_types            , mpl::protect<                  detail::variant::quoted_enable_recursive<wknd_self_t>                >            >        , mpl::identity< specified_types >        >::type recursive_enabled_types;public: // public typedefs    typedef typename mpl::transform<          recursive_enabled_types        , unwrap_recursive<mpl::_1>        >::type types;private: // internal typedefs    typedef typename mpl::transform<          recursive_enabled_types        , mpl::protect< detail::make_reference_content<> >        >::type internal_types;    typedef typename mpl::front<          internal_types        >::type internal_T0;#else // defined(BOOST_VARIANT_NO_TYPE_SEQUENCE_SUPPORT)private: // helpers, for typedefs (below)    typedef unwrapped_T0_ T0;    #define BOOST_VARIANT_AUX_ENABLE_RECURSIVE_TYPEDEFS(z,N,_) \        typedef typename mpl::eval_if< \              is_recursive_ \            , detail::variant::enable_recursive< \                  BOOST_PP_CAT(T,N) \                , wknd_self_t \                > \            , mpl::identity< BOOST_PP_CAT(T,N) > \            >::type BOOST_PP_CAT(recursive_enabled_T,N); \        /**/    BOOST_PP_REPEAT(          BOOST_VARIANT_LIMIT_TYPES        , BOOST_VARIANT_AUX_ENABLE_RECURSIVE_TYPEDEFS        , _        )    #undef BOOST_VARIANT_AUX_ENABLE_RECURSIVE_TYPEDEFS    #define BOOST_VARIANT_AUX_UNWRAP_RECURSIVE_TYPEDEFS(z,N,_) \        typedef typename unwrap_recursive< \              BOOST_PP_CAT(recursive_enabled_T,N) \            >::type BOOST_PP_CAT(public_T,N); \        /**/    BOOST_PP_REPEAT(          BOOST_VARIANT_LIMIT_TYPES        , BOOST_VARIANT_AUX_UNWRAP_RECURSIVE_TYPEDEFS        , _        )    #undef BOOST_VARIANT_AUX_UNWRAP_RECURSIVE_TYPEDEFSpublic: // public typedefs    typedef typename detail::variant::make_variant_list<          BOOST_VARIANT_ENUM_PARAMS(public_T)        >::type types;private: // helpers, for internal typedefs (below)    #define BOOST_VARIANT_AUX_MAKE_REFERENCE_CONTENT_TYPEDEFS(z,N,_) \        typedef detail::make_reference_content< \              BOOST_PP_CAT(recursive_enabled_T,N) \            >::type BOOST_PP_CAT(internal_T,N); \        /**/    BOOST_PP_REPEAT(          BOOST_VARIANT_LIMIT_TYPES        , BOOST_VARIANT_AUX_MAKE_REFERENCE_CONTENT_TYPEDEFS        , _        )    #undef BOOST_VARIANT_AUX_MAKE_REFERENCE_CONTENT_TYPEDEFSprivate: // internal typedefs    typedef typename detail::variant::make_variant_list<          BOOST_VARIANT_ENUM_PARAMS(internal_T)        >::type internal_types;private: // static precondition assertions    // NOTE TO USER :    // variant< type-sequence > syntax is not supported on this compiler!    //    BOOST_MPL_ASSERT_NOT(( is_sequence_based_ ));#endif // BOOST_VARIANT_NO_TYPE_SEQUENCE_SUPPORT workaroundprivate: // helpers, for representation (below)    typedef typename detail::variant::find_fallback_type<          internal_types        >::type fallback_type_result_;    typedef typename fallback_type_result_::first        fallback_type_index_;    typedef typename fallback_type_result_::second        fallback_type_;    struct has_fallback_type_        : mpl::not_<              is_same< fallback_type_, detail::variant::no_fallback_type >            >    {    };    typedef has_fallback_type_        never_uses_backup_flag;    typedef typename detail::variant::make_storage<          internal_types, never_uses_backup_flag        >::type storage_t;#ifndef BOOST_NO_CXX11_NOEXCEPT    typedef typename detail::variant::is_variant_move_noexcept<        internal_types    > variant_move_noexcept;#endifprivate: // helpers, for representation (below)    // which_ on:    // * [0,  size<internal_types>) indicates stack content    // * [-size<internal_types>, 0) indicates pointer to heap backup    // if which_ >= 0:    // * then which() -> which_    // * else which() -> -(which_ + 1)#if !defined(BOOST_VARIANT_MINIMIZE_SIZE)    typedef int which_t;#else // defined(BOOST_VARIANT_MINIMIZE_SIZE)    // [if O1_size available, then attempt which_t size optimization...]    // [select signed char if fewer than SCHAR_MAX types, else signed int:]    typedef typename mpl::eval_if<          mpl::equal_to< mpl::O1_size<internal_types>, mpl::long_<-1> >        , mpl::identity< int >        , mpl::if_<              mpl::less< mpl::O1_size<internal_types>, mpl::int_<SCHAR_MAX> >            , signed char            , int            >        >::type which_t;#endif // BOOST_VARIANT_MINIMIZE_SIZE switch// representation -- private when possible#if !defined(BOOST_NO_MEMBER_TEMPLATE_FRIENDS)    private:#else    public:#endif    which_t which_;    storage_t storage_;    void indicate_which(int which_arg) BOOST_NOEXCEPT    {        which_ = static_cast<which_t>( which_arg );    }    void indicate_backup_which(int which_arg) BOOST_NOEXCEPT    {        which_ = static_cast<which_t>( -(which_arg + 1) );    }private: // helpers, for queries (below)    bool using_backup() const BOOST_NOEXCEPT    {        return which_ < 0;    }public: // queries    int which() const BOOST_NOEXCEPT    {        // If using heap backup...        if (using_backup())            // ...then return adjusted which_:            return -(which_ + 1);        // Otherwise, return which_ directly:        return which_;    }private: // helpers, for structors (below)    struct initializer        : BOOST_VARIANT_AUX_INITIALIZER_T(              recursive_enabled_types, recursive_enabled_T            )    {    };    void destroy_content()    {        detail::variant::destroyer visitor;        this->internal_apply_visitor(visitor);    }public: // structors    ~variant() BOOST_NOEXCEPT    {        destroy_content();    }    variant()    {        // NOTE TO USER :        // Compile error from here indicates that the first bound        // type is not default-constructible, and so variant cannot        // support its own default-construction.        //        new( storage_.address() ) internal_T0();        indicate_which(0); // zero is the index of the first bounded type    }private: // helpers, for structors, cont. (below)    class convert_copy_into        : public static_visitor<int>    {    private: // representation        void* storage_;    public: // structors        explicit convert_copy_into(void* storage) BOOST_NOEXCEPT            : storage_(storage)        {        }    public: // internal visitor interfaces (below)        template <typename T>        int internal_visit(T& operand, int) const        {            // NOTE TO USER :            // Compile error here indicates one of the source variant's types             // cannot be unambiguously converted to the destination variant's            // types (or that no conversion exists).            //            return initializer::initialize(storage_, operand);        }#   if BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x0564))        template <typename T>        result_type internal_visit(const T& operand, int) const        {            return initializer::initialize(storage_, operand);        }#   endif        template <typename T>        int internal_visit(boost::detail::reference_content<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(const boost::detail::reference_content<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(boost::detail::variant::backup_holder<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(const boost::detail::variant::backup_holder<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(boost::recursive_wrapper<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(const boost::recursive_wrapper<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }    };    friend class convert_copy_into;#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    class convert_move_into        : public static_visitor<int>    {    private: // representation        void* storage_;    public: // structors        explicit convert_move_into(void* storage) BOOST_NOEXCEPT            : storage_(storage)        {        }    public: // internal visitor interfaces (below)        template <typename T>        int internal_visit(T& operand, int) const        {            // NOTE TO USER :            // Compile error here indicates one of the source variant's types             // cannot be unambiguously converted to the destination variant's            // types (or that no conversion exists).            //            return initializer::initialize(storage_, detail::variant::move(operand) );        }        template <typename T>        int internal_visit(boost::detail::reference_content<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(const boost::detail::reference_content<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(boost::detail::variant::backup_holder<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(const boost::detail::variant::backup_holder<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(boost::recursive_wrapper<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }        template <typename T>        int internal_visit(const boost::recursive_wrapper<T>& operand, long) const        {            return internal_visit( operand.get(), 1L );        }    };    friend class convert_move_into;#endifprivate: // helpers, for structors, below     template <typename T>    void convert_construct(          T& operand        , int        , mpl::false_ = mpl::false_() // is_foreign_variant        )    {        // NOTE TO USER :        // Compile error here indicates that the given type is not         // unambiguously convertible to one of the variant's types        // (or that no conversion exists).        //        indicate_which(              initializer::initialize(                  storage_.address()                , operand                )            );    }#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    template <typename T>    typename boost::enable_if<boost::is_rvalue_reference<T&&> >::type convert_construct(          T&& operand        , int        , mpl::false_ = mpl::false_() // is_foreign_variant        )    {        // NOTE TO USER :        // Compile error here indicates that the given type is not         // unambiguously convertible to one of the variant's types        // (or that no conversion exists).        //        indicate_which(              initializer::initialize(                  storage_.address()                , detail::variant::move(operand)                )            );    }#endif    template <typename Variant>    void convert_construct(          Variant& operand        , long        , mpl::true_// is_foreign_variant        )    {        convert_copy_into visitor(storage_.address());        indicate_which(              operand.internal_apply_visitor(visitor)            );    }#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    template <typename Variant>    typename boost::enable_if<boost::is_rvalue_reference<Variant&&> >::type convert_construct(          Variant&& operand        , long        , mpl::true_// is_foreign_variant        )    {        convert_move_into visitor(storage_.address());        indicate_which(              operand.internal_apply_visitor(visitor)            );    }#endif    template <typename Variant>    void convert_construct_variant(Variant& operand)    {        // [Determine if the given variant is itself a bounded type, or if its        //  content needs to be converted (i.e., it is a 'foreign' variant):]        //        typedef typename mpl::find_if<              types            , is_same<                  add_const<mpl::_1>                , const Variant                >            >::type found_it;        typedef typename mpl::end<types>::type not_found;        typedef typename is_same<              found_it, not_found            >::type is_foreign_variant;        // Convert construct from operand:        convert_construct(              operand, 1L            , is_foreign_variant()            );    }#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    template <typename Variant>    typename boost::enable_if<boost::is_rvalue_reference<Variant&&> >::type convert_construct_variant(Variant&& operand)    {        // [Determine if the given variant is itself a bounded type, or if its        //  content needs to be converted (i.e., it is a 'foreign' variant):]        //        typedef typename mpl::find_if<              types            , is_same<                  add_const<mpl::_1>                , const Variant                >            >::type found_it;        typedef typename mpl::end<types>::type not_found;        typedef typename is_same<              found_it, not_found            >::type is_foreign_variant;        // Convert move construct from operand:        convert_construct(              detail::variant::move(operand), 1L            , is_foreign_variant()            );    }#endif    template <BOOST_VARIANT_ENUM_PARAMS(typename U)>    void convert_construct(          boost::variant<BOOST_VARIANT_ENUM_PARAMS(U)>& operand        , long        )    {        convert_construct_variant(operand);    }    template <BOOST_VARIANT_ENUM_PARAMS(typename U)>    void convert_construct(          const boost::variant<BOOST_VARIANT_ENUM_PARAMS(U)>& operand        , long        )    {        convert_construct_variant(operand);        }#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    template <BOOST_VARIANT_ENUM_PARAMS(typename U)>    void convert_construct(          boost::variant<BOOST_VARIANT_ENUM_PARAMS(U)>&& operand        , long        )    {        convert_construct_variant( detail::variant::move(operand) );        }#endifpublic: // structors, cont.#if !defined(BOOST_VARIANT_AUX_BROKEN_CONSTRUCTOR_TEMPLATE_ORDERING)    template <typename T>    variant(const T& operand)    {        convert_construct(operand, 1L);    }    template <typename T>    variant(T& operand)    {        convert_construct(operand, 1L);    }#elif defined(BOOST_VARIANT_AUX_HAS_CONSTRUCTOR_TEMPLATE_ORDERING_SFINAE_WKND)    // For compilers that cannot distinguish between T& and const T& in    // template constructors, but do fully support SFINAE, we can workaround:    template <typename T>    variant(const T& operand)    {        convert_construct(operand, 1L);    }    template <typename T>    variant(          T& operand        , typename enable_if<              mpl::not_< is_const<T> >            , void            >::type* = 0        )    {        convert_construct(operand, 1L);    }#else // !defined(BOOST_VARIANT_AUX_HAS_CONSTRUCTOR_TEMPLATE_ORDERING_SFINAE_WKND)    // For compilers that cannot distinguish between T& and const T& in    // template constructors, and do NOT support SFINAE, we can't workaround:    template <typename T>    variant(const T& operand)    {        convert_construct(operand, 1L);    }#endif // BOOST_VARIANT_AUX_BROKEN_CONSTRUCTOR_TEMPLATE_ORDERING workarounds    #ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    template <class T>    variant(T&& operand, typename boost::enable_if<boost::is_rvalue_reference<T&&> >::type* = 0,         typename boost::disable_if<boost::is_const<T> >::type* = 0)    {        convert_construct( detail::variant::move(operand), 1L);    }#endifpublic: // structors, cont.    // [MSVC6 requires copy constructor appear after template constructors]    variant(const variant& operand)    {        // Copy the value of operand into *this...        detail::variant::copy_into visitor( storage_.address() );        operand.internal_apply_visitor(visitor);        // ...and activate the *this's primary storage on success:        indicate_which(operand.which());    }    #ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    variant(variant&& operand) BOOST_NOEXCEPT_IF(variant_move_noexcept::type::value)    {        // Move the value of operand into *this...        detail::variant::move_into visitor( storage_.address() );        operand.internal_apply_visitor(visitor);        // ...and activate the *this's primary storage on success:        indicate_which(operand.which());    }#endifprivate: // helpers, for modifiers (below)#   if !defined(BOOST_NO_MEMBER_TEMPLATE_FRIENDS)    template <typename Variant>    friend class detail::variant::backup_assigner;#   endif    // class assigner    //    // Internal visitor that "assigns" the visited value to the given variant    // by appropriate destruction and copy-construction.    //    class assigner        : public static_visitor<>    {    private: // representation        variant& lhs_;        int rhs_which_;    public: // structors        assigner(variant& lhs, int rhs_which) BOOST_NOEXCEPT            : lhs_(lhs)            , rhs_which_(rhs_which)        {        }    private: // helpers, for internal visitor interface (below)        template <typename RhsT, typename B1, typename B2>        void assign_impl(              const RhsT& rhs_content            , mpl::true_ // has_nothrow_copy            , B1 // is_nothrow_move_constructible            , B2 // has_fallback_type            )        {            // Destroy lhs's content...            lhs_.destroy_content(); // nothrow            // ...copy rhs content into lhs's storage...            new(lhs_.storage_.address())                RhsT( rhs_content ); // nothrow            // ...and indicate new content type:            lhs_.indicate_which(rhs_which_); // nothrow        }        template <typename RhsT, typename B>        void assign_impl(              const RhsT& rhs_content            , mpl::false_ // has_nothrow_copy            , mpl::true_ // is_nothrow_move_constructible            , B // has_fallback_type            )        {            // Attempt to make a temporary copy (so as to move it below)...            RhsT temp(rhs_content);            // ...and upon success destroy lhs's content...            lhs_.destroy_content(); // nothrow            // ...move the temporary copy into lhs's storage...            new(lhs_.storage_.address())                RhsT( detail::variant::move(temp) ); // nothrow            // ...and indicate new content type:            lhs_.indicate_which(rhs_which_); // nothrow        }        template <typename RhsT>        void assign_impl(              const RhsT& rhs_content            , mpl::false_ // has_nothrow_copy            , mpl::false_ // is_nothrow_move_constructible            , mpl::true_ // has_fallback_type            )        {            // Destroy lhs's content...            lhs_.destroy_content(); // nothrow            BOOST_TRY            {                // ...and attempt to copy rhs's content into lhs's storage:                new(lhs_.storage_.address())                    RhsT( rhs_content );            }            BOOST_CATCH (...)            {                // In case of failure, default-construct fallback type in lhs's storage...                new (lhs_.storage_.address())                    fallback_type_; // nothrow                // ...indicate construction of fallback type...                lhs_.indicate_which(                      BOOST_MPL_AUX_VALUE_WKND(fallback_type_index_)::value                    ); // nothrow                // ...and rethrow:                BOOST_RETHROW;            }            BOOST_CATCH_END            // In the event of success, indicate new content type:            lhs_.indicate_which(rhs_which_); // nothrow        }        template <typename RhsT>        void assign_impl(              const RhsT& rhs_content            , mpl::false_ // has_nothrow_copy            , mpl::false_ // is_nothrow_move_constructible            , mpl::false_ // has_fallback_type            )        {            detail::variant::backup_assigner<wknd_self_t>                visitor(lhs_, rhs_which_, rhs_content);            lhs_.internal_apply_visitor(visitor);        }    public: // internal visitor interfaces        template <typename RhsT>            BOOST_VARIANT_AUX_RETURN_VOID_TYPE        internal_visit(const RhsT& rhs_content, int)        {            typedef typename has_nothrow_copy<RhsT>::type                nothrow_copy;            typedef typename mpl::or_< // reduces compile-time                  nothrow_copy                , is_nothrow_move_constructible<RhsT>                >::type nothrow_move_constructor;            assign_impl(                  rhs_content                , nothrow_copy()                , nothrow_move_constructor()                , has_fallback_type_()                );            BOOST_VARIANT_AUX_RETURN_VOID;        }#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1600))    private:        // silence MSVC warning C4512: assignment operator could not be generated        assigner& operator= (assigner const&);#endif    };        friend class assigner;   #ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    // class move_assigner    //    // Internal visitor that "move assigns" the visited value to the given variant    // by appropriate destruction and move-construction.    //    class move_assigner        : public static_visitor<>    {    private: // representation        variant& lhs_;        int rhs_which_;    public: // structors        move_assigner(variant& lhs, int rhs_which) BOOST_NOEXCEPT            : lhs_(lhs)            , rhs_which_(rhs_which)        {        }    private: // helpers, for internal visitor interface (below)        template <typename RhsT, typename B2>        void assign_impl(              RhsT& rhs_content            , mpl::true_ // has_nothrow_copy            , mpl::false_ // is_nothrow_move_constructible            , B2 // has_fallback_type            )        {            // Destroy lhs's content...            lhs_.destroy_content(); // nothrow            // ...copy rhs content into lhs's storage...            new(lhs_.storage_.address())                RhsT( rhs_content ); // nothrow            // ...and indicate new content type:            lhs_.indicate_which(rhs_which_); // nothrow        }        template <typename RhsT, typename B>        void assign_impl(              RhsT& rhs_content            , mpl::true_ // has_nothrow_copy            , mpl::true_ // is_nothrow_move_constructible            , B // has_fallback_type            )        {            // ...destroy lhs's content...            lhs_.destroy_content(); // nothrow            // ...move the rhs_content into lhs's storage...            new(lhs_.storage_.address())                RhsT( detail::variant::move(rhs_content) ); // nothrow            // ...and indicate new content type:            lhs_.indicate_which(rhs_which_); // nothrow        }        template <typename RhsT>        void assign_impl(              RhsT& rhs_content            , mpl::false_ // has_nothrow_copy            , mpl::false_ // is_nothrow_move_constructible            , mpl::true_ // has_fallback_type            )        {            // Destroy lhs's content...            lhs_.destroy_content(); // nothrow            BOOST_TRY            {                // ...and attempt to copy rhs's content into lhs's storage:                new(lhs_.storage_.address())                    RhsT( detail::variant::move(rhs_content) );            }            BOOST_CATCH (...)            {                // In case of failure, default-construct fallback type in lhs's storage...                new (lhs_.storage_.address())                    fallback_type_; // nothrow                // ...indicate construction of fallback type...                lhs_.indicate_which(                      BOOST_MPL_AUX_VALUE_WKND(fallback_type_index_)::value                    ); // nothrow                // ...and rethrow:                BOOST_RETHROW;            }            BOOST_CATCH_END            // In the event of success, indicate new content type:            lhs_.indicate_which(rhs_which_); // nothrow        }        template <typename RhsT>        void assign_impl(              const RhsT& rhs_content            , mpl::false_ // has_nothrow_copy            , mpl::false_ // is_nothrow_move_constructible            , mpl::false_ // has_fallback_type            )        {            detail::variant::backup_assigner<wknd_self_t>                visitor(lhs_, rhs_which_, rhs_content);            lhs_.internal_apply_visitor(visitor);        }    public: // internal visitor interfaces        template <typename RhsT>            BOOST_VARIANT_AUX_RETURN_VOID_TYPE        internal_visit(RhsT& rhs_content, int)        {            typedef typename is_nothrow_move_constructible<RhsT>::type                nothrow_move_constructor;            typedef typename mpl::or_< // reduces compile-time                  nothrow_move_constructor                , has_nothrow_copy<RhsT>                >::type nothrow_copy;            assign_impl(                  rhs_content                , nothrow_copy()                , nothrow_move_constructor()                , has_fallback_type_()                );            BOOST_VARIANT_AUX_RETURN_VOID;        }#if BOOST_WORKAROUND(BOOST_MSVC, BOOST_TESTED_AT(1600))    private:        // silence MSVC warning C4512: assignment operator could not be generated        move_assigner& operator= (move_assigner const&);#endif    };    friend class move_assigner;#endif // BOOST_NO_CXX11_RVALUE_REFERENCES    void variant_assign(const variant& rhs)    {        // If the contained types are EXACTLY the same...        if (which_ == rhs.which_)        {            // ...then assign rhs's storage to lhs's content:            detail::variant::assign_storage visitor(rhs.storage_.address());            this->internal_apply_visitor(visitor);        }        else        {            // Otherwise, perform general (copy-based) variant assignment:            assigner visitor(*this, rhs.which());            rhs.internal_apply_visitor(visitor);         }    }#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    void variant_assign(variant&& rhs)    {        // If the contained types are EXACTLY the same...        if (which_ == rhs.which_)        {            // ...then move rhs's storage to lhs's content:            detail::variant::move_storage visitor(rhs.storage_.address());            this->internal_apply_visitor(visitor);        }        else        {            // Otherwise, perform general (move-based) variant assignment:            move_assigner visitor(*this, rhs.which());            rhs.internal_apply_visitor(visitor);         }    }#endif // BOOST_NO_CXX11_RVALUE_REFERENCESprivate: // helpers, for modifiers (below)    template <typename T>    void assign(const T& rhs)    {        // If direct T-to-T assignment is not possible...        detail::variant::direct_assigner<T> direct_assign(rhs);        if (this->apply_visitor(direct_assign) == false)        {            // ...then convert rhs to variant and assign:            //            // While potentially inefficient, the following construction of a            // variant allows T as any type convertible to one of the bounded            // types without excessive code redundancy.            //            variant temp(rhs);            variant_assign( detail::variant::move(temp) );        }    }#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    template <typename T>    void move_assign(T&& rhs)    {        // If direct T-to-T move assignment is not possible...        detail::variant::direct_mover<T> direct_move(rhs);        if (this->apply_visitor(direct_move) == false)        {            // ...then convert rhs to variant and assign:            //            // While potentially inefficient, the following construction of a            // variant allows T as any type convertible to one of the bounded            // types without excessive code redundancy.            //            variant temp( detail::variant::move(rhs) );            variant_assign( detail::variant::move(temp) );        }    }#endif // BOOST_NO_CXX11_RVALUE_REFERENCESpublic: // modifiers#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    template <class T>    typename boost::enable_if_c<boost::is_rvalue_reference<T&&>::value && !boost::is_const<T>::value, variant& >::type         operator=(T&& rhs)    {        move_assign( detail::variant::move(rhs) );        return *this;    }#endif // BOOST_NO_CXX11_RVALUE_REFERENCES    template <typename T>    variant& operator=(const T& rhs)    {        assign(rhs);        return *this;    }    // [MSVC6 requires copy assign appear after templated operator=]    variant& operator=(const variant& rhs)    {        variant_assign(rhs);        return *this;    }#ifndef BOOST_NO_CXX11_RVALUE_REFERENCES    variant& operator=(variant&& rhs) // BOOST_NOEXCEPT_IF(variant_move_noexcept::type::value && all move assign operators are noexcept)    {        variant_assign( detail::variant::move(rhs) );        return *this;    }#endif // BOOST_NO_CXX11_RVALUE_REFERENCES    void swap(variant& rhs)    {        // If the contained types are the same...        if (which() == rhs.which())        {            // ...then swap the values directly:            detail::variant::swap_with<variant> visitor(rhs);            this->apply_visitor(visitor);        }        else        {            // ...otherwise, perform general variant swap:            variant tmp( detail::variant::move(rhs) );            rhs = detail::variant::move(*this);            *this = detail::variant::move(tmp);        }    }public: // queries    //    // NOTE: member which() defined above.    //    bool empty() const BOOST_NOEXCEPT    {        return false;    }#if !defined(BOOST_NO_TYPEID)    const std::type_info& type() const    {        detail::variant::reflect visitor;        return this->apply_visitor(visitor);    }#endifpublic: // prevent comparison with foreign types#if !BOOST_WORKAROUND(BOOST_MSVC, <= 1300)#   define BOOST_VARIANT_AUX_FAIL_COMPARISON_RETURN_TYPE \    void#else // MSVC7    //    // MSVC7 gives error about return types for above being different than    // the true comparison operator overloads:    //#   define BOOST_VARIANT_AUX_FAIL_COMPARISON_RETURN_TYPE \    bool#endif // MSVC7 workaround    template <typename U>        BOOST_VARIANT_AUX_FAIL_COMPARISON_RETURN_TYPE    operator==(const U&) const    {        BOOST_STATIC_ASSERT( false && sizeof(U) );    }    template <typename U>        BOOST_VARIANT_AUX_FAIL_COMPARISON_RETURN_TYPE    operator<(const U&) const    {        BOOST_STATIC_ASSERT( false && sizeof(U) );    }public: // comparison operators    // [MSVC6 requires these operators appear after template operators]    bool operator==(const variant& rhs) const    {        if (this->which() != rhs.which())            return false;        detail::variant::comparer<              variant, detail::variant::equal_comp            > visitor(*this);        return rhs.apply_visitor(visitor);    }    bool operator<(const variant& rhs) const    {        //        // Dirk Schreib suggested this collating order.        //        if (this->which() != rhs.which())            return this->which() < rhs.which();        detail::variant::comparer<              variant, detail::variant::less_comp            > visitor(*this);        return rhs.apply_visitor(visitor);    }// helpers, for visitation support (below) -- private when possible#if !defined(BOOST_NO_MEMBER_TEMPLATE_FRIENDS)    template < BOOST_VARIANT_ENUM_PARAMS(typename U) >    friend class variant;private:#else// defined(BOOST_NO_MEMBER_TEMPLATE_FRIENDS)public:#endif// !defined(BOOST_NO_MEMBER_TEMPLATE_FRIENDS)    template <typename Visitor, typename VoidPtrCV>    static        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(              typename Visitor::result_type            )    internal_apply_visitor_impl(          int internal_which        , int logical_which        , Visitor& visitor        , VoidPtrCV storage        )    {        typedef mpl::int_<0> first_which;        typedef typename mpl::begin<internal_types>::type first_it;        typedef typename mpl::end<internal_types>::type last_it;        typedef detail::variant::visitation_impl_step<              first_it, last_it            > first_step;        return detail::variant::visitation_impl(              internal_which, logical_which            , visitor, storage, mpl::false_()            , never_uses_backup_flag()            , static_cast<first_which*>(0), static_cast<first_step*>(0)            );    }    template <typename Visitor>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(              typename Visitor::result_type            )    internal_apply_visitor(Visitor& visitor)    {        return internal_apply_visitor_impl(              which_, which(), visitor, storage_.address()            );    }    template <typename Visitor>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(              typename Visitor::result_type            )    internal_apply_visitor(Visitor& visitor) const    {        return internal_apply_visitor_impl(              which_, which(), visitor, storage_.address()            );    }public: // visitation support    template <typename Visitor>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(              typename Visitor::result_type            )    apply_visitor(Visitor& visitor)    {        detail::variant::invoke_visitor<Visitor> invoker(visitor);        return this->internal_apply_visitor(invoker);    }    template <typename Visitor>        BOOST_VARIANT_AUX_GENERIC_RESULT_TYPE(              typename Visitor::result_type            )    apply_visitor(Visitor& visitor) const    {        detail::variant::invoke_visitor<Visitor> invoker(visitor);        return this->internal_apply_visitor(invoker);    }}; // class variant///////////////////////////////////////////////////////////////////////////////// metafunction make_variant_over//// See docs and boost/variant/variant_fwd.hpp for more information.//template <typename Types>struct make_variant_over{private: // precondition assertions#if !BOOST_WORKAROUND(BOOST_MSVC, <= 1300)    BOOST_STATIC_ASSERT(( ::boost::mpl::is_sequence<Types>::value ));#endifpublic: // metafunction result    typedef variant<          detail::variant::over_sequence< Types >        > type;};///////////////////////////////////////////////////////////////////////////////// function template swap//// Swaps two variants of the same type (i.e., identical specification).//template < BOOST_VARIANT_ENUM_PARAMS(typename T) >inline void swap(      variant< BOOST_VARIANT_ENUM_PARAMS(T) >& lhs    , variant< BOOST_VARIANT_ENUM_PARAMS(T) >& rhs    ){    lhs.swap(rhs);}} // namespace boost// implementation additions#if !defined(BOOST_NO_IOSTREAM)#include "boost/variant/detail/variant_io.hpp"#endif // BOOST_NO_IOSTREAM#endif // BOOST_VARIANT_VARIANT_HPP
 |