Merged trunk at revision 161680 into branch.
[official-gcc.git] / libstdc++-v3 / testsuite / 28_regex / 11_algorithms / 02_match / extended / cstring_questionmark.cc
blob21abea456a9ef7c507ee7663b7e35dc1e1bed946
1 // { dg-options "-std=c++0x" }
2 // { dg-do run { xfail *-*-* } }
4 //
5 // 2010-06-21 Stephen M. Webb <stephen.webb@bregmasoft.ca>
6 //
7 // Copyright (C) 2010 Free Software Foundation, Inc.
8 //
9 // This file is part of the GNU ISO C++ Library. This library is free
10 // software; you can redistribute it and/or modify it under the
11 // terms of the GNU General Public License as published by the
12 // Free Software Foundation; either version 3, or (at your option)
13 // any later version.
15 // This library is distributed in the hope that it will be useful,
16 // but WITHOUT ANY WARRANTY; without even the implied warranty of
17 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 // GNU General Public License for more details.
20 // You should have received a copy of the GNU General Public License along
21 // with this library; see the file COPYING3. If not see
22 // <http://www.gnu.org/licenses/>.
24 // 28.11.2 regex_match
25 // Tests ERE against a C-string target, question-mark match.
27 #include <regex>
28 #include <testsuite_hooks.h>
30 void
31 test01()
33 bool test __attribute__((unused)) = true;
35 std::regex re("(aa?)", std::regex::extended);
36 char target[] = "a";
37 std::cmatch m;
39 VERIFY( std::regex_match(target, m, re) );
41 VERIFY( re.mark_count() == 1 );
42 VERIFY( m.size() == re.mark_count()+1 );
43 VERIFY( m.empty() == false );
44 VERIFY( m.prefix().first == target );
45 VERIFY( m.prefix().second == target );
46 VERIFY( m.prefix().matched == false );
47 VERIFY( m.suffix().first == target+sizeof(target) );
48 VERIFY( m.suffix().second == target+sizeof(target) );
49 VERIFY( m.suffix().matched == false );
50 VERIFY( m[0].first == target );
51 VERIFY( m[0].second == target+sizeof(target) );
52 VERIFY( m[0].matched == true );
53 VERIFY( m[1].first == target );
54 VERIFY( m[1].second == target+sizeof(target) );
55 VERIFY( m[1].matched == true );
59 int
60 main()
62 test01();
63 return 0;