diff options
author | redi <redi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2016-12-15 13:25:22 +0000 |
---|---|---|
committer | redi <redi@138bc75d-0d04-0410-961f-82ee72b054a4> | 2016-12-15 13:25:22 +0000 |
commit | d989a3e05b13881015835848a0cde28a639c4851 (patch) | |
tree | 89179b409860041c2cc9c9cac49b6ee9a618ed29 /libstdc++-v3 | |
parent | 1dc84a99267eb2536b1414d694db0fb0d26b3dc5 (diff) | |
download | gcc-d989a3e05b13881015835848a0cde28a639c4851.tar.gz |
PR59161 make pretty printers always return strings
PR libstdc++/59161
* python/libstdcxx/v6/printers.py (StdListIteratorPrinter.to_string)
(StdSlistIteratorPrinter.to_string, StdVectorIteratorPrinter.to_string)
(StdRbtreeIteratorPrinter.to_string, StdDequeIteratorPrinter.to_string)
(StdDebugIteratorPrinter.to_string): Return string instead of
gdb.Value.
* testsuite/libstdc++-prettyprinters/59161.cc: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@243690 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3')
-rw-r--r-- | libstdc++-v3/ChangeLog | 8 | ||||
-rw-r--r-- | libstdc++-v3/python/libstdcxx/v6/printers.py | 12 | ||||
-rw-r--r-- | libstdc++-v3/testsuite/libstdc++-prettyprinters/59161.cc | 70 |
3 files changed, 84 insertions, 6 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 14c0c6e0dc7..7b5bd259173 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,5 +1,13 @@ 2016-12-15 Jonathan Wakely <jwakely@redhat.com> + PR libstdc++/59161 + * python/libstdcxx/v6/printers.py (StdListIteratorPrinter.to_string) + (StdSlistIteratorPrinter.to_string, StdVectorIteratorPrinter.to_string) + (StdRbtreeIteratorPrinter.to_string, StdDequeIteratorPrinter.to_string) + (StdDebugIteratorPrinter.to_string): Return string instead of + gdb.Value. + * testsuite/libstdc++-prettyprinters/59161.cc: New test. + * python/libstdcxx/v6/printers.py (UniquePointerPrinter.to_string): Remove redundant parentheses. (RbtreeIterator, StdRbtreeIteratorPrinter): Add docstrings. diff --git a/libstdc++-v3/python/libstdcxx/v6/printers.py b/libstdc++-v3/python/libstdcxx/v6/printers.py index 9d84b4f263b..ab3592a7e67 100644 --- a/libstdc++-v3/python/libstdcxx/v6/printers.py +++ b/libstdc++-v3/python/libstdcxx/v6/printers.py @@ -203,7 +203,7 @@ class StdListIteratorPrinter: nodetype = find_type(self.val.type, '_Node') nodetype = nodetype.strip_typedefs().pointer() node = self.val['_M_node'].cast(nodetype).dereference() - return get_value_from_list_node(node) + return str(get_value_from_list_node(node)) class StdSlistPrinter: "Print a __gnu_cxx::slist" @@ -248,7 +248,7 @@ class StdSlistIteratorPrinter: def to_string(self): nodetype = find_type(self.val.type, '_Node') nodetype = nodetype.strip_typedefs().pointer() - return self.val['_M_node'].cast(nodetype).dereference()['_M_data'] + return str(self.val['_M_node'].cast(nodetype).dereference()['_M_data']) class StdVectorPrinter: "Print a std::vector" @@ -333,7 +333,7 @@ class StdVectorIteratorPrinter: self.val = val def to_string(self): - return self.val['_M_current'].dereference() + return str(self.val['_M_current'].dereference()) class StdTuplePrinter: "Print a std::tuple" @@ -495,7 +495,7 @@ class StdRbtreeIteratorPrinter: def to_string (self): node = self.val['_M_node'].cast(self.link_type).dereference() - return get_value_from_Rb_tree_node(node) + return str(get_value_from_Rb_tree_node(node)) class StdDebugIteratorPrinter: "Print a debug enabled version of an iterator" @@ -511,7 +511,7 @@ class StdDebugIteratorPrinter: if not safe_seq or self.val['_M_version'] != safe_seq['_M_version']: return "invalid iterator" itype = self.val.type.template_argument(0) - return self.val.cast(itype) + return str(self.val.cast(itype)) def num_elements(num): """Return either "1 element" or "N elements" depending on the argument.""" @@ -708,7 +708,7 @@ class StdDequeIteratorPrinter: self.val = val def to_string(self): - return self.val['_M_cur'].dereference() + return str(self.val['_M_cur'].dereference()) class StdStringPrinter: "Print a std::basic_string of some kind" diff --git a/libstdc++-v3/testsuite/libstdc++-prettyprinters/59161.cc b/libstdc++-v3/testsuite/libstdc++-prettyprinters/59161.cc new file mode 100644 index 00000000000..d8fef27bbb5 --- /dev/null +++ b/libstdc++-v3/testsuite/libstdc++-prettyprinters/59161.cc @@ -0,0 +1,70 @@ +// { dg-do run } +// { dg-options "-g -O0" } + +// Copyright (C) 2011-2016 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 +// <http://www.gnu.org/licenses/>. + +#include <deque> +#include <list> +#include <ext/slist> +#include <set> +#include <vector> +#include <debug/vector> +#include <iostream> + +struct C { + C(int& i) : ref(i) { } + int& ref; + bool operator<(const C& c) const { return ref < c.ref; } +}; + +int main() +{ + int i = 1; + C c(i); + + std::deque<C> d; + d.push_back(c); + std::deque<C>::iterator diter = d.begin(); +// { dg-final { regexp-test diter {ref = @0x.*} } } + + std::list<C> l; + l.push_back(c); + std::list<C>::iterator liter = l.begin(); + // Need to ensure the list<C>::iterator::_Node typedef is in the debuginfo: + int tmp __attribute__((unused)) = (*liter).ref; +// { dg-final { regexp-test liter {ref = @0x.*} } } + + __gnu_cxx::slist<C> sl; + sl.push_front(c); + __gnu_cxx::slist<C>::iterator sliter = sl.begin(); +// { dg-final { regexp-test sliter {ref = @0x.*} } } + + std::set<C> s; + s.insert(c); + std::set<C>::iterator siter = s.begin(); +// { dg-final { regexp-test siter {ref = @0x.*} } } + + std::vector<C> v; + v.push_back(c); + std::vector<C>::iterator viter = v.begin(); +// { dg-final { regexp-test viter {ref = @0x.*} } } + + std::cout << "\n"; + return 0; // Mark SPOT +} +// { dg-final { gdb-test SPOT } } |