]>
Commit | Line | Data |
---|---|---|
1 | ############################################################################### | |
2 | # Name: misc/gdb/print.py | |
3 | # Purpose: pretty-printers for wx data structures: this file is meant to | |
4 | # be sourced from gdb using "source -p" (or, better, autoloaded | |
5 | # in the future...) | |
6 | # Author: Vadim Zeitlin | |
7 | # Created: 2009-01-04 | |
8 | # RCS-Id: $Id$ | |
9 | # Copyright: (c) 2009 Vadim Zeitlin | |
10 | # Licence: wxWindows licence | |
11 | ############################################################################### | |
12 | ||
13 | # Define wxFooPrinter class implementing (at least) to_string() method for each | |
14 | # wxFoo class we want to pretty print. Then just add wxFoo to the types array | |
15 | # in wxLookupFunction at the bottom of this file. | |
16 | ||
17 | import datetime | |
18 | ||
19 | # shamelessly stolen from std::string example | |
20 | class wxStringPrinter: | |
21 | def __init__(self, val): | |
22 | self.val = val | |
23 | ||
24 | def to_string(self): | |
25 | return self.val['m_impl']['_M_dataplus']['_M_p'] | |
26 | ||
27 | def display_hint(self): | |
28 | return 'string' | |
29 | ||
30 | class wxDateTimePrinter: | |
31 | def __init__(self, val): | |
32 | self.val = val | |
33 | ||
34 | def to_string(self): | |
35 | # A value of type wxLongLong can't be used in Python arithmetic | |
36 | # expressions directly so we need to convert it to long long first and | |
37 | # then cast to int explicitly to be able to use it as a timestamp. | |
38 | msec = self.val['m_time'].cast(gdb.lookup_type('long long')) | |
39 | if msec == 0x8000000000000000: | |
40 | return 'NONE' | |
41 | sec = int(msec / 1000) | |
42 | return datetime.datetime.fromtimestamp(sec).isoformat(' ') | |
43 | ||
44 | class wxFileNamePrinter: | |
45 | def __init__(self, val): | |
46 | self.val = val | |
47 | ||
48 | def to_string(self): | |
49 | # It is simpler to just call the internal function here than to iterate | |
50 | # over m_dirs array ourselves. The disadvantage of this approach is | |
51 | # that it requires a live inferior process and so doesn't work when | |
52 | # debugging using only a core file. If this ever becomes a serious | |
53 | # problem, this should be rewritten to use m_dirs and m_name and m_ext. | |
54 | return gdb.parse_and_eval('((wxFileName*)%s)->GetFullPath(0)' % | |
55 | self.val.address) | |
56 | ||
57 | class wxXYPrinterBase: | |
58 | def __init__(self, val): | |
59 | self.x = val['x'] | |
60 | self.y = val['y'] | |
61 | ||
62 | class wxPointPrinter(wxXYPrinterBase): | |
63 | def to_string(self): | |
64 | return '(%d, %d)' % (self.x, self.y) | |
65 | ||
66 | class wxSizePrinter(wxXYPrinterBase): | |
67 | def to_string(self): | |
68 | return '%d*%d' % (self.x, self.y) | |
69 | ||
70 | class wxRectPrinter(wxXYPrinterBase): | |
71 | def __init__(self, val): | |
72 | wxXYPrinterBase.__init__(self, val) | |
73 | self.width = val['width'] | |
74 | self.height = val['height'] | |
75 | ||
76 | def to_string(self): | |
77 | return '(%d, %d) %d*%d' % (self.x, self.y, self.width, self.height) | |
78 | ||
79 | ||
80 | # The function looking up the pretty-printer to use for the given value. | |
81 | def wxLookupFunction(val): | |
82 | # Using a list is probably ok for so few items but consider switching to a | |
83 | # set (or a dict and cache class types as the keys in it?) if needed later. | |
84 | types = ['wxString', | |
85 | 'wxDateTime', | |
86 | 'wxFileName', | |
87 | 'wxPoint', | |
88 | 'wxSize', | |
89 | 'wxRect'] | |
90 | ||
91 | for t in types: | |
92 | if val.type.tag == t: | |
93 | # Not sure if this is the best name to create the object of a class | |
94 | # by name but at least it beats eval() | |
95 | return globals()[t + 'Printer'](val) | |
96 | ||
97 | return None | |
98 | ||
99 | gdb.pretty_printers.append(wxLookupFunction) |