bitcore-node-zcash/deps/boost/log/support/xpressive.hpp

95 lines
2.7 KiB
C++

/*
* 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
#endif
namespace boost {
BOOST_LOG_OPEN_NAMESPACE
namespace aux {
//! The trait verifies if the type can be converted to a Boost.Xpressive regex
template< 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 implementation
template< >
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 aux
BOOST_LOG_CLOSE_NAMESPACE // namespace log
} // namespace boost
#include <boost/log/detail/footer.hpp>
#endif // BOOST_LOG_SUPPORT_XPRESSIVE_HPP_INCLUDED_