# -*- tab-width: 4; indent-tabs-mode: nil; py-indent-offset: 4 -*- # Version: MPL 1.1 / GPLv3+ / LGPLv3+ # # The contents of this file are subject to the Mozilla Public License Version # 1.1 (the "License"); you may not use this file except in compliance with # the License or as specified alternatively below. You may obtain a copy of # the License at http://www.mozilla.org/MPL/ # # Software distributed under the License is distributed on an "AS IS" basis, # WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License # for the specific language governing rights and limitations under the # License. # # Major Contributor(s): # Copyright (C) 2010 Red Hat, Inc., David Tardon # (initial developer) # # All Rights Reserved. # # For minor contributions see the git repository. # # Alternatively, the contents of this file may be used under the terms of # either the GNU General Public License Version 3 or later (the "GPLv3+"), or # the GNU Lesser General Public License Version 3 or later (the "LGPLv3+"), # in which case the provisions of the GPLv3+ or the LGPLv3+ are applicable # instead of those above. from libreoffice.util import printing class SwPositionPrinter(object): '''Prints SwPosition.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): node = self.value['nNode']['pNd'].dereference(); offset = self.value['nContent']['m_nIndex'] return "%s (node %d, offset %d)" % (self.typename, node['nOffset'], offset) class SwNodeIndexPrinter(object): '''Prints SwNodeIndex.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): node = self.value['pNd'].dereference(); return "%s (node %d)" % (self.typename, node['nOffset']) class SwIndexPrinter(object): '''Prints SwIndex.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): offset = self.value['m_nIndex'] return "%s (offset %d)" % (self.typename, offset) class SwPaMPrinter(object): '''Prints SwPaM.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): return "%s" % (self.typename) def children(self): next_ = self.value['pNext'] prev = self.value['pPrev'] point = self.value['m_pPoint'].dereference() mark = self.value['m_pMark'].dereference() children = [ ( 'point', point), ( 'mark', mark ) ] if next_ != self.value.address: children.append(("next", next_)) if prev != self.value.address: children.append(("prev", prev)) return children.__iter__() class SwRectPrinter(object): '''Prints SwRect.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): return "%s" % (self.typename) def children(self): point = self.value['m_Point'] size = self.value['m_Size'] children = [ ( 'point', point), ( 'size', size ) ] return children.__iter__() class SwIMarkPrinter(object): '''Prints sw::mark::IMark.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): return "%s" % (self.typename) def children(self): if str(self.value.dynamic_type) == "sw::mark::UnoMark": unoMark = self.value.cast(self.value.dynamic_type) pos1 = unoMark['m_pPos1'] pos2 = unoMark['m_pPos2'] children = [ ( 'pos1', pos1), ( 'pos2', pos2 ) ] return children.__iter__() else: return self._iterator(self.value) class SwXTextRangeImplPrinter(object): '''Prints SwXTextRange::Impl.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): return "%s" % (self.typename) def children(self): mark = self.value['m_pMark'].dereference() children = [('mark', mark)] return children.__iter__() class SwUnoImplPtrPrinter(object): """Prints sw::UnoImplPtr""" def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): if self.value['m_p']: return "%s %s" % (self.typename, self.value['m_p'].dereference()) else: return "empty %s" % (self.typename,) class SwXTextRangePrinter(object): '''Prints SwXTextRange.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): return "%s %s" % (self.typename, self.value['m_pImpl']) class BigPtrArrayPrinter(object): '''Prints BigPtrArray.''' def __init__(self, typename, value): self.typename = typename self.value = value def to_string(self): length = self.value['nSize'] if length > 0: return "%s of length %d" % (self.typename, length) else: return "empty %s" % self.typename def children(self): return self._iterator(self.value) def display_hint(self): return 'array' class _iterator(object): def __init__(self, array): self.blocks = array['ppInf'] self.count = array['nSize'] self.pos = 0 self.block_count = array['nBlock'] self.block_pos = 0 self.block = None self.indent = "" self.max_indent = " " self._next_block(False) self._check_invariant() def __iter__(self): return self def _node_value(self, node): cur_indent = self.indent if str(node.dynamic_type.target()) == "SwTxtNode": # accessing this is completely non-obvious... # also, node.dynamic_cast(node.dynamic_type) is null? value = " TextNode " + \ unicode(node.cast(node.dynamic_type).dereference()['m_Text']) elif str(node.dynamic_type.target()) == "SwOLENode": value = " OLENode " elif str(node.dynamic_type.target()) == "SwGrfNode": value = " GrfNode " elif str(node.dynamic_type.target()) == "SwSectionNode": value = " SectionNode " self.indent += " " elif str(node.dynamic_type.target()) == "SwTableNode": value = " TableNode " self.indent += " " elif str(node.dynamic_type.target()) == "SwStartNode": value = " StartNode " self.indent += " " elif str(node.dynamic_type.target()) == "SwEndNode": value = " EndNode " self.indent = self.indent[:-1] cur_indent = self.indent elif str(node.dynamic_type.target()) == "SwDummySectionNode": value = "DummySctNode " else: # must be currently being deleted, so has some abstract type value = "~DeletedNode " # return "\n[%s%4d%s] %s %s" % (cur_indent, self.pos, \ # self.max_indent[len(cur_indent):], node, value) return "\n[%4d] %s%s%s %s" % (self.pos, cur_indent, \ node, self.max_indent[len(cur_indent):], value) def next(self): if self.pos == self.count: raise StopIteration() name = str(self.pos) node = self.block['pData'][self.pos - self.block['nStart']] value = self._node_value(node) if self.pos == self.block['nEnd']: self._next_block() self.pos += 1 self._check_invariant() return (name, value) def _next_block(self, advance = True): if advance: self.block_pos += 1 if self.block_pos == self.block_count: return pblock = self.blocks[self.block_pos] assert pblock block = pblock.dereference() start = block['nStart'] end = block['nEnd'] assert end - start + 1 == block['nElem'] if self.block: assert start == self.block['nEnd'] + 1 assert end <= self.count else: assert start == 0 self.block = block def _check_invariant(self): assert self.pos <= self.count assert self.block_pos <= self.block_count if self.pos == 0 and self.pos < self.count: assert self.block != None printer = None def build_pretty_printers(): global printer printer = printing.Printer("libreoffice/sw") printer.add('BigPtrArray', BigPtrArrayPrinter) printer.add('SwPosition', SwPositionPrinter) printer.add('SwNodeIndex', SwNodeIndexPrinter) printer.add('SwIndex', SwIndexPrinter) printer.add('SwPaM', SwPaMPrinter) printer.add('SwRect', SwRectPrinter) printer.add('sw::mark::IMark', SwIMarkPrinter) printer.add('SwXTextRange::Impl', SwXTextRangeImplPrinter) printer.add('sw::UnoImplPtr', SwUnoImplPtrPrinter) printer.add('SwXTextRange', SwXTextRangePrinter) def register_pretty_printers(obj): printing.register_pretty_printer(printer, obj) build_pretty_printers() # vim:set shiftwidth=4 softtabstop=4 expandtab: