1 //===----------------------------------------------------------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is dual licensed under the MIT and the University of Illinois Open 6 // Source Licenses. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 10 // <regex> 11 12 // class regex_iterator<BidirectionalIterator, charT, traits> 13 14 // template <size_t N> 15 // regex_token_iterator(BidirectionalIterator a, BidirectionalIterator b, 16 // const regex_type&& re, 17 // const int (&submatches)[N], 18 // regex_constants::match_flag_type m = 19 // regex_constants::match_default); 20 21 #include <regex> 22 #include <vector> 23 #include <cassert> 24 #include "test_macros.h" 25 26 #if TEST_STD_VER < 14 27 #error 28 #endif 29 30 int main() 31 { 32 { 33 std::regex phone_numbers("\\d{3}-(\\d{4})"); 34 const char phone_book[] = "start 555-1234, 555-2345, 555-3456 end"; 35 const int indices[] = {-1, 0, 1}; 36 std::cregex_token_iterator i(std::begin(phone_book), std::end(phone_book)-1, 37 std::regex("\\d{3}-\\d{4}"), indices); 38 } 39 } 40