// { dg-options "-g -O0" } // { dg-do run { target c++17 } } // Copyright (C) 2014-2022 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 // . // Type printers only recognize the old std::string for now. #define _GLIBCXX_USE_CXX11_ABI 0 #include #include #include #include #include #include #include #include #include #include using std::any; using std::optional; using std::variant; using std::string_view; using std::map; using std::unordered_set; using std::shared_ptr; using std::weak_ptr; struct X { X(int) { } X(const X&) { } // not trivially-copyable }; int main() { string_view str = "string"; // { dg-final { note-test str "\"string\"" } } optional o; // { dg-final { note-test o {std::optional [no contained value]} } } optional ob{false}; // { dg-final { note-test ob {std::optional = {[contained value] = false}} } } optional oi{5}; // { dg-final { note-test oi {std::optional = {[contained value] = 5}} } } optional op{nullptr}; // { dg-final { note-test op {std::optional = {[contained value] = 0x0}} } } optional> om; om = std::map{ {1, 2.}, {3, 4.}, {5, 6.} }; // { dg-final { regexp-test om {std::optional> containing std::(__debug::)?map with 3 elements = {\[1\] = 2, \[3\] = 4, \[5\] = 6}} } } optional os{ "stringy" }; // { dg-final { note-test os {std::optional = {[contained value] = "stringy"}} } } any a; // { dg-final { note-test a {std::any [no contained value]} } } any ab(false); // { dg-final { note-test ab {std::any containing bool = {[contained value] = false}} } } any ai(6); // { dg-final { note-test ai {std::any containing int = {[contained value] = 6}} } } any ap = (void*)nullptr; // { dg-final { note-test ap {std::any containing void * = {[contained value] = 0x0}} } } any as = *os; // { dg-final { note-test as {std::any containing std::string = {[contained value] = "stringy"}} } } any as2("stringiest"); // { dg-final { regexp-test as2 {std::any containing const char \* = {\[contained value\] = 0x[[:xdigit:]]+ "stringiest"}} } } any am = *om; // { dg-final { regexp-test am {std::any containing std::(__debug::)?map with 3 elements = {\[1\] = 2, \[3\] = 4, \[5\] = 6}} } } struct local_type { int i = 99; }; any al = local_type{}; // { dg-final { note-test al {std::any containing local_type = {[contained value] = {i = 99}}} } } struct S { operator int() { throw 42; }}; variant v0; // { dg-final { note-test v0 {std::variant [index 0] = {0}} } } variant v1{ 0.5f }; // { dg-final { note-test v1 {std::variant [index 0] = {0.5}} } } variant v2; try { v2.emplace<1>(S()); } catch (int) { } // { dg-final { note-test v2 {std::variant [no contained value]} } } variant v3{ 3 }; // { dg-final { note-test v3 {std::variant [index 1] = {3}} } } variant v4{ str }; // { dg-final { note-test v4 {std::variant [index 2] = {"string"}} } } map m{ {1, "one"} }; map::node_type n0; // { dg-final { note-test n0 {empty node handle for map}}} map::node_type n1 = m.extract(1); // { dg-final { note-test n1 {node handle for map with element = {{first = 1, second = "two"}}}}} unordered_set s{ 3, 4 }; unordered_set::node_type n2; // { dg-final { note-test n2 {empty node handle for unordered set}}} unordered_set::node_type n3 = s.extract(3); // { dg-final { note-test n1 {node handle for unordered set with element = {3}}}} shared_ptr p(new int[1]); weak_ptr wp = p; weak_ptr wp2 = p; // { dg-final { regexp-test p {std::shared_ptr.int \[\]. \(use count 1, weak count 2\) = {get\(\) = 0x.*}} } } // { dg-final { regexp-test wp {std::weak_ptr.int \[\]. \(use count 1, weak count 2\) = {get\(\) = 0x.*}} } } shared_ptr q(new int[2]); shared_ptr q2 = q; weak_ptr wq = q; // { dg-final { regexp-test q {std::shared_ptr.int \[2\]. \(use count 2, weak count 1\) = {get\(\) = 0x.*}} } } // { dg-final { regexp-test wq {std::weak_ptr.int \[2\]. \(use count 2, weak count 1\) = {get\(\) = 0x.*}} } } std::filesystem::path path0; // { dg-final { note-test path0 {filesystem::path ""} } } std::filesystem::path path1("filename"); // { dg-final { note-test path1 {filesystem::path "filename"} } } std::filesystem::path path2("/dir/."); // { dg-final { note-test path2 {filesystem::path "/dir/." = {[root-directory] = "/", [1] = "dir", [2] = "."}} } } std::cout << "\n"; return 0; // Mark SPOT } // { dg-final { gdb-test SPOT } }