/////////////////////////////////////////////////////////////////////////////// /// \file args.hpp /// Contains definition of \c term\<\>, \c list1\<\>, \c list2\<\>, ... /// class templates. // // 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) #ifndef BOOST_PROTO_ARGS_HPP_EAN_04_01_2005 #define BOOST_PROTO_ARGS_HPP_EAN_04_01_2005 #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace proto { namespace detail { // All classes derived from std::ios_base have these public nested types, // and are non-copyable. This is an imperfect test, but it's the best we // we can do. template yes_type check_is_iostream( typename T::failure * , typename T::Init * , typename T::fmtflags * , typename T::iostate * , typename T::openmode * , typename T::seekdir * ); template no_type check_is_iostream(...); template struct is_iostream { static bool const value = sizeof(yes_type) == sizeof(check_is_iostream(0,0,0,0,0,0)); typedef mpl::bool_ type; }; /// INTERNAL ONLY // This should be a customization point. And it serves the same purpose // as the is_noncopyable trait in Boost.Foreach. template struct ref_only : mpl::or_< is_function , is_abstract , is_iostream > {}; /// INTERNAL ONLY template struct expr_traits { typedef Expr value_type; typedef Expr &reference; typedef Expr const &const_reference; }; /// INTERNAL ONLY template struct expr_traits { typedef Expr value_type; typedef Expr &reference; typedef Expr &const_reference; }; /// INTERNAL ONLY template struct expr_traits { typedef Expr value_type; typedef Expr const &reference; typedef Expr const &const_reference; }; /// INTERNAL ONLY template struct term_traits { typedef T value_type; typedef T &reference; typedef T const &const_reference; }; /// INTERNAL ONLY template struct term_traits { typedef typename mpl::if_c::value, T &, T>::type value_type; typedef T &reference; typedef T &const_reference; }; /// INTERNAL ONLY template struct term_traits { typedef T value_type; typedef T const &reference; typedef T const &const_reference; }; /// INTERNAL ONLY template struct term_traits { typedef T value_type[N]; typedef T (&reference)[N]; typedef T (&const_reference)[N]; }; /// INTERNAL ONLY template struct term_traits { typedef T value_type[N]; typedef T const (&reference)[N]; typedef T const (&const_reference)[N]; }; /// INTERNAL ONLY template struct term_traits { typedef T value_type[N]; typedef T (&reference)[N]; typedef T const (&const_reference)[N]; }; /// INTERNAL ONLY template struct term_traits { typedef T value_type[N]; typedef T const (&reference)[N]; typedef T const (&const_reference)[N]; }; } namespace argsns_ { // This is where term and all the different listN templates are defined #include } }} #endif