Index: include/llvm/Support/Regex.h =================================================================== --- include/llvm/Support/Regex.h +++ include/llvm/Support/Regex.h @@ -52,11 +52,7 @@ std::swap(error, regex.error); return *this; } - Regex(Regex &®ex) { - preg = regex.preg; - error = regex.error; - regex.preg = nullptr; - } + Regex(Regex &®ex); ~Regex(); /// isValid - returns the error encountered during regex compilation, or Index: lib/Support/Regex.cpp =================================================================== --- lib/Support/Regex.cpp +++ lib/Support/Regex.cpp @@ -34,6 +34,13 @@ error = llvm_regcomp(preg, regex.data(), flags|REG_PEND); } +Regex::Regex(Regex &®ex) { + preg = regex.preg; + error = regex.error; + regex.preg = nullptr; + regex.error = REG_BADPAT; +} + Regex::~Regex() { if (preg) { llvm_regfree(preg); @@ -59,6 +66,9 @@ } bool Regex::match(StringRef String, SmallVectorImpl *Matches){ + if (error) + return false; + unsigned nmatch = Matches ? preg->re_nsub+1 : 0; // pmatch needs to have at least one element. Index: unittests/Support/RegexTest.cpp =================================================================== --- unittests/Support/RegexTest.cpp +++ unittests/Support/RegexTest.cpp @@ -151,6 +151,8 @@ Regex r2("abc"); r2 = std::move(r1); EXPECT_TRUE(r2.match("916")); + std::string Error; + EXPECT_FALSE(r1.isValid(Error)); } TEST_F(RegexTest, NoArgConstructor) { @@ -162,4 +164,11 @@ EXPECT_TRUE(r1.isValid(Error)); } +TEST_F(RegexTest, MatchInvalid) { + Regex r1; + std::string Error; + EXPECT_FALSE(r1.isValid(Error)); + EXPECT_FALSE(r1.match("X")); +} + }