summaryrefslogtreecommitdiff
path: root/solenv
diff options
context:
space:
mode:
authorMichael Stahl <mstahl@redhat.com>2015-04-08 17:26:49 +0200
committerDavid Tardon <dtardon@redhat.com>2015-04-09 07:33:23 +0000
commitefe23e6f2707ceef5d99d5e8cef503ca7bc1e01c (patch)
treea9a6a16bc63a5aee2577cf2e378bbb411230fbdd /solenv
parent3629a6a3706febac5a444e77003f4959126fe6f5 (diff)
solenv: add GDB pretty printer for SfxItemSet
(cherry picked from commit b34199bc156527b6aa16858587b8e3cadb647b8c) Change-Id: Ibd74c58efa7f1a24de409820655fb98b4fc13df3 Reviewed-on: https://gerrit.libreoffice.org/15208 Tested-by: David Tardon <dtardon@redhat.com> Reviewed-by: David Tardon <dtardon@redhat.com>
Diffstat (limited to 'solenv')
-rw-r--r--solenv/gdb/libreoffice/svl.py66
1 files changed, 66 insertions, 0 deletions
diff --git a/solenv/gdb/libreoffice/svl.py b/solenv/gdb/libreoffice/svl.py
index 31b4507777a9..583c08fed677 100644
--- a/solenv/gdb/libreoffice/svl.py
+++ b/solenv/gdb/libreoffice/svl.py
@@ -12,6 +12,71 @@ import six
from libreoffice.util import printing
+class ItemSetPrinter(object):
+ '''Prints SfxItemSets'''
+
+ def __init__(self, typename, value):
+ self.typename = typename
+ self.value = value
+
+ def to_string(self):
+ whichranges = self.which_ranges()
+ return "SfxItemSet of pool %s with parent %s and Which ranges: %s" \
+ % (self.value['_pPool'], self.value['_pParent'], whichranges)
+
+ def which_ranges(self):
+ whichranges = self.value['_pWhichRanges']
+ index = 0
+ whiches = []
+ while (whichranges[index]):
+ whiches.append((int(whichranges[index]), int(whichranges[index+1])))
+ index = index + 2
+ return whiches
+
+ def children(self):
+ whichranges = self.which_ranges()
+ size = 0
+ whichids = []
+ for (whichfrom, whichto) in whichranges:
+ size += whichto - whichfrom + 1
+ whichids += [which for which in range(whichfrom, whichto+1)]
+ return self._iterator(self.value['_aItems'], size, whichids)
+
+ class _iterator(six.Iterator):
+
+ def __init__(self, data, count, whichids):
+ self.data = data
+ self.whichids = whichids
+ self.count = count
+ self.pos = 0
+ self._check_invariant()
+
+ def __iter__(self):
+ return self
+
+ def __next__(self):
+ if self.pos == self.count:
+ raise StopIteration()
+
+ which = self.whichids[self.pos]
+ elem = self.data[self.pos]
+ self.pos = self.pos + 1
+
+ self._check_invariant()
+ if (elem == -1):
+ elem = "(Invalid)"
+ elif (elem != 0):
+ # let's try how well that works...
+ elem = elem.cast(elem.dynamic_type).dereference()
+ return (str(which), elem)
+
+ def _check_invariant(self):
+ assert self.count >= 0
+ assert self.data
+ assert self.pos >= 0
+ assert self.pos <= self.count
+ assert len(self.whichids) == self.count
+
class SvArrayPrinter(object):
'''Prints macro-declared arrays from svl module'''
@@ -97,6 +162,7 @@ def build_pretty_printers():
printer = printing.Printer("libreoffice/svl")
+ printer.add('SfxItemSet', ItemSetPrinter)
# macro-based arrays from svl module
printer.add('SvArray', SvArrayPrinter, SvArrayPrinter.query)