summaryrefslogtreecommitdiffstats
path: root/libcxx/test
diff options
context:
space:
mode:
authorHoward Hinnant <hhinnant@apple.com>2013-07-23 16:18:04 +0000
committerHoward Hinnant <hhinnant@apple.com>2013-07-23 16:18:04 +0000
commit7491a160311b10bd073b65233787b932f9d79675 (patch)
tree2c75e840df27279f7563be6d5d2e45beabd9e4fe /libcxx/test
parent9b3d2c026039a3a888de78ee86ccf1da3cf01dca (diff)
downloadbcm5719-llvm-7491a160311b10bd073b65233787b932f9d79675.tar.gz
bcm5719-llvm-7491a160311b10bd073b65233787b932f9d79675.zip
Bill Fisher: This patch fixes a bug where std::regex in ECMAScript mode was ignoring capture groups inside lookahead assertions.
For example, matching /(?=(a))(a)/ to "a" should yield two captures: \1 = "a", \2 = "a" llvm-svn: 186954
Diffstat (limited to 'libcxx/test')
-rw-r--r--libcxx/test/re/re.alg/re.alg.match/lookahead_capture.pass.cpp98
1 files changed, 98 insertions, 0 deletions
diff --git a/libcxx/test/re/re.alg/re.alg.match/lookahead_capture.pass.cpp b/libcxx/test/re/re.alg/re.alg.match/lookahead_capture.pass.cpp
new file mode 100644
index 00000000000..78e1e65c31d
--- /dev/null
+++ b/libcxx/test/re/re.alg/re.alg.match/lookahead_capture.pass.cpp
@@ -0,0 +1,98 @@
+//===----------------------------------------------------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is dual licensed under the MIT and the University of Illinois Open
+// Source Licenses. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+// <regex>
+
+// template <class BidirectionalIterator, class Allocator, class charT, class traits>
+// bool
+// regex_match(BidirectionalIterator first, BidirectionalIterator last,
+// match_results<BidirectionalIterator, Allocator>& m,
+// const basic_regex<charT, traits>& e,
+// regex_constants::match_flag_type flags = regex_constants::match_default);
+
+// std::regex in ECMAScript mode should not ignore capture groups inside lookahead assertions.
+// For example, matching /(?=(a))(a)/ to "a" should yield two captures: \1 = "a", \2 = "a"
+
+#include <regex>
+#include <cassert>
+
+#include "test_iterators.h"
+
+int main()
+{
+ {
+ std::regex re{"^(?=(.))a$"};
+ assert(re.mark_count() == 1);
+
+ std::string s{"a"};
+ std::smatch m;
+ assert(std::regex_match(s, m, re));
+ assert(m.size() == 2);
+ assert(m[0] == "a");
+ assert(m[1] == "a");
+ }
+
+ {
+ std::regex re{"^(a)(?=(.))(b)$"};
+ assert(re.mark_count() == 3);
+
+ std::string s{"ab"};
+ std::smatch m;
+ assert(std::regex_match(s, m, re));
+ assert(m.size() == 4);
+ assert(m[0] == "ab");
+ assert(m[1] == "a");
+ assert(m[2] == "b");
+ assert(m[3] == "b");
+ }
+
+ {
+ std::regex re{"^(.)(?=(.)(?=.(.)))(...)$"};
+ assert(re.mark_count() == 4);
+
+ std::string s{"abcd"};
+ std::smatch m;
+ assert(std::regex_match(s, m, re));
+ assert(m.size() == 5);
+ assert(m[0] == "abcd");
+ assert(m[1] == "a");
+ assert(m[2] == "b");
+ assert(m[3] == "d");
+ assert(m[4] == "bcd");
+ }
+
+ {
+ std::regex re{"^(a)(?!([^b]))(.c)$"};
+ assert(re.mark_count() == 3);
+
+ std::string s{"abc"};
+ std::smatch m;
+ assert(std::regex_match(s, m, re));
+ assert(m.size() == 4);
+ assert(m[0] == "abc");
+ assert(m[1] == "a");
+ assert(m[2] == "");
+ assert(m[3] == "bc");
+ }
+
+ {
+ std::regex re{"^(?!((b)))(?=(.))(?!(abc)).b$"};
+ assert(re.mark_count() == 4);
+
+ std::string s{"ab"};
+ std::smatch m;
+ assert(std::regex_match(s, m, re));
+ assert(m.size() == 5);
+ assert(m[0] == "ab");
+ assert(m[1] == "");
+ assert(m[2] == "");
+ assert(m[3] == "a");
+ assert(m[4] == "");
+ }
+}
OpenPOWER on IntegriCloud