as_set.hpp

来自「Boost provides free peer-reviewed portab」· HPP 代码 · 共 214 行

HPP
214
字号
///////////////////////////////////////////////////////////////////////////////// as_set.hpp////  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_XPRESSIVE_DETAIL_STATIC_TRANSFORMS_AS_SET_HPP_EAN_04_05_2007#define BOOST_XPRESSIVE_DETAIL_STATIC_TRANSFORMS_AS_SET_HPP_EAN_04_05_2007// MS compatible compilers support #pragma once#if defined(_MSC_VER) && (_MSC_VER >= 1020)# pragma once#endif#include <boost/mpl/assert.hpp>#include <boost/xpressive/proto/proto.hpp>#include <boost/xpressive/detail/detail_fwd.hpp>#include <boost/xpressive/detail/static/static.hpp>#include <boost/xpressive/detail/utility/chset/chset.hpp>#include <boost/xpressive/detail/utility/traits_utils.hpp>namespace boost { namespace xpressive { namespace grammar_detail{    ///////////////////////////////////////////////////////////////////////////    // CharLiteral    template<typename Char>    struct CharLiteral      : or_<            terminal<char>          , terminal<Char>        >    {};    template<>    struct CharLiteral<char>      : terminal<char>    {};    ///////////////////////////////////////////////////////////////////////////    // ListSet    //  matches expressions like (set= 'a','b','c')    //  calculates the size of the set    template<typename Char>    struct ListSet      : or_<            when<                comma<ListSet<Char>, CharLiteral<Char> >              , make<mpl::next<call<ListSet<Char>(_left)> > > // TODO make a custom transform for this...            >          , when<                assign<detail::set_initializer_type, CharLiteral<Char> >              , make<mpl::int_<1> >            >        >    {};    template<typename Char, typename Traits>    void fill_list_set(Char *&, detail::set_initializer_type, Traits const &)    {}    template<typename Char, typename Expr, typename Traits>    void fill_list_set(Char *&buffer, Expr const &expr, Traits const &traits)    {        fill_list_set(buffer, proto::left(expr), traits);        *buffer++ = traits.translate(detail::char_cast<Char>(proto::arg(proto::right(expr)), traits));    }    ///////////////////////////////////////////////////////////////////////////////    // as_list_set_matcher    template<typename Char>    struct as_list_set_matcher    {        template<typename Sig> struct result {};        template<typename This, typename Expr, typename State, typename Visitor>        struct result<This(Expr, State, Visitor)>        {            typedef detail::set_matcher<                typename Visitor::traits_type              , typename ListSet<Char>::template result<void(Expr, State, Visitor)>::type            > type;        };        template<typename Expr, typename State, typename Visitor>        typename result<void(Expr, State, Visitor)>::type        operator ()(Expr const &expr, State const &, Visitor &visitor) const        {            detail::set_matcher<                typename Visitor::traits_type              , typename ListSet<Char>::template result<void(Expr, State, Visitor)>::type            > set;            typename Visitor::char_type *buffer = set.set_;            fill_list_set(buffer, expr, visitor.traits());            return set;        }    };    ///////////////////////////////////////////////////////////////////////////////    // merge_charset    //    template<typename Grammar, typename CharSet, typename Visitor>    struct merge_charset    {        typedef typename Visitor::traits_type traits_type;        typedef typename CharSet::char_type char_type;        typedef typename CharSet::icase_type icase_type;        merge_charset(CharSet &charset, Visitor &visitor)          : charset_(charset)          , visitor_(visitor)        {}        template<typename Expr>        void operator ()(Expr const &expr) const        {            this->call_(expr, typename Expr::proto_tag());        }    private:        merge_charset &operator =(merge_charset const &);        template<typename Expr, typename Tag>        void call_(Expr const &expr, Tag) const        {            this->set_(Grammar()(expr, detail::end_xpression(), this->visitor_));        }        template<typename Expr>        void call_(Expr const &expr, tag::bitwise_or) const        {            (*this)(proto::left(expr));            (*this)(proto::right(expr));        }        template<typename Not>        void set_(detail::literal_matcher<traits_type, icase_type, Not> const &ch) const        {            // BUGBUG fixme!            BOOST_MPL_ASSERT_NOT((Not));            set_char(this->charset_.charset_, ch.ch_, this->visitor_.traits(), icase_type());        }        void set_(detail::range_matcher<traits_type, icase_type> const &rg) const        {            // BUGBUG fixme!            BOOST_ASSERT(!rg.not_);            set_range(this->charset_.charset_, rg.ch_min_, rg.ch_max_, this->visitor_.traits(), icase_type());        }        template<typename Size>        void set_(detail::set_matcher<traits_type, Size> const &set_) const        {            // BUGBUG fixme!            BOOST_ASSERT(!set_.not_);            for(int i = 0; i < Size::value; ++i)            {                set_char(this->charset_.charset_, set_.set_[i], this->visitor_.traits(), icase_type());            }        }        void set_(detail::posix_charset_matcher<traits_type> const &posix) const        {            set_class(this->charset_.charset_, posix.mask_, posix.not_, this->visitor_.traits());        }        CharSet &charset_;        Visitor &visitor_;    };    ///////////////////////////////////////////////////////////////////////////////    //    template<typename Grammar>    struct as_set_matcher : proto::callable    {        template<typename Sig> struct result {};        template<typename This, typename Expr, typename State, typename Visitor>        struct result<This(Expr, State, Visitor)>        {            typedef typename Visitor::char_type char_type;            // if sizeof(char_type)==1, merge everything into a basic_chset            // BUGBUG this is not optimal.            typedef typename mpl::if_<                detail::is_narrow_char<char_type>              , detail::basic_chset<char_type>              , detail::compound_charset<typename Visitor::traits_type>            >::type charset_type;            typedef detail::charset_matcher<                typename Visitor::traits_type              , typename Visitor::icase_type              , charset_type            > type;        };        template<typename Expr, typename State, typename Visitor>        typename result<void(Expr, State, Visitor)>::type        operator ()(Expr const &expr, State const &, Visitor &visitor) const        {            typedef typename result<void(Expr, State, Visitor)>::type set_type;            set_type matcher;            merge_charset<Grammar, set_type, Visitor> merge(matcher, visitor);            merge(expr); // Walks the tree and fills in the charset            return matcher;        }    };}}}#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?