98 lines
3.5 KiB
Plaintext
98 lines
3.5 KiB
Plaintext
|
#if !defined(BOOST_PROTO_DONT_USE_PREPROCESSED_FILES)
|
||
|
|
||
|
#include <boost/proto/transform/detail/preprocessed/default_function_impl.hpp>
|
||
|
|
||
|
#elif !defined(BOOST_PP_IS_ITERATING)
|
||
|
|
||
|
#define BOOST_PROTO_DEF_FUN_INVOKE_ARG(Z, M, DATA) \
|
||
|
BOOST_PROTO_DEFAULT_EVAL(Z, BOOST_PP_ADD(M, 2), DATA)
|
||
|
|
||
|
#if defined(__WAVE__) && defined(BOOST_PROTO_CREATE_PREPROCESSED_FILES)
|
||
|
#pragma wave option(preserve: 2, line: 0, output: "preprocessed/default_function_impl.hpp")
|
||
|
#endif
|
||
|
|
||
|
///////////////////////////////////////////////////////////////////////////////
|
||
|
/// \file default_function_impl.hpp
|
||
|
/// Contains definition of the default_function_impl, the implementation of the
|
||
|
/// _default transform for function-like nodes.
|
||
|
//
|
||
|
// Copyright 2008 Eric Niebler. 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)
|
||
|
|
||
|
#if defined(__WAVE__) && defined(BOOST_PROTO_CREATE_PREPROCESSED_FILES)
|
||
|
#pragma wave option(preserve: 1)
|
||
|
#endif
|
||
|
|
||
|
#define BOOST_PP_ITERATION_PARAMS_1 \
|
||
|
(3, (3, BOOST_PROTO_MAX_ARITY, <boost/proto/transform/detail/default_function_impl.hpp>))
|
||
|
#include BOOST_PP_ITERATE()
|
||
|
|
||
|
#if defined(__WAVE__) && defined(BOOST_PROTO_CREATE_PREPROCESSED_FILES)
|
||
|
#pragma wave option(output: null)
|
||
|
#endif
|
||
|
|
||
|
#undef BOOST_PROTO_DEF_FUN_INVOKE_ARG
|
||
|
|
||
|
#else
|
||
|
|
||
|
#define N BOOST_PP_ITERATION()
|
||
|
|
||
|
template<typename Grammar, typename Expr, typename State, typename Data>
|
||
|
struct default_function_impl<Grammar, Expr, State, Data, N>
|
||
|
: transform_impl<Expr, State, Data>
|
||
|
{
|
||
|
BOOST_PP_REPEAT(N, BOOST_PROTO_DEFAULT_EVAL_TYPE, Expr)
|
||
|
|
||
|
typedef
|
||
|
typename proto::detail::result_of_fixup<r0>::type
|
||
|
function_type;
|
||
|
|
||
|
typedef
|
||
|
typename BOOST_PROTO_RESULT_OF<
|
||
|
function_type(BOOST_PP_ENUM_SHIFTED_PARAMS(N, r))
|
||
|
>::type
|
||
|
result_type;
|
||
|
|
||
|
result_type operator ()(
|
||
|
typename default_function_impl::expr_param e
|
||
|
, typename default_function_impl::state_param s
|
||
|
, typename default_function_impl::data_param d
|
||
|
) const
|
||
|
{
|
||
|
return this->invoke(e, s, d, is_member_function_pointer<function_type>());
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
result_type invoke(
|
||
|
typename default_function_impl::expr_param e
|
||
|
, typename default_function_impl::state_param s
|
||
|
, typename default_function_impl::data_param d
|
||
|
, mpl::false_
|
||
|
) const
|
||
|
{
|
||
|
return BOOST_PROTO_DEFAULT_EVAL(~, 0, e)(
|
||
|
BOOST_PP_ENUM_SHIFTED(N, BOOST_PROTO_DEFAULT_EVAL, e)
|
||
|
);
|
||
|
}
|
||
|
|
||
|
result_type invoke(
|
||
|
typename default_function_impl::expr_param e
|
||
|
, typename default_function_impl::state_param s
|
||
|
, typename default_function_impl::data_param d
|
||
|
, mpl::true_
|
||
|
) const
|
||
|
{
|
||
|
BOOST_PROTO_USE_GET_POINTER();
|
||
|
typedef typename detail::class_member_traits<function_type>::class_type class_type;
|
||
|
return (
|
||
|
BOOST_PROTO_GET_POINTER(class_type, (BOOST_PROTO_DEFAULT_EVAL(~, 1, e))) ->*
|
||
|
BOOST_PROTO_DEFAULT_EVAL(~, 0, e)
|
||
|
)(BOOST_PP_ENUM(BOOST_PP_SUB(N, 2), BOOST_PROTO_DEF_FUN_INVOKE_ARG, e));
|
||
|
}
|
||
|
};
|
||
|
|
||
|
#undef N
|
||
|
|
||
|
#endif
|