/////////////////////////////////////////////////////////////////////////////// // as_independent.hpp // // Copyright 2007 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_XPRESSIVE_DETAIL_STATIC_TRANSFORMS_AS_INDEPENDENT_HPP_EAN_04_05_2007 #define BOOST_XPRESSIVE_DETAIL_STATIC_TRANSFORMS_AS_INDEPENDENT_HPP_EAN_04_05_2007 // MS compatible compilers support #pragma once #if defined(_MSC_VER) && (_MSC_VER >= 1020) # pragma once #endif #include #include #include #include #include namespace boost { namespace xpressive { namespace detail { struct keeper_tag {}; struct lookahead_tag {}; struct lookbehind_tag {}; template struct as_lookahead : Grammar { as_lookahead(); template struct apply { typedef lookahead_matcher< typename Grammar::template apply::type > type; }; template static typename apply::type call(Expr const &expr, State const &, Visitor &visitor) { return typename apply::type( Grammar::call(expr, true_xpression(), visitor) , false ); } }; template struct as_lookbehind : Grammar { as_lookbehind(); template struct apply { typedef lookbehind_matcher< typename Grammar::template apply::type > type; }; template static typename apply::type call(Expr const &expr, State const &, Visitor &visitor) { typename Grammar::template apply::type const & expr2 = Grammar::call(expr, true_xpression(), visitor); std::size_t width = expr2.get_width().value(); return typename apply::type(expr2, width, false); } }; template struct as_keeper : Grammar { as_keeper(); template struct apply { typedef keeper_matcher< typename Grammar::template apply::type > type; }; template static typename apply::type call(Expr const &expr, State const &, Visitor &visitor) { return typename apply::type( Grammar::call(expr, true_xpression(), visitor) ); } }; }}} #endif