annotate DEPENDENCIES/generic/include/boost/phoenix/scope/this.hpp @ 16:2665513ce2d3

Add boost headers
author Chris Cannam
date Tue, 05 Aug 2014 11:11:38 +0100
parents
children c530137014c0
rev   line source
Chris@16 1 /*=============================================================================
Chris@16 2 Copyright (c) 2005-2011 Joel de Guzman
Chris@16 3 Copyright (c) 2011 Thomas Heller
Chris@16 4
Chris@16 5 Distributed under the Boost Software License, Version 1.0. (See accompanying
Chris@16 6 file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
Chris@16 7 ==============================================================================*/
Chris@16 8 #ifndef BOOST_PHOENIX_SCOPE_THIS_HPP
Chris@16 9 #define BOOST_PHOENIX_SCOPE_THIS_HPP
Chris@16 10
Chris@16 11 #include <boost/phoenix/core/limits.hpp>
Chris@16 12 #include <boost/phoenix/core/actor.hpp>
Chris@16 13 #include <boost/phoenix/core/environment.hpp>
Chris@16 14 #include <boost/phoenix/core/expression.hpp>
Chris@16 15 #include <boost/phoenix/core/meta_grammar.hpp>
Chris@16 16 #include <boost/phoenix/core/terminal.hpp>
Chris@16 17 #include <boost/phoenix/scope/lambda.hpp>
Chris@16 18 #include <boost/type_traits/remove_pointer.hpp>
Chris@16 19
Chris@16 20 BOOST_PHOENIX_DEFINE_EXPRESSION_VARARG(
Chris@16 21 (boost)(phoenix)(this_)
Chris@16 22 , (meta_grammar)(meta_grammar)
Chris@16 23 , BOOST_PHOENIX_LIMIT
Chris@16 24 )
Chris@16 25
Chris@16 26 namespace boost { namespace phoenix {
Chris@16 27 namespace detail
Chris@16 28 {
Chris@16 29 /*
Chris@16 30 struct infinite_recursion_detected {};
Chris@16 31
Chris@16 32 struct last_non_this_actor
Chris@16 33 : proto::or_<
Chris@16 34 proto::when<
Chris@16 35 proto::nary_expr<
Chris@16 36 proto::_
Chris@16 37 , proto::_
Chris@16 38 , proto::_
Chris@16 39 >
Chris@16 40 , proto::_child_c<1>
Chris@16 41 >
Chris@16 42 , proto::when<
Chris@16 43 proto::nary_expr<
Chris@16 44 proto::_
Chris@16 45 , proto::_
Chris@16 46 , proto::_
Chris@16 47 , proto::_
Chris@16 48 >
Chris@16 49 , proto::_child_c<2>
Chris@16 50 >
Chris@16 51 >
Chris@16 52 {};
Chris@16 53 */
Chris@16 54 }
Chris@16 55 struct this_eval
Chris@16 56 {
Chris@16 57 BOOST_PROTO_CALLABLE()
Chris@16 58
Chris@16 59 template <typename Sig>
Chris@16 60 struct result;
Chris@16 61
Chris@16 62 template <typename This, typename A0, typename Context>
Chris@16 63 struct result<This(A0, Context)>
Chris@16 64 {
Chris@16 65 typedef
Chris@16 66 typename proto::detail::uncvref<
Chris@16 67 typename result_of::env<
Chris@16 68 Context
Chris@16 69 >::type
Chris@16 70 >::type
Chris@16 71 outer_env_type;
Chris@16 72
Chris@16 73 typedef
Chris@16 74 typename remove_pointer<
Chris@16 75 typename remove_reference<
Chris@16 76 typename fusion::result_of::at_c<
Chris@16 77 outer_env_type
Chris@16 78 , 0
Chris@16 79 >::type
Chris@16 80 >::type
Chris@16 81 >::type
Chris@16 82 actor_type;
Chris@16 83
Chris@16 84 typedef
Chris@16 85 typename result_of::eval<
Chris@16 86 A0 const &
Chris@16 87 , Context const &
Chris@16 88 >::type
Chris@16 89 a0_type;
Chris@16 90
Chris@16 91 typedef
Chris@16 92 vector2<actor_type const *, a0_type>
Chris@16 93 inner_env_type;
Chris@16 94
Chris@16 95 typedef
Chris@16 96 scoped_environment<
Chris@16 97 inner_env_type
Chris@16 98 , outer_env_type
Chris@16 99 , vector0<>
Chris@16 100 , detail::map_local_index_to_tuple<>
Chris@16 101 >
Chris@16 102 env_type;
Chris@16 103
Chris@16 104 typedef
Chris@16 105 typename result_of::eval<
Chris@16 106 actor_type const &
Chris@16 107 , typename result_of::context<
Chris@16 108 inner_env_type
Chris@16 109 , typename result_of::actions<
Chris@16 110 Context
Chris@16 111 >::type
Chris@16 112 >::type
Chris@16 113 >::type
Chris@16 114 type;
Chris@16 115 };
Chris@16 116
Chris@16 117 template <typename A0, typename Context>
Chris@16 118 typename result<this_eval(A0 const&, Context const &)>::type
Chris@16 119 operator()(A0 const & a0, Context const & ctx) const
Chris@16 120 {
Chris@16 121
Chris@16 122 //std::cout << typeid(checker).name() << "\n";
Chris@16 123 //std::cout << typeid(checker).name() << "\n";
Chris@16 124 typedef
Chris@16 125 typename proto::detail::uncvref<
Chris@16 126 typename result_of::env<
Chris@16 127 Context
Chris@16 128 >::type
Chris@16 129 >::type
Chris@16 130 outer_env_type;
Chris@16 131
Chris@16 132 typedef
Chris@16 133 typename remove_pointer<
Chris@16 134 typename remove_reference<
Chris@16 135 typename fusion::result_of::at_c<
Chris@16 136 outer_env_type
Chris@16 137 , 0
Chris@16 138 >::type
Chris@16 139 >::type
Chris@16 140 >::type
Chris@16 141 actor_type;
Chris@16 142
Chris@16 143 typedef
Chris@16 144 typename result_of::eval<
Chris@16 145 A0 const &
Chris@16 146 , Context const &
Chris@16 147 >::type
Chris@16 148 a0_type;
Chris@16 149
Chris@16 150 typedef
Chris@16 151 vector2<actor_type const *, a0_type>
Chris@16 152 inner_env_type;
Chris@16 153
Chris@16 154 typedef
Chris@16 155 scoped_environment<
Chris@16 156 inner_env_type
Chris@16 157 , outer_env_type
Chris@16 158 , vector0<>
Chris@16 159 , detail::map_local_index_to_tuple<>
Chris@16 160 >
Chris@16 161 env_type;
Chris@16 162
Chris@16 163 inner_env_type inner_env = {fusion::at_c<0>(phoenix::env(ctx)), phoenix::eval(a0, ctx)};
Chris@16 164 vector0<> locals;
Chris@16 165 env_type env(inner_env, phoenix::env(ctx), locals);
Chris@16 166
Chris@16 167 return phoenix::eval(*fusion::at_c<0>(phoenix::env(ctx)), phoenix::context(inner_env, phoenix::actions(ctx)));
Chris@16 168 //return (*fusion::at_c<0>(phoenix::env(ctx)))(eval(a0, ctx));
Chris@16 169 }
Chris@16 170 };
Chris@16 171
Chris@16 172 template <typename Dummy>
Chris@16 173 struct default_actions::when<rule::this_, Dummy>
Chris@16 174 : call<this_eval>
Chris@16 175 {};
Chris@16 176
Chris@16 177 template <typename Dummy>
Chris@16 178 struct is_nullary::when<rule::this_, Dummy>
Chris@16 179 : proto::make<mpl::false_()>
Chris@16 180 {};
Chris@16 181
Chris@16 182 template <typename A0>
Chris@16 183 typename expression::this_<A0>::type const
Chris@16 184 this_(A0 const & a0)
Chris@16 185 {
Chris@16 186 return expression::this_<A0>::make(a0);
Chris@16 187 }
Chris@16 188
Chris@16 189 }}
Chris@16 190
Chris@16 191 #endif