From 14f38667487c308a68ee67d25aee9275ab70aaf0 Mon Sep 17 00:00:00 2001 From: Vadim Zeitlin Date: Sun, 25 Mar 2012 00:31:38 +0000 Subject: [PATCH] Add a gdb pretty printer for wxDateTime. Format it using Python datetime module in the standard ISO notation. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@70992 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- misc/gdb/print.py | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/misc/gdb/print.py b/misc/gdb/print.py index 703c9c6a68..8e19a57a24 100755 --- a/misc/gdb/print.py +++ b/misc/gdb/print.py @@ -14,6 +14,7 @@ # wxFoo class we want to pretty print. Then just add wxFoo to the types array # in wxLookupFunction at the bottom of this file. +import datetime # shamelessly stolen from std::string example class wxStringPrinter: @@ -26,6 +27,18 @@ class wxStringPrinter: def display_hint(self): return 'string' +class wxDateTimePrinter: + def __init__(self, val): + self.val = val + + def to_string(self): + # A value of type wxLongLong can't be used in Python arithmetic + # expressions directly so we need to convert it to long long first and + # then cast to int explicitly to be able to use it as a timestamp. + msec = self.val['m_time'].cast(gdb.lookup_type('long long')) + sec = int(msec / 1000) + return datetime.datetime.fromtimestamp(sec).isoformat(' ') + class wxXYPrinterBase: def __init__(self, val): self.x = val['x'] @@ -53,7 +66,7 @@ class wxRectPrinter(wxXYPrinterBase): def wxLookupFunction(val): # Using a list is probably ok for so few items but consider switching to a # set (or a dict and cache class types as the keys in it?) if needed later. - types = ['wxString', 'wxPoint', 'wxSize', 'wxRect'] + types = ['wxString', 'wxDateTime', 'wxPoint', 'wxSize', 'wxRect'] for t in types: if val.type.tag == t: -- 2.45.2