Mercurial > hg > vamp-build-and-test
view DEPENDENCIES/generic/include/boost/log/support/xpressive.hpp @ 16:2665513ce2d3
Add boost headers
author | Chris Cannam |
---|---|
date | Tue, 05 Aug 2014 11:11:38 +0100 |
parents | |
children | c530137014c0 |
line wrap: on
line source
/* * 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_