/////////////////////////////////////////////////////////////////////////////// // compile.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_COMPILE_HPP_EAN_10_04_2005 #define BOOST_XPRESSIVE_DETAIL_STATIC_COMPILE_HPP_EAN_10_04_2005 // MS compatible compilers support #pragma once #if defined(_MSC_VER) && (_MSC_VER >= 1020) # pragma once #endif #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace xpressive { namespace detail { /////////////////////////////////////////////////////////////////////////////// // static_compile_impl2 template void static_compile_impl2(Xpr const &xpr, regex_impl &impl, Traits const &traits) { typedef typename iterator_value::type char_type; // "compile" the regex and wrap it in an xpression_adaptor xpression_visitor visitor(traits, impl.shared_from_this()); visitor.impl().traits_.reset(new Traits(visitor.traits())); visitor.impl().xpr_ = make_adaptor( proto::compile(xpr, end_xpression(), visitor, seq_tag())); // "link" the regex xpression_linker linker(visitor.traits()); visitor.impl().xpr_->link(linker); // optimization: get the peek chars OR the boyer-moore search string optimize_regex(visitor.impl(), visitor.traits(), is_random()); // copy the implementation impl.tracking_copy(visitor.impl()); } /////////////////////////////////////////////////////////////////////////////// // static_compile_impl1 template void static_compile_impl1(Xpr const &xpr, regex_impl &impl) { // use default traits typedef typename iterator_value::type char_type; typedef typename default_regex_traits::type traits_type; traits_type traits; static_compile_impl2(xpr, impl, traits); } /////////////////////////////////////////////////////////////////////////////// // static_compile_impl1 template void static_compile_impl1 ( proto::binary_op, Xpr, modifier_tag> const &xpr , regex_impl &impl ) { // use specified traits typedef typename regex_traits_type::type traits_type; static_compile_impl2(proto::right(xpr), impl, traits_type(proto::left(xpr).getloc())); } /////////////////////////////////////////////////////////////////////////////// // static_compile template void static_compile(Xpr const &xpr, regex_impl &impl) { static_compile_impl1(xpr, impl); } }}} // namespace boost::xpressive::detail #endif