regex.hpp

来自「Boost provides free peer-reviewed portab」· HPP 代码 · 共 647 行 · 第 1/2 页

HPP
647
字号
            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                    a modified copy of the input                                     \note The second variant of this function provides the strong exception-safety guarantee        */        template<             typename OutputIteratorT,            typename RangeT,             typename CharT,             typename RegexTraitsT >        inline OutputIteratorT erase_all_regex_copy(            OutputIteratorT Output,            const RangeT& Input,            const basic_regex<CharT, RegexTraitsT>& Rx,            match_flag_type Flags=match_default )        {            return find_format_all_copy(                Output,                Input,                regex_finder( Rx, Flags ),                empty_formatter( Input ) );        }        //! Erase all regex algorithm        /*!            \overload        */        template<             typename SequenceT,             typename CharT,             typename RegexTraitsT >        inline SequenceT erase_all_regex_copy(             const SequenceT& Input,            const basic_regex<CharT, RegexTraitsT>& Rx,            match_flag_type Flags=match_default )        {            return find_format_all_copy(                 Input,                 regex_finder( Rx, Flags ),                empty_formatter( Input ) );        }        //! Erase all regex algorithm        /*!            Erase all substrings, matching given regex, from the input.            The input string is modified in-place.            \param Input An input string            \param Rx A regular expression            \param Flags Regex options        */        template<             typename SequenceT,             typename CharT,             typename RegexTraitsT>        inline void erase_all_regex(             SequenceT& Input,            const basic_regex<CharT, RegexTraitsT>& Rx,            match_flag_type Flags=match_default )        {            find_format_all(                 Input,                 regex_finder( Rx, Flags ),                empty_formatter( Input ) );        }//  find_all_regex ------------------------------------------------------------------//        //! Find all regex algorithm        /*!            This algorithm finds all substrings matching the give regex            in the input.                                     Each part is copied and added as a new element to the output container.            Thus the result container must be able to hold copies            of the matches (in a compatible structure like std::string) or            a reference to it (e.g. using the iterator range class).            Examples of such a container are \c std::vector<std::string>            or \c std::list<boost::iterator_range<std::string::iterator>>            \param Result A container that can hold copies of references to the substrings.            \param Input A container which will be searched.            \param Rx A regular expression            \param Flags Regex options            \return A reference to the result            \note Prior content of the result will be overwritten.             \note This function provides the strong exception-safety guarantee        */        template<             typename SequenceSequenceT,             typename RangeT,                     typename CharT,             typename RegexTraitsT >        inline SequenceSequenceT& find_all_regex(            SequenceSequenceT& Result,            const RangeT& Input,            const basic_regex<CharT, RegexTraitsT>& Rx,            match_flag_type Flags=match_default )        {            return iter_find(                Result,                Input,                regex_finder(Rx,Flags) );                 }//  split_regex ------------------------------------------------------------------//        //! Split regex algorithm        /*!             Tokenize expression. This function is equivalent to C strtok. Input            sequence is split into tokens, separated  by separators. Separator            is an every match of the given regex.            Each part is copied and added as a new element to the output container.            Thus the result container must be able to hold copies            of the matches (in a compatible structure like std::string) or            a reference to it (e.g. using the iterator range class).            Examples of such a container are \c std::vector<std::string>            or \c std::list<boost::iterator_range<std::string::iterator>>                \param Result A container that can hold copies of references to the substrings.                      \param Input A container which will be searched.            \param Rx A regular expression            \param Flags Regex options            \return A reference to the result            \note Prior content of the result will be overwritten.               \note This function provides the strong exception-safety guarantee        */        template<             typename SequenceSequenceT,             typename RangeT,                     typename CharT,             typename RegexTraitsT >        inline SequenceSequenceT& split_regex(            SequenceSequenceT& Result,            const RangeT& Input,            const basic_regex<CharT, RegexTraitsT>& Rx,            match_flag_type Flags=match_default )        {            return iter_split(                Result,                Input,                regex_finder(Rx,Flags) );                 }//  join_if ------------------------------------------------------------------//#ifndef BOOST_NO_FUNCTION_TEMPLATE_ORDERING        //! Conditional join algorithm        /*!            This algorithm joins all strings in a 'list' into one long string.            Segments are concatenated by given separator. Only segments that            match the given regular expression will be added to the result            This is a specialization of join_if algorithm.            \param Input A container that holds the input strings. It must be a container-of-containers.            \param Separator A string that will separate the joined segments.            \param Rx A regular expression            \param Flags Regex options            \return Concatenated string.            \note This function provides the strong exception-safety guarantee        */        template<             typename SequenceSequenceT,             typename Range1T,                         typename CharT,             typename RegexTraitsT >        inline typename range_value<SequenceSequenceT>::type         join_if(            const SequenceSequenceT& Input,            const Range1T& Separator,            const basic_regex<CharT, RegexTraitsT>& Rx,            match_flag_type Flags=match_default )        {            // Define working types            typedef typename range_value<SequenceSequenceT>::type ResultT;            typedef typename range_const_iterator<SequenceSequenceT>::type InputIteratorT;            // Parse input            InputIteratorT itBegin=::boost::begin(Input);            InputIteratorT itEnd=::boost::end(Input);            // Construct container to hold the result            ResultT Result;            // Roll to the first element that will be added            while(                itBegin!=itEnd &&                 !regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags)) ++itBegin;            // Add this element            if(itBegin!=itEnd)            {                detail::insert(Result, ::boost::end(Result), *itBegin);                ++itBegin;            }            for(;itBegin!=itEnd; ++itBegin)            {                if(regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags))                {                    // Add separator                    detail::insert(Result, ::boost::end(Result), as_literal(Separator));                    // Add element                    detail::insert(Result, ::boost::end(Result), *itBegin);                }            }            return Result;        }#else  // BOOST_NO_FUNCTION_TEMPLATE_ORDERING                //! Conditional join algorithm        /*!            This algorithm joins all strings in a 'list' into one long string.            Segments are concatenated by given separator. Only segments that            match the given regular expression will be added to the result            This is a specialization of join_if algorithm.            \param Input A container that holds the input strings. It must be a container-of-containers.            \param Separator A string that will separate the joined segments.            \param Rx A regular expression            \param Flags Regex options            \return Concatenated string.            \note This function provides the strong exception-safety guarantee        */        template<             typename SequenceSequenceT,             typename Range1T,                         typename CharT,             typename RegexTraitsT >        inline typename range_value<SequenceSequenceT>::type         join_if_regex(            const SequenceSequenceT& Input,            const Range1T& Separator,            const basic_regex<CharT, RegexTraitsT>& Rx,            match_flag_type Flags=match_default )        {            // Define working types            typedef typename range_value<SequenceSequenceT>::type ResultT;            typedef typename range_const_iterator<SequenceSequenceT>::type InputIteratorT;            // Parse input            InputIteratorT itBegin=::boost::begin(Input);            InputIteratorT itEnd=::boost::end(Input);            // Construct container to hold the result            ResultT Result;            // Roll to the first element that will be added            while(                itBegin!=itEnd &&                 !regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags)) ++itBegin;            // Add this element            if(itBegin!=itEnd)            {                detail::insert(Result, ::boost::end(Result), *itBegin);                ++itBegin;            }            for(;itBegin!=itEnd; ++itBegin)            {                if(regex_match(::boost::begin(*itBegin), ::boost::end(*itBegin), Rx, Flags))                {                    // Add separator                    detail::insert(Result, ::boost::end(Result), as_literal(Separator));                    // Add element                    detail::insert(Result, ::boost::end(Result), *itBegin);                }            }            return Result;        }#endif // BOOST_NO_FUNCTION_TEMPLATE_ORDERING    } // namespace algorithm    // pull names into the boost namespace    using algorithm::find_regex;    using algorithm::replace_regex;    using algorithm::replace_regex_copy;    using algorithm::replace_all_regex;    using algorithm::replace_all_regex_copy;    using algorithm::erase_regex;    using algorithm::erase_regex_copy;    using algorithm::erase_all_regex;    using algorithm::erase_all_regex_copy;    using algorithm::find_all_regex;    using algorithm::split_regex;#ifndef BOOST_NO_FUNCTION_TEMPLATE_ORDERING    using algorithm::join_if;#else  // BOOST_NO_FUNCTION_TEMPLATE_ORDERING    using algorithm::join_if_regex;#endif // BOOST_NO_FUNCTION_TEMPLATE_ORDERING} // namespace boost#endif  // BOOST_STRING_REGEX_HPP

⌨️ 快捷键说明

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