Created on 2019-11-17.00:00:00 last changed 1 month ago
[ 2022-04-22; Jonathan adds a comment ]
As well as requiring the reference type to be convertible to charT, we might want to consider constraining these with forward_iterator as per P2408.
[ 2021-10-04; Jonathan adds a comment ]
There isn't even a requirement that the arguments are iterators. And assign(InputIterator, InputIterator, flag_type) is not constrained to only accept iterators either, meaning you can call it with two integers and call the basic_string(size_type, char_type) constructor.
[ 2019-11-30 Issue Prioritization ]
Priority to 3 after reflector discussion.
This is description of a basic_regex range constructor from N4835, [re.regex.construct]:
template<class ForwardIterator> basic_regex(ForwardIterator first, ForwardIterator last, flag_type f = regex_constants::ECMAScript);
-17- Throws: regex_error if the sequence [first, last) is not a valid regular expression.-18- Effects: Constructs an object of class basic_regex; the object's internal finite state machine is constructed from the regular expression contained in the sequence of characters [first, last), and interpreted according to the flags specified in f. -19- Ensures: flags() returns f. mark_count() returns the number of marked sub-expressions within the expression.
It seems that there are no requirements about dereferenced iterator's element type, that, apparently, must be implicitly convertible to the basic_regex::value_type. For example, containers having range constructor satisfy a SequenceContainer requirements, where implicit converting to its elements is specified.
|2022-04-22 17:05:58||admin||set||messages: + msg12421|
|2021-10-04 12:26:14||admin||set||messages: + msg12102|
|2019-11-30 13:47:36||admin||set||messages: + msg10852|