summaryrefslogtreecommitdiffstats
path: root/libstdc++-v3/python/libstdcxx
diff options
context:
space:
mode:
authorfdumont <fdumont@138bc75d-0d04-0410-961f-82ee72b054a4>2013-05-15 19:39:18 +0000
committerfdumont <fdumont@138bc75d-0d04-0410-961f-82ee72b054a4>2013-05-15 19:39:18 +0000
commit611894d11cc044ebccf44b2ad2a8a63e07ecbb84 (patch)
treed30dd906ec6223b52dc6ddcfc8daec3d80189322 /libstdc++-v3/python/libstdcxx
parentc0de02330f20127f25e6099a8689c99408d3fc1e (diff)
downloadppe42-gcc-611894d11cc044ebccf44b2ad2a8a63e07ecbb84.tar.gz
ppe42-gcc-611894d11cc044ebccf44b2ad2a8a63e07ecbb84.zip
2013-05-15 François Dumont <fdumont@gcc.gnu.org>
* python/libstdcxx/v6/printers.py (Tr1HashtableIterator): Fix rendering of std::tr1 unordered containers iterator. (StdHashtableIterator): New, render std unordered containers iterator. * testsuite/libstdc++-prettyprinters/tr1.cc: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@198947 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3/python/libstdcxx')
-rw-r--r--libstdc++-v3/python/libstdcxx/v6/printers.py49
1 files changed, 44 insertions, 5 deletions
diff --git a/libstdc++-v3/python/libstdcxx/v6/printers.py b/libstdc++-v3/python/libstdcxx/v6/printers.py
index e6f20074979..a3a8b1e2fd7 100644
--- a/libstdc++-v3/python/libstdcxx/v6/printers.py
+++ b/libstdc++-v3/python/libstdcxx/v6/printers.py
@@ -621,8 +621,16 @@ class StdStringPrinter:
class Tr1HashtableIterator:
def __init__ (self, hash):
- self.node = hash['_M_bbegin']['_M_node']['_M_nxt']
- self.node_type = find_type(hash.type, '__node_type').pointer()
+ self.buckets = hash['_M_buckets']
+ self.bucket = 0
+ self.bucket_count = hash['_M_bucket_count']
+ self.node_type = find_type(hash.type, '_Node').pointer()
+ self.node = 0
+ while self.bucket != self.bucket_count:
+ self.node = self.buckets[self.bucket]
+ if self.node:
+ break
+ self.bucket = self.bucket + 1
def __iter__ (self):
return self
@@ -632,9 +640,33 @@ class Tr1HashtableIterator:
raise StopIteration
node = self.node.cast(self.node_type)
result = node.dereference()['_M_v']
- self.node = node.dereference()['_M_nxt']
+ self.node = node.dereference()['_M_next'];
+ if self.node == 0:
+ self.bucket = self.bucket + 1
+ while self.bucket != self.bucket_count:
+ self.node = self.buckets[self.bucket]
+ if self.node:
+ break
+ self.bucket = self.bucket + 1
return result
+class StdHashtableIterator:
+ def __init__(self, hash):
+ self.node = hash['_M_bbegin']['_M_node']['_M_nxt']
+ self.node_type = find_type(hash.type, '__node_type').pointer()
+
+ def __iter__(self):
+ return self
+
+ def next(self):
+ if self.node == 0:
+ raise StopIteration
+ elt = self.node.cast(self.node_type).dereference()
+ self.node = elt['_M_nxt']
+ valptr = elt['_M_storage'].address
+ valptr = valptr.cast(elt.type.template_argument(0).pointer())
+ return valptr.dereference()
+
class Tr1UnorderedSetPrinter:
"Print a tr1::unordered_set"
@@ -656,7 +688,9 @@ class Tr1UnorderedSetPrinter:
def children (self):
counter = itertools.imap (self.format_count, itertools.count())
- return itertools.izip (counter, Tr1HashtableIterator (self.hashtable()))
+ if self.typename.startswith('std::tr1'):
+ return itertools.izip (counter, Tr1HashtableIterator (self.hashtable()))
+ return itertools.izip (counter, StdHashtableIterator (self.hashtable()))
class Tr1UnorderedMapPrinter:
"Print a tr1::unordered_map"
@@ -690,9 +724,14 @@ class Tr1UnorderedMapPrinter:
def children (self):
counter = itertools.imap (self.format_count, itertools.count())
# Map over the hash table and flatten the result.
- data = self.flatten (itertools.imap (self.format_one, Tr1HashtableIterator (self.hashtable())))
+ if self.typename.startswith('std::tr1'):
+ data = self.flatten (itertools.imap (self.format_one, Tr1HashtableIterator (self.hashtable())))
+ # Zip the two iterators together.
+ return itertools.izip (counter, data)
+ data = self.flatten (itertools.imap (self.format_one, StdHashtableIterator (self.hashtable())))
# Zip the two iterators together.
return itertools.izip (counter, data)
+
def display_hint (self):
return 'map'
OpenPOWER on IntegriCloud