Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

This is the documentation for an old version of boost. Click here for the latest Boost documentation.

boost/xpressive/detail/static/productions/independent_compiler.hpp

///////////////////////////////////////////////////////////////////////////////
// independent_compiler.hpp
//
//  Copyright 2004 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_PRODUCTIONS_INDEPENDENT_COMPILER_HPP_EAN_10_04_2005
#define BOOST_XPRESSIVE_DETAIL_STATIC_PRODUCTIONS_INDEPENDENT_COMPILER_HPP_EAN_10_04_2005

#include <boost/mpl/bool.hpp>
#include <boost/type_traits/is_base_and_derived.hpp>
#include <boost/xpressive/detail/detail_fwd.hpp>
#include <boost/xpressive/proto/proto.hpp>
#include <boost/xpressive/detail/static/productions/domain_tags.hpp>

namespace boost { namespace xpressive { namespace detail
{
    template<bool Positive>
    struct lookahead_tag : proto::unary_tag {};

    template<bool Positive>
    struct lookbehind_tag : proto::unary_tag {};

    struct keeper_tag : proto::unary_tag {};

    ///////////////////////////////////////////////////////////////////////////////
    // lookahead_branch
    template<bool Positive>
    struct lookahead_branch
    {
        typedef true_xpression state_type;

        template<typename Op, typename State, typename>
        struct apply
        {
            typedef static_xpression<lookahead_matcher<Op>, State> type;
        };

        template<typename Op, typename State, typename Visitor>
        static static_xpression<lookahead_matcher<Op>, State>
        call(Op const &op, State const &state, Visitor &)
        {
            return make_static_xpression(lookahead_matcher<Op>(op, !Positive), state);
        }
    };

    ///////////////////////////////////////////////////////////////////////////////
    // lookbehind_branch
    template<bool Positive>
    struct lookbehind_branch
    {
        typedef true_xpression state_type;

        template<typename Op, typename State, typename>
        struct apply
        {
            typedef static_xpression<lookbehind_matcher<Op>, State> type;
        };

        template<typename Op, typename State, typename Visitor>
        static static_xpression<lookbehind_matcher<Op>, State>
        call(Op const &op, State const &state, Visitor &)
        {
            return make_static_xpression(lookbehind_matcher<Op>(op, !Positive), state);
        }
    };

    ///////////////////////////////////////////////////////////////////////////////
    // keeper_branch
    struct keeper_branch
    {
        typedef true_xpression state_type;

        template<typename Op, typename State, typename>
        struct apply
        {
            typedef static_xpression<keeper_matcher<Op>, State> type;
        };

        template<typename Op, typename State, typename Visitor>
        static static_xpression<keeper_matcher<Op>, State>
        call(Op const &op, State const &state, Visitor &)
        {
            return make_static_xpression(keeper_matcher<Op>(op), state);
        }
    };

}}}


namespace boost { namespace proto
{
    // ericne, 28/nov/05: CW9_4 doesn't like partial specializations of the form:
    //   template<bool F> struct foo<bar<F> >
    template<>
    struct compiler<xpressive::detail::lookahead_tag<true>, xpressive::detail::seq_tag, void>
      : branch_compiler<xpressive::detail::lookahead_branch<true>, xpressive::detail::ind_tag>
    {
    };

    template<>
    struct compiler<xpressive::detail::lookahead_tag<false>, xpressive::detail::seq_tag, void>
      : branch_compiler<xpressive::detail::lookahead_branch<false>, xpressive::detail::ind_tag>
    {
    };

    template<>
    struct compiler<xpressive::detail::lookbehind_tag<true>, xpressive::detail::seq_tag, void>
      : branch_compiler<xpressive::detail::lookbehind_branch<true>, xpressive::detail::ind_tag>
    {
    };

    template<>
    struct compiler<xpressive::detail::lookbehind_tag<false>, xpressive::detail::seq_tag, void>
      : branch_compiler<xpressive::detail::lookbehind_branch<false>, xpressive::detail::ind_tag>
    {
    };

    template<>
    struct compiler<xpressive::detail::keeper_tag, xpressive::detail::seq_tag, void>
      : branch_compiler<xpressive::detail::keeper_branch, xpressive::detail::ind_tag>
    {
    };
    
    template<typename OpTag>
    struct compiler<OpTag, xpressive::detail::ind_tag, void>
      : transform_compiler<arg_transform, xpressive::detail::seq_tag>
    {
    };

}}


#endif