/*============================================================================= Copyright (c) 2006-2007 Tobias Schwinger 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). ==============================================================================*/ #if !defined(BOOST_FUSION_FUNCTIONAL_ADAPTER_UNFUSED_GENERIC_HPP_INCLUDED) #if !defined(BOOST_PP_IS_ITERATING) #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace fusion { template class unfused_generic; //----- ---- --- -- - - - - struct void_; template class unfused_generic : public detail::nullary_call_base, Function> { Function fnc_transformed; template friend struct detail::nullary_call_base; typedef detail::nullary_call_base< fusion::unfused_generic, Function > base; typedef typename boost::remove_reference::type function; typedef typename detail::call_param::type func_const_fwd_t; public: inline explicit unfused_generic(func_const_fwd_t f = Function()) : fnc_transformed(f) { } using base::operator(); template < BOOST_PP_ENUM_BINARY_PARAMS(BOOST_FUSION_UNFUSED_GENERIC_MAX_ARITY, typename T, = fusion::void_ BOOST_PP_INTERCEPT), class _ = fusion::void_ > struct result; template struct result< BOOST_PP_ENUM_PARAMS(BOOST_FUSION_UNFUSED_GENERIC_MAX_ARITY, fusion::void_ BOOST_PP_INTERCEPT),_> : base::r0 { }; #define BOOST_FUSION_CODE(tpl_params,arg_types,params,args) \ template \ inline typename function::template result< \ BOOST_PP_CAT(fusion::vector,N) >::type \ operator()(params) const \ { \ BOOST_PP_CAT(fusion::vector,N) arg(args); \ return this->fnc_transformed(arg); \ } \ template \ inline typename function::template result< \ BOOST_PP_CAT(fusion::vector,N) >::type \ operator()(params) \ { \ BOOST_PP_CAT(fusion::vector,N) arg(args); \ return this->fnc_transformed(arg); \ } #define BOOST_PP_INDIRECT_SELF \ #define BOOST_PP_FILENAME_1 \ #define BOOST_PP_ITERATION_LIMITS \ (1,BOOST_FUSION_UNFUSED_GENERIC_MAX_ARITY) #define N BOOST_PP_ITERATION_1 #include BOOST_PP_ITERATE() #undef N #undef BOOST_FUSION_CODE }; }} #define BOOST_FUSION_CLASS_TPL_PARAMS class F #define BOOST_FUSION_CLASS_TPL_SPEC fusion::unfused_generic #define BOOST_FUSION_FUNC_OBJ_ARITY BOOST_FUSION_UNFUSED_GENERIC_MAX_ARITY #include #define BOOST_FUSION_FUNCTIONAL_ADAPTER_UNFUSED_GENERIC_HPP_INCLUDED #else // defined(BOOST_PP_IS_ITERATING) /////////////////////////////////////////////////////////////////////////////// // // Preprocessor vertical repetition code // /////////////////////////////////////////////////////////////////////////////// #include #if BOOST_PP_SLOT_1() == 0 template struct result #if N < BOOST_FUSION_UNFUSED_GENERIC_MAX_ARITY < BOOST_PP_ENUM_PARAMS(N,T), BOOST_PP_ENUM_PARAMS( BOOST_PP_SUB(BOOST_FUSION_UNFUSED_GENERIC_MAX_ARITY,N), fusion::void_ BOOST_PP_INTERCEPT), _ > #endif : function::template result< BOOST_PP_CAT(fusion::vector,N)< BOOST_PP_ENUM_BINARY_PARAMS(N,typename detail::gref::type BOOST_PP_INTERCEPT) > > { }; #endif #if BOOST_WORKAROUND(BOOST_MSVC,BOOST_TESTED_AT(1400)) template inline typename function::template result< BOOST_PP_CAT(fusion::vector,N) >::type operator()(BOOST_PP_ENUM_BINARY_PARAMS(N,PT,a)) const { BOOST_PP_CAT(fusion::vector,N) arg(BOOST_PP_ENUM_PARAMS(N,a)); return this->fnc_transformed(arg); } template inline typename function::template result< BOOST_PP_CAT(fusion::vector,N) >::type operator()(BOOST_PP_ENUM_BINARY_PARAMS(N,PT,a)) { BOOST_PP_CAT(fusion::vector,N) arg(BOOST_PP_ENUM_PARAMS(N,a)); return this->fnc_transformed(arg); } #else BOOST_FUSION_CODE(BOOST_PP_ENUM_PARAMS(N,typename T), BOOST_PP_ENUM_PARAMS(N,PT), BOOST_PP_ENUM_BINARY_PARAMS(N,PT,a), BOOST_PP_ENUM_PARAMS(N,a) ) // ...generates uglier code but is faster - it caches ENUM_* #endif #include #endif // defined(BOOST_PP_IS_ITERATING) #endif