forked from OSchip/llvm-project
Make regex::assign not clobber the regex in case of failure. Fixes PR#22213
llvm-svn: 225799
This commit is contained in:
parent
e7cad7a1df
commit
9db9069cf3
|
@ -2599,9 +2599,7 @@ public:
|
||||||
assign(_ForwardIterator __first, _ForwardIterator __last,
|
assign(_ForwardIterator __first, _ForwardIterator __last,
|
||||||
flag_type __f = regex_constants::ECMAScript)
|
flag_type __f = regex_constants::ECMAScript)
|
||||||
{
|
{
|
||||||
__member_init(__f);
|
return assign(basic_regex(__first, __last, __f));
|
||||||
__parse(__first, __last);
|
|
||||||
return *this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
|
#ifndef _LIBCPP_HAS_NO_GENERALIZED_INITIALIZERS
|
||||||
|
|
|
@ -23,4 +23,13 @@ int main()
|
||||||
r2.assign(r1);
|
r2.assign(r1);
|
||||||
assert(r2.flags() == std::regex::ECMAScript);
|
assert(r2.flags() == std::regex::ECMAScript);
|
||||||
assert(r2.mark_count() == 2);
|
assert(r2.mark_count() == 2);
|
||||||
|
assert(std::regex_search("ab", r2));
|
||||||
|
|
||||||
|
bool caught = false;
|
||||||
|
try { r2.assign("(def", std::regex::extended); }
|
||||||
|
catch(std::regex_error &) { caught = true; }
|
||||||
|
assert(caught);
|
||||||
|
assert(r2.flags() == std::regex::ECMAScript);
|
||||||
|
assert(r2.mark_count() == 2);
|
||||||
|
assert(std::regex_search("ab", r2));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue