// If you modify this, please update simple.cc and debug.cc as well. // { dg-do run { target c++11 } } // { dg-options "-g -O0" } // Copyright (C) 2011-2024 Free Software Foundation, Inc. // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the // terms of the GNU General Public License as published by the // Free Software Foundation; either version 3, or (at your option) // any later version. // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License along // with this library; see the file COPYING3. If not see // . #include #include #include #include #include #include #include #include #include #include int main() { std::string tem; std::string str = "zardoz"; // { dg-final { note-test str "\"zardoz\"" } } std::bitset<10> bs; bs[0] = 1; bs[5] = 1; bs[7] = 1; // { dg-final { regexp-test bs {std::(__debug::)?bitset = {\[0\] = 1, \[5\] = 1, \[7\] = 1}} } } std::deque deq; deq.push_back("one"); deq.push_back("two"); // { dg-final { regexp-test deq {std::(__debug::)?deque with 2 elements = {"one", "two"}} } } std::deque::iterator deqiter = deq.begin(); // { dg-final { note-test deqiter {"one"} } } std::deque::iterator deqiter0; // { dg-final { note-test deqiter0 {non-dereferenceable iterator for std::deque} } } std::list lst; lst.push_back("one"); lst.push_back("two"); // { dg-final { regexp-test lst {std::(__cxx11::)?(__debug::)?list = {\[0\] = "one", \[1\] = "two"}} } } std::list::iterator lstiter = lst.begin(); tem = *lstiter; // { dg-final { note-test lstiter {"one"}} } std::list::const_iterator lstciter = lst.begin(); tem = *lstciter; // { dg-final { note-test lstciter {"one"}} } std::list::iterator lstiter0; // { dg-final { note-test lstiter0 {non-dereferenceable iterator for std::list} } } std::map mp; mp["zardoz"] = 23; // { dg-final { regexp-test mp {std::(__debug::)?map with 1 element = {\["zardoz"\] = 23}} } } std::map::iterator mpiter = mp.begin(); // { dg-final { note-test mpiter {{first = "zardoz", second = 23}} } } std::map::iterator mpiter0; // { dg-final { note-test mpiter0 {non-dereferenceable iterator for associative container} } } // PR 67440 const std::set const_intset = {2, 3}; // { dg-final { regexp-test const_intset {std::(__debug::)?set with 2 elements = {\[0\] = 2, \[1\] = 3}} } } std::set sp; sp.insert("clownfish"); sp.insert("barrel"); // { dg-final { regexp-test sp {std::(__debug::)?set with 2 elements = {\[0\] = "barrel", \[1\] = "clownfish"}} } } std::set::const_iterator spciter = sp.begin(); // { dg-final { note-test spciter {"barrel"} } } std::set::iterator spiter0; // { dg-final { note-test spiter0 {non-dereferenceable iterator for associative container} } } std::vector v; v.push_back(1); v.push_back(2); v.erase(v.begin()); // { dg-final { regexp-test v {std::(__debug::)?vector of length 1, capacity 2 = \\{2\\}} } } std::vector::iterator viter3 = v.begin(); // { dg-final { note-test viter3 {2} } } std::vector::iterator viter0; // { dg-final { note-test viter0 {non-dereferenceable iterator for std::vector} } } std::vector vb; vb.reserve(100); vb.push_back(true); vb.push_back(true); vb.push_back(true); vb.push_back(false); vb.push_back(false); vb.push_back(true); vb.erase(vb.begin()); // { dg-final { regexp-test vb {std::(__debug::)?vector of length 5, capacity 128 = \\{true, true, false, false, true\\}} } } std::vector::iterator vbIt = vb.begin(); // { dg-final { note-test vbIt {true} } } std::vector::iterator vbIt2 = ++vbIt; // { dg-final { note-test vbIt2 {true} } } std::vector::iterator vbIt3 = ++vbIt; // { dg-final { note-test vbIt3 {false} } } std::vector::iterator vbIt4 = ++vbIt; // { dg-final { note-test vbIt4 {false} } } std::vector::iterator vbIt5 = ++vbIt; // { dg-final { note-test vbIt5 {true} } } std::vector::const_iterator vbcIt = vb.cbegin(); // { dg-final { note-test vbcIt {true} } } std::vector::iterator vbIt0; // { dg-final { note-test vbIt0 {non-dereferenceable iterator for std::vector} } } std::vector::reference br = *vb.begin(); // { dg-final { note-test br {true} } } std::vector::reference br2 = *vbIt2; // { dg-final { note-test br2 {true} } } std::vector::reference br3 = *vbIt3; // { dg-final { note-test br3 {false} } } std::vector::reference br4 = *vbIt4; // { dg-final { note-test br4 {false} } } std::vector::reference br5 = *vbIt5; // { dg-final { note-test br5 {true} } } std::vector::reference br0; // { dg-final { note-test br0 {invalid std::vector::reference} } } __gnu_cxx::slist sll; sll.push_front(23); sll.push_front(47); // { dg-final { note-test sll {__gnu_cxx::slist = {[0] = 47, [1] = 23}} } } __gnu_cxx::slist::iterator slliter = sll.begin(); // { dg-final { note-test slliter {47} } } __gnu_cxx::slist::iterator slliter0; // { dg-final { note-test slliter0 {non-dereferenceable iterator for __gnu_cxx::slist} } } std::stringstream sstream; sstream << "abc"; // { dg-final { note-test sstream "\"abc\"" } } std::stringstream ssin("input", std::ios::in); // { dg-final { note-test ssin "\"input\"" } } std::istringstream ssin2("input"); // { dg-final { note-test ssin2 "\"input\"" } } std::ostringstream ssout; ssout << "out"; // { dg-final { note-test ssout "\"out\"" } } std::stringstream redirected("xxx"); static_cast&>(redirected).rdbuf(sstream.rdbuf()); // { dg-final { regexp-test redirected {std::.*stringstream redirected to .*} } } std::cout << "\n"; return 0; // Mark SPOT } // { dg-final { gdb-test SPOT } }