boost/xpressive/detail/static/compile.hpp
///////////////////////////////////////////////////////////////////////////////
// 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 <boost/mpl/bool.hpp>
#include <boost/iterator/iterator_traits.hpp>
#include <boost/xpressive/proto/proto.hpp>
#include <boost/xpressive/regex_traits.hpp>
#include <boost/xpressive/detail/core/regex_impl.hpp>
#include <boost/xpressive/detail/core/linker.hpp>
#include <boost/xpressive/detail/core/optimize.hpp>
#include <boost/xpressive/detail/core/adaptor.hpp>
#include <boost/xpressive/detail/core/matcher/end_matcher.hpp>
#include <boost/xpressive/detail/static/static.hpp>
#include <boost/xpressive/detail/static/productions/visitor.hpp>
#include <boost/xpressive/detail/static/productions/domain_tags.hpp>
namespace boost { namespace xpressive { namespace detail
{
///////////////////////////////////////////////////////////////////////////////
// static_compile_impl2
template<typename Xpr, typename BidiIter, typename Traits>
void static_compile_impl2(Xpr const &xpr, regex_impl<BidiIter> &impl, Traits const &traits)
{
typedef typename iterator_value<BidiIter>::type char_type;
// "compile" the regex and wrap it in an xpression_adaptor
xpression_visitor<BidiIter, mpl::false_, Traits> visitor(traits, impl.shared_from_this());
visitor.impl().traits_.reset(new Traits(visitor.traits()));
visitor.impl().xpr_ = make_adaptor<BidiIter>(
proto::compile(xpr, end_xpression(), visitor, seq_tag()));
// "link" the regex
xpression_linker<char_type> 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<BidiIter>());
// copy the implementation
impl.tracking_copy(visitor.impl());
}
///////////////////////////////////////////////////////////////////////////////
// static_compile_impl1
template<typename Xpr, typename BidiIter>
void static_compile_impl1(Xpr const &xpr, regex_impl<BidiIter> &impl)
{
// use default traits
typedef typename iterator_value<BidiIter>::type char_type;
typedef typename default_regex_traits<char_type>::type traits_type;
traits_type traits;
static_compile_impl2(xpr, impl, traits);
}
///////////////////////////////////////////////////////////////////////////////
// static_compile_impl1
template<typename Locale, typename Xpr, typename BidiIter>
void static_compile_impl1
(
proto::binary_op<locale_modifier<Locale>, Xpr, modifier_tag> const &xpr
, regex_impl<BidiIter> &impl
)
{
// use specified traits
typedef typename regex_traits_type<Locale, BidiIter>::type traits_type;
static_compile_impl2(proto::right(xpr), impl, traits_type(proto::left(xpr).getloc()));
}
///////////////////////////////////////////////////////////////////////////////
// static_compile
template<typename Xpr, typename BidiIter>
void static_compile(Xpr const &xpr, regex_impl<BidiIter> &impl)
{
static_compile_impl1(xpr, impl);
}
}}} // namespace boost::xpressive::detail
#endif