| //===----------------------------------------------------------------------===// |
| // |
| // 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 OutputIterator, class BidirectionalIterator, |
| // class traits, class charT, class ST, class SA> |
| // OutputIterator |
| // regex_replace(OutputIterator out, |
| // BidirectionalIterator first, BidirectionalIterator last, |
| // const basic_regex<charT, traits>& e, |
| // const basic_string<charT, ST, SA>& fmt, |
| // regex_constants::match_flag_type flags = |
| // regex_constants::match_default); |
| |
| #include <regex> |
| #include <cassert> |
| |
| #include "test_iterators.h" |
| |
| int main() |
| { |
| { |
| std::regex phone_numbers("\\d{3}-\\d{4}"); |
| const char phone_book[] = "555-1234, 555-2345, 555-3456"; |
| typedef output_iterator<char*> Out; |
| typedef bidirectional_iterator<const char*> Bi; |
| char buf[100] = {0}; |
| Out r = std::regex_replace(Out(buf), Bi(std::begin(phone_book)), |
| Bi(std::end(phone_book)-1), phone_numbers, |
| std::string("123-$&")); |
| assert(r.base() == buf+40); |
| assert(buf == std::string("123-555-1234, 123-555-2345, 123-555-3456")); |
| } |
| { |
| std::regex phone_numbers("\\d{3}-\\d{4}"); |
| const char phone_book[] = "555-1234, 555-2345, 555-3456"; |
| typedef output_iterator<char*> Out; |
| typedef bidirectional_iterator<const char*> Bi; |
| char buf[100] = {0}; |
| Out r = std::regex_replace(Out(buf), Bi(std::begin(phone_book)), |
| Bi(std::end(phone_book)-1), phone_numbers, |
| std::string("123-$&"), |
| std::regex_constants::format_sed); |
| assert(r.base() == buf+43); |
| assert(buf == std::string("123-$555-1234, 123-$555-2345, 123-$555-3456")); |
| } |
| { |
| std::regex phone_numbers("\\d{3}-\\d{4}"); |
| const char phone_book[] = "555-1234, 555-2345, 555-3456"; |
| typedef output_iterator<char*> Out; |
| typedef bidirectional_iterator<const char*> Bi; |
| char buf[100] = {0}; |
| Out r = std::regex_replace(Out(buf), Bi(std::begin(phone_book)), |
| Bi(std::end(phone_book)-1), phone_numbers, |
| std::string("123-&"), |
| std::regex_constants::format_sed); |
| assert(r.base() == buf+40); |
| assert(buf == std::string("123-555-1234, 123-555-2345, 123-555-3456")); |
| } |
| { |
| std::regex phone_numbers("\\d{3}-\\d{4}"); |
| const char phone_book[] = "555-1234, 555-2345, 555-3456"; |
| typedef output_iterator<char*> Out; |
| typedef bidirectional_iterator<const char*> Bi; |
| char buf[100] = {0}; |
| Out r = std::regex_replace(Out(buf), Bi(std::begin(phone_book)), |
| Bi(std::end(phone_book)-1), phone_numbers, |
| std::string("123-$&"), |
| std::regex_constants::format_no_copy); |
| assert(r.base() == buf+36); |
| assert(buf == std::string("123-555-1234123-555-2345123-555-3456")); |
| } |
| { |
| std::regex phone_numbers("\\d{3}-\\d{4}"); |
| const char phone_book[] = "555-1234, 555-2345, 555-3456"; |
| typedef output_iterator<char*> Out; |
| typedef bidirectional_iterator<const char*> Bi; |
| char buf[100] = {0}; |
| Out r = std::regex_replace(Out(buf), Bi(std::begin(phone_book)), |
| Bi(std::end(phone_book)-1), phone_numbers, |
| std::string("123-$&"), |
| std::regex_constants::format_first_only); |
| assert(r.base() == buf+32); |
| assert(buf == std::string("123-555-1234, 555-2345, 555-3456")); |
| } |
| { |
| std::regex phone_numbers("\\d{3}-\\d{4}"); |
| const char phone_book[] = "555-1234, 555-2345, 555-3456"; |
| typedef output_iterator<char*> Out; |
| typedef bidirectional_iterator<const char*> Bi; |
| char buf[100] = {0}; |
| Out r = std::regex_replace(Out(buf), Bi(std::begin(phone_book)), |
| Bi(std::end(phone_book)-1), phone_numbers, |
| std::string("123-$&"), |
| std::regex_constants::format_first_only | |
| std::regex_constants::format_no_copy); |
| assert(r.base() == buf+12); |
| assert(buf == std::string("123-555-1234")); |
| } |
| } |