diff options
| author | Howard Hinnant <hhinnant@apple.com> | 2013-07-23 16:18:04 +0000 |
|---|---|---|
| committer | Howard Hinnant <hhinnant@apple.com> | 2013-07-23 16:18:04 +0000 |
| commit | 7491a160311b10bd073b65233787b932f9d79675 (patch) | |
| tree | 2c75e840df27279f7563be6d5d2e45beabd9e4fe /libcxx/test | |
| parent | 9b3d2c026039a3a888de78ee86ccf1da3cf01dca (diff) | |
| download | bcm5719-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.cpp | 98 |
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] == ""); + } +} |

