| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 | /* *          Copyright Andrey Semashev 2007 - 2013. * 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) *//*! * \file   support/xpressive.hpp * \author Andrey Semashev * \date   18.07.2009 * * This header enables Boost.Xpressive support for Boost.Log. */#ifndef BOOST_LOG_SUPPORT_XPRESSIVE_HPP_INCLUDED_#define BOOST_LOG_SUPPORT_XPRESSIVE_HPP_INCLUDED_#include <boost/mpl/bool.hpp>#include <boost/xpressive/basic_regex.hpp>#include <boost/xpressive/regex_constants.hpp>#include <boost/xpressive/regex_algorithms.hpp>#include <boost/log/detail/config.hpp>#include <boost/log/utility/functional/matches.hpp>#include <boost/log/detail/header.hpp>#ifdef BOOST_HAS_PRAGMA_ONCE#pragma once#endifnamespace boost {BOOST_LOG_OPEN_NAMESPACEnamespace aux {//! The trait verifies if the type can be converted to a Boost.Xpressive regextemplate< typename T >struct is_xpressive_regex< T, true >{private:    typedef char yes_type;    struct no_type { char dummy[2]; };    template< typename U >    static yes_type check_xpressive_regex(xpressive::basic_regex< U > const&);    static no_type check_xpressive_regex(...);    static T& get_T();public:    enum { value = sizeof(check_xpressive_regex(get_T())) == sizeof(yes_type) };    typedef mpl::bool_< value > type;};//! The regex matching functor implementationtemplate< >struct matches_fun_impl< boost_xpressive_expression_tag >{    template< typename StringT, typename T >    static bool matches(        StringT const& str,        xpressive::basic_regex< T > const& expr,        xpressive::regex_constants::match_flag_type flags = xpressive::regex_constants::match_default)    {        return xpressive::regex_match(str, expr, flags);    }    template< typename StringT >    static bool matches(        StringT const& str,        xpressive::basic_regex< typename StringT::value_type* > const& expr,        xpressive::regex_constants::match_flag_type flags = xpressive::regex_constants::match_default)    {        return xpressive::regex_match(str.c_str(), expr, flags);    }    template< typename StringT >    static bool matches(        StringT const& str,        xpressive::basic_regex< typename StringT::value_type const* > const& expr,        xpressive::regex_constants::match_flag_type flags = xpressive::regex_constants::match_default)    {        return xpressive::regex_match(str.c_str(), expr, flags);    }};} // namespace auxBOOST_LOG_CLOSE_NAMESPACE // namespace log} // namespace boost#include <boost/log/detail/footer.hpp>#endif // BOOST_LOG_SUPPORT_XPRESSIVE_HPP_INCLUDED_
 |