diff -r 000000000000 -r bde4ae8d615e os/ossrv/ossrv_pub/boost_apis/boost/xpressive/sub_match.hpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/os/ossrv/ossrv_pub/boost_apis/boost/xpressive/sub_match.hpp Fri Jun 15 03:10:57 2012 +0200 @@ -0,0 +1,331 @@ +/////////////////////////////////////////////////////////////////////////////// +/// \file sub_match.hpp +/// Contains the definition of the class template sub_match\<\> +/// and associated helper functions +// +// 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_SUB_MATCH_HPP_EAN_10_04_2005 +#define BOOST_XPRESSIVE_SUB_MATCH_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 + +//{{AFX_DOC_COMMENT +/////////////////////////////////////////////////////////////////////////////// +// This is a hack to get Doxygen to show the inheritance relation between +// sub_match and std::pair. +#ifdef BOOST_XPRESSIVE_DOXYGEN_INVOKED +/// INTERNAL ONLY +namespace std +{ + /// INTERNAL ONLY + template struct pair {}; +} +#endif +//}}AFX_DOC_COMMENT + +namespace boost { namespace xpressive +{ + +/////////////////////////////////////////////////////////////////////////////// +// sub_match +// +/// \brief Class template sub_match denotes the sequence of characters matched by a particular marked sub-expression. +/// +/// When the marked sub-expression denoted by an object of type sub_match\<\> participated in a +/// regular expression match then member matched evaluates to true, and members first and second +/// denote the range of characters [first,second) which formed that match. Otherwise matched is false, +/// and members first and second contained undefined values. +/// +/// If an object of type sub_match\<\> represents sub-expression 0 - that is to say the whole match - +/// then member matched is always true, unless a partial match was obtained as a result of the flag +/// match_partial being passed to a regular expression algorithm, in which case member matched is +/// false, and members first and second represent the character range that formed the partial match. +template +struct sub_match + : std::pair +{ +private: + struct dummy { int i_; }; + typedef int dummy::*bool_type; + +public: + typedef typename iterator_value::type value_type; + typedef typename iterator_difference::type difference_type; + typedef std::basic_string string_type; + typedef BidiIter iterator; + + explicit sub_match(BidiIter first = BidiIter(), BidiIter second = BidiIter(), bool matched_ = false) + : std::pair(first, second) + , matched(matched_) + { + } + + string_type str() const + { + return this->matched ? string_type(this->first, this->second) : string_type(); + } + + operator string_type() const + { + return this->matched ? string_type(this->first, this->second) : string_type(); + } + + difference_type length() const + { + return this->matched ? std::distance(this->first, this->second) : 0; + } + + operator bool_type() const + { + return this->matched ? &dummy::i_ : 0; + } + + bool operator !() const + { + return !this->matched; + } + + /// \brief Performs a lexicographic string comparison + /// \param str the string against which to compare + /// \return the results of (*this).str().compare(str) + int compare(string_type const &str) const + { + return this->str().compare(str); + } + + /// \overload + int compare(sub_match const &sub) const + { + return this->str().compare(sub.str()); + } + + /// \overload + int compare(value_type const *ptr) const + { + return this->str().compare(ptr); + } + + /// \brief true if this sub-match participated in the full match. + bool matched; +}; + +/////////////////////////////////////////////////////////////////////////////// +/// \brief insertion operator for sending sub-matches to ostreams +/// \param sout output stream. +/// \param sub sub_match object to be written to the stream. +/// \return sout \<\< sub.str() +template +inline std::basic_ostream &operator << +( + std::basic_ostream &sout + , sub_match const &sub +) +{ + typedef typename iterator_value::type char_type; + if(sub.matched) + { + std::ostream_iterator iout(sout); + std::copy(sub.first, sub.second, iout); + } + return sout; +} + + +// BUGBUG make these more efficient + +template +bool operator == (sub_match const &lhs, sub_match const &rhs) +{ + return lhs.compare(rhs) == 0; +} + +template +bool operator != (sub_match const &lhs, sub_match const &rhs) +{ + return lhs.compare(rhs) != 0; +} + +template +bool operator < (sub_match const &lhs, sub_match const &rhs) +{ + return lhs.compare(rhs) < 0; +} + +template +bool operator <= (sub_match const &lhs, sub_match const &rhs) +{ + return lhs.compare(rhs) <= 0; +} + +template +bool operator >= (sub_match const &lhs, sub_match const &rhs) +{ + return lhs.compare(rhs)>= 0; +} + +template +bool operator> (sub_match const &lhs, sub_match const &rhs) +{ + return lhs.compare(rhs)> 0; +} + +template +bool operator == (typename iterator_value::type const *lhs, sub_match const &rhs) +{ + return lhs == rhs.str(); +} + +template +bool operator != (typename iterator_value::type const *lhs, sub_match const &rhs) +{ + return lhs != rhs.str(); +} + +template +bool operator < (typename iterator_value::type const *lhs, sub_match const &rhs) +{ + return lhs < rhs.str(); +} + +template +bool operator> (typename iterator_value::type const *lhs, sub_match const &rhs) +{ + return lhs> rhs.str(); +} + +template +bool operator >= (typename iterator_value::type const *lhs, sub_match const &rhs) +{ + return lhs >= rhs.str(); +} + +template +bool operator <= (typename iterator_value::type const *lhs, sub_match const &rhs) +{ + return lhs <= rhs.str(); +} + +template +bool operator == (sub_match const &lhs, typename iterator_value::type const *rhs) +{ + return lhs.str() == rhs; +} + +template +bool operator != (sub_match const &lhs, typename iterator_value::type const *rhs) +{ + return lhs.str() != rhs; +} + +template +bool operator < (sub_match const &lhs, typename iterator_value::type const *rhs) +{ + return lhs.str() < rhs; +} + +template +bool operator> (sub_match const &lhs, typename iterator_value::type const *rhs) +{ + return lhs.str()> rhs; +} + +template +bool operator >= (sub_match const &lhs, typename iterator_value::type const *rhs) +{ + return lhs.str()>= rhs; +} + +template +bool operator <= (sub_match const &lhs, typename iterator_value::type const *rhs) +{ + return lhs.str() <= rhs; +} + +template +bool operator == (typename iterator_value::type const &lhs, sub_match const &rhs) +{ + return lhs == rhs.str(); +} + +template +bool operator != (typename iterator_value::type const &lhs, sub_match const &rhs) +{ + return lhs != rhs.str(); +} + +template +bool operator < (typename iterator_value::type const &lhs, sub_match const &rhs) +{ + return lhs < rhs.str(); +} + +template +bool operator> (typename iterator_value::type const &lhs, sub_match const &rhs) +{ + return lhs> rhs.str(); +} + +template +bool operator >= (typename iterator_value::type const &lhs, sub_match const &rhs) +{ + return lhs >= rhs.str(); +} + +template +bool operator <= (typename iterator_value::type const &lhs, sub_match const &rhs) +{ + return lhs <= rhs.str(); +} + +template +bool operator == (sub_match const &lhs, typename iterator_value::type const &rhs) +{ + return lhs.str() == rhs; +} + +template +bool operator != (sub_match const &lhs, typename iterator_value::type const &rhs) +{ + return lhs.str() != rhs; +} + +template +bool operator < (sub_match const &lhs, typename iterator_value::type const &rhs) +{ + return lhs.str() < rhs; +} + +template +bool operator> (sub_match const &lhs, typename iterator_value::type const &rhs) +{ + return lhs.str()> rhs; +} + +template +bool operator >= (sub_match const &lhs, typename iterator_value::type const &rhs) +{ + return lhs.str()>= rhs; +} + +template +bool operator <= (sub_match const &lhs, typename iterator_value::type const &rhs) +{ + return lhs.str() <= rhs; +} + +}} // namespace boost::xpressive + +#endif