Implement P0386R2 - C++17 inline variables
[official-gcc.git] / libstdc++-v3 / testsuite / 28_regex / algorithms / regex_match / basic / string_01.cc
bloba949f90ae3ac15ae0853b3c9ab11a2cf82f4a76a
1 // { dg-do run { target c++11 } }
3 //
4 // 2010-06-11 Stephen M. Webb <stephen.webb@bregmasoft.ca>
5 //
6 // Copyright (C) 2010-2016 Free Software Foundation, Inc.
7 //
8 // This file is part of the GNU ISO C++ Library. This library is free
9 // software; you can redistribute it and/or modify it under the
10 // terms of the GNU General Public License as published by the
11 // Free Software Foundation; either version 3, or (at your option)
12 // any later version.
14 // This library is distributed in the hope that it will be useful,
15 // but WITHOUT ANY WARRANTY; without even the implied warranty of
16 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 // GNU General Public License for more details.
19 // You should have received a copy of the GNU General Public License along
20 // with this library; see the file COPYING3. If not see
21 // <http://www.gnu.org/licenses/>.
23 // 28.11.2 regex_match
24 // Tests BRE against a std::string target.
26 #include <regex>
27 #include <testsuite_hooks.h>
28 #include <testsuite_regex.h>
30 using namespace __gnu_test;
31 using namespace std;
33 void
34 test01()
36 bool test __attribute__((unused)) = true;
38 std::regex re("\\(a\\).*", std::regex::basic);
39 std::string target("aaba");
40 std::smatch m;
42 VERIFY( regex_match_debug(target, m, re) );
44 VERIFY( m.size() == re.mark_count()+1 );
45 VERIFY( m.empty() == false );
46 VERIFY( m.prefix().first == target.begin() );
47 VERIFY( m.prefix().second == target.begin() );
48 VERIFY( m.prefix().matched == false );
49 VERIFY( m.suffix().first == target.end() );
50 VERIFY( m.suffix().second == target.end() );
51 VERIFY( m.suffix().matched == false );
52 VERIFY( m[0].first == target.begin() );
53 VERIFY( m[0].second == target.end() );
54 VERIFY( m[0].matched == true );
55 VERIFY( m[1].first == target.begin() );
56 VERIFY( m[1].second == target.begin()+1 );
57 VERIFY( m[1].matched == true );
61 int
62 main()
64 test01();
65 return 0;