regex_search
paramsSection: 28.6.10.3 [re.alg.search] Status: NAD Editorial Submitter: Daniel Krügler Opened: 2007-02-26 Last modified: 2016-01-28
Priority: Not Prioritized
View all issues with NAD Editorial status.
Discussion:
28.6.10.3 [re.alg.search]/5 declares
template <class iterator, class charT, class traits> bool regex_search(iterator first, iterator last, const basic_regex<charT, traits>& e, regex_constants::match_flag_type flags = regex_constants::match_default);
where it's not explained, which iterator category the parameter iterator belongs to. This is inconsistent to the preceding declaration in the synopsis section 28.6.3 [re.syn], which says:
template <class BidirectionalIterator, class charT, class traits> bool regex_search(BidirectionalIterator first, BidirectionalIterator last, const basic_regex<charT, traits>& e, regex_constants::match_flag_type flags = regex_constants::match_default);
Proposed resolution:
In 28.6.10.3 [re.alg.search]/5 replace all three occurences of param "iterator" with "BidirectionalIterator"
template <classiteratorBidirectionalIterator, class charT, class traits> bool regex_search(iteratorBidirectionalIterator first,iteratorBidirectionalIterator last, const basic_regex<charT, traits>& e, regex_constants::match_flag_type flags = regex_constants::match_default);-6- Effects: Behaves "as if" by constructing an object what of type
match_results<
and then returning the result ofiteratorBidirectionalIterator>regex_search(first, last, what, e, flags)
.
Rationale:
Applied to working paper while issue was still in New status.