diff --git a/libcxx/include/regex b/libcxx/include/regex --- a/libcxx/include/regex +++ b/libcxx/include/regex @@ -2306,7 +2306,7 @@ else { if (__b.size() != 1 || __e.size() != 1) - __throw_regex_error(); + __throw_regex_error(); if (__icase_) { __b[0] = __traits_.translate_nocase(__b[0]); diff --git a/libcxx/test/std/re/re.regex/re.regex.construct/bad_range.pass.cpp b/libcxx/test/std/re/re.regex/re.regex.construct/bad_range.pass.cpp new file mode 100644 --- /dev/null +++ b/libcxx/test/std/re/re.regex/re.regex.construct/bad_range.pass.cpp @@ -0,0 +1,38 @@ +//===----------------------------------------------------------------------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +// UNSUPPORTED: libcpp-no-exceptions +// + +// template > class basic_regex; + +// template +// basic_regex(const basic_string& s); + +#include +#include +#include "test_macros.h" + +static bool error_range_thrown(const char *pat) +{ + bool result = false; + try { + std::regex re(pat); + } catch (const std::regex_error &ex) { + result = (ex.code() == std::regex_constants::error_range); + } + return result; +} + +int main(int, char**) +{ + assert(error_range_thrown(R"([\w-a])")); + assert(error_range_thrown(R"([a-\w])")); + + return 0; +}