⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 regex.hpp

📁 CGAL is a collaborative effort of several sites in Europe and Israel. The goal is to make the most i
💻 HPP
📖 第 1 页 / 共 2 页
字号:
//  Boost string_algo library regex.hpp header file  ---------------------------////  Copyright Pavol Droba 2002-2003. Use, modification and//  distribution is subject to 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)//  See http://www.boost.org for updates, documentation, and revision history.#ifndef BOOST_STRING_REGEX_HPP#define BOOST_STRING_REGEX_HPP#include <boost/algorithm/string/config.hpp>#include <boost/regex.hpp>#include <boost/algorithm/string/collection_traits.hpp>#include <boost/algorithm/string/iterator_range.hpp>#include <boost/algorithm/string/find_format.hpp>#include <boost/algorithm/string/regex_find_format.hpp>#include <boost/algorithm/string/formatter.hpp>#include <boost/algorithm/string/iter_find.hpp>/*! \file    Defines regex variants of the algorithms. */namespace boost {    namespace algorithm {//  find_regex  -----------------------------------------------//        //! Find regex algorithm        /*!            Search for a substring matching the given regex in the input.                        \param Input A container which will be searched.            \param Rx A regular expression            \param Flags Regex options            \return                 An \c iterator_range delimiting the match.                 Returned iterator is either \c InputContainerT::iterator or                 \c InputContainerT::const_iterator, depending on the constness of                 the input parameter.              \note This function provides the strong exception-safety guarantee        */        template<             typename CollectionT,             typename CharT,             typename RegexTraitsT, typename RegexAllocatorT>        inline iterator_range<             BOOST_STRING_TYPENAME result_iterator_of<CollectionT>::type >        find_regex(             CollectionT& Input,             const reg_expression<CharT, RegexTraitsT, RegexAllocatorT>& Rx,            match_flag_type Flags=match_default )        {            return regex_finder(Rx,Flags)(                begin(Input), end(Input) );        }//  replace_regex --------------------------------------------------------------------//        //! Replace regex algorithm        /*!            Search for a substring matching given regex and format it with             the specified format.                         The result is a modified copy of the input. It is returned as a sequence             or copied to the output iterator.            \param Output An output iterator to which the result will be copied            \param Input An input string            \param Rx A regular expression            \param Format Regex format definition            \param Flags Regex options            \return An output iterator pointing just after the last inserted character or                    a modified copy of the input                \note The second variant of this function provides the strong exception-safety guarantee        */        template<             typename OutputIteratorT,            typename CollectionT,             typename CharT,             typename RegexTraitsT, typename RegexAllocatorT,            typename FormatStringTraitsT, typename FormatStringAllocatorT >        inline OutputIteratorT replace_regex_copy(            OutputIteratorT Output,            const CollectionT& Input,            const reg_expression<CharT, RegexTraitsT, RegexAllocatorT>& Rx,            const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,            match_flag_type Flags=match_default | format_default )        {            return find_format_copy(                 Output,                Input,                regex_finder( Rx, Flags ),                regex_formatter( Format, Flags ) );        }        //! Replace regex algorithm        /*!            \overload        */        template<             typename SequenceT,             typename CharT,             typename RegexTraitsT, typename RegexAllocatorT,            typename FormatStringTraitsT, typename FormatStringAllocatorT >        inline SequenceT replace_regex_copy(             const SequenceT& Input,            const reg_expression<CharT, RegexTraitsT, RegexAllocatorT>& Rx,            const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,            match_flag_type Flags=match_default | format_default )        {            return find_format_copy(                 Input,                regex_finder( Rx, Flags ),                regex_formatter( Format, Flags ) );        }        //! Replace regex algorithm        /*!            Search for a substring matching given regex and format it with             the specified format. The input string is modified in-place.            \param Input An input string            \param Rx A regular expression            \param Format Regex format definition            \param Flags Regex options        */        template<             typename SequenceT,             typename CharT,             typename RegexTraitsT, typename RegexAllocatorT,            typename FormatStringTraitsT, typename FormatStringAllocatorT >        inline void replace_regex(             SequenceT& Input,            const reg_expression<CharT, RegexTraitsT, RegexAllocatorT>& Rx,            const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,            match_flag_type Flags=match_default | format_default )        {            find_format(                 Input,                regex_finder( Rx, Flags ),                regex_formatter( Format, Flags ) );        }//  replace_all_regex --------------------------------------------------------------------//        //! Replace all regex algorithm        /*!            Format all substrings, matching given regex, with the specified format.             The result is a modified copy of the input. It is returned as a sequence             or copied to the output iterator.            \param Output An output iterator to which the result will be copied            \param Input An input string            \param Rx A regular expression            \param Format Regex format definition            \param Flags Regex options            \return An output iterator pointing just after the last inserted character or                    a modified copy of the input                   \note The second variant of this function provides the strong exception-safety guarantee        */        template<             typename OutputIteratorT,            typename CollectionT,             typename CharT,             typename RegexTraitsT, typename RegexAllocatorT,            typename FormatStringTraitsT, typename FormatStringAllocatorT >        inline OutputIteratorT replace_all_regex_copy(            OutputIteratorT Output,            const CollectionT& Input,            const reg_expression<CharT, RegexTraitsT, RegexAllocatorT>& Rx,            const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,            match_flag_type Flags=match_default | format_default )        {            return find_format_all_copy(                 Output,                Input,                regex_finder( Rx, Flags ),                regex_formatter( Format, Flags ) );        }        //! Replace all regex algorithm        /*!            \overload        */        template<             typename SequenceT,             typename CharT,             typename RegexTraitsT, typename RegexAllocatorT,            typename FormatStringTraitsT, typename FormatStringAllocatorT >        inline SequenceT replace_all_regex_copy(             const SequenceT& Input,            const reg_expression<CharT, RegexTraitsT, RegexAllocatorT>& Rx,            const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,            match_flag_type Flags=match_default | format_default )        {            return find_format_all_copy(                 Input,                regex_finder( Rx, Flags ),                regex_formatter( Format, Flags ) );        }        //! Replace all regex algorithm        /*!            Format all substrings, matching given regex, with the specified format.             The input string is modified in-place.            \param Input An input string            \param Rx A regular expression            \param Format Regex format definition            \param Flags Regex options                    */        template<             typename SequenceT,             typename CharT,             typename RegexTraitsT, typename RegexAllocatorT,            typename FormatStringTraitsT, typename FormatStringAllocatorT >        inline void replace_all_regex(             SequenceT& Input,            const reg_expression<CharT, RegexTraitsT, RegexAllocatorT>& Rx,            const std::basic_string<CharT, FormatStringTraitsT, FormatStringAllocatorT>& Format,            match_flag_type Flags=match_default | format_default )        {            find_format_all(                 Input,                regex_finder( Rx, Flags ),                regex_formatter( Format, Flags ) );        }//  erase_regex --------------------------------------------------------------------//        //! Erase regex algorithm        /*!            Remove a substring matching given regex from the input.            The result is a modified copy of the input. It is returned as a sequence             or copied to the output iterator.                                    \param Output An output iterator to which the result will be copied            \param Input An input string            \param Rx A regular expression            \param Flags Regex options            \return An output iterator pointing just after the last inserted character or

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -