* include/bits/stl_algo.h (is_permutation): Add overloads from N3671.
[official-gcc.git] / libstdc++-v3 / testsuite / libstdc++-prettyprinters / debug.cc
blob6adba773c491a92ca151945b4697149cb634711a
1 // { dg-do run }
2 // { dg-options "-g -O0" }
4 // Copyright (C) 2011-2013 Free Software Foundation, Inc.
5 //
6 // This file is part of the GNU ISO C++ Library. This library is free
7 // software; you can redistribute it and/or modify it under the
8 // terms of the GNU General Public License as published by the
9 // Free Software Foundation; either version 3, or (at your option)
10 // any later version.
12 // This library is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 // GNU General Public License for more details.
17 // You should have received a copy of the GNU General Public License along
18 // with this library; see the file COPYING3. If not see
19 // <http://www.gnu.org/licenses/>.
21 #define _GLIBCXX_DEBUG
23 #include <string>
24 #include <deque>
25 #include <bitset>
26 #include <iostream>
27 #include <list>
28 #include <map>
29 #include <set>
30 #include <ext/slist>
32 int
33 main()
35 std::string tem;
36 std::string str = "zardoz";
37 // { dg-final { note-test str "\"zardoz\"" } }
39 std::bitset<10> bs;
40 bs[0] = 1;
41 bs[5] = 1;
42 bs[7] = 1;
43 // { dg-final { note-test bs {std::__debug::bitset = {[0] = 1, [5] = 1, [7] = 1}} } }
45 std::deque<std::string> deq;
46 deq.push_back("one");
47 deq.push_back("two");
48 // { dg-final { note-test deq {std::__debug::deque with 2 elements = {"one", "two"}} } }
50 std::deque<std::string>::iterator deqiter = deq.begin();
51 // { dg-final { note-test deqiter {"one"} } }
53 std::list<std::string> lst;
54 lst.push_back("one");
55 lst.push_back("two");
56 // { dg-final { note-test lst {std::__debug::list = {[0] = "one", [1] = "two"}} } }
58 std::list<std::string>::iterator lstiter = lst.begin();
59 tem = *lstiter;
60 // { dg-final { note-test lstiter {"one"}} }
62 std::list<std::string>::const_iterator lstciter = lst.begin();
63 tem = *lstciter;
64 // { dg-final { note-test lstciter {"one"}} }
66 std::map<std::string, int> mp;
67 mp["zardoz"] = 23;
68 // { dg-final { note-test mp {std::__debug::map with 1 elements = {["zardoz"] = 23}} } }
70 std::map<std::string, int>::iterator mpiter = mp.begin();
71 // { dg-final { note-test mpiter {{first = "zardoz", second = 23}} } }
73 std::set<std::string> sp;
74 sp.insert("clownfish");
75 sp.insert("barrel");
76 // { dg-final { note-test sp {std::__debug::set with 2 elements = {[0] = "barrel", [1] = "clownfish"}} } }
78 std::set<std::string>::const_iterator spciter = sp.begin();
79 // { dg-final { note-test spciter {"barrel"} } }
81 __gnu_cxx::slist<int> sll;
82 sll.push_front(23);
83 sll.push_front(47);
84 // { dg-final { note-test sll {__gnu_cxx::slist = {[0] = 47, [1] = 23}} } }
86 __gnu_cxx::slist<int>::iterator slliter = sll.begin();
87 // { dg-final { note-test slliter {47} } }
89 return 0; // Mark SPOT
92 // { dg-final { gdb-test SPOT } }