| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | import sys | 
					
						
							| 
									
										
										
										
											2009-12-04 13:22:39 +01:00
										 |  |  | import base64 | 
					
						
							| 
									
										
										
										
											2010-03-05 15:24:39 +01:00
										 |  |  | import __builtin__ | 
					
						
							| 
									
										
										
										
											2010-03-30 16:44:18 +02:00
										 |  |  | import os | 
					
						
							| 
									
										
										
										
											2011-05-31 15:34:50 +02:00
										 |  |  | import tempfile | 
					
						
							| 
									
										
										
										
											2010-06-10 14:28:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-16 15:51:46 +01:00
										 |  |  | # Fails on Windows. | 
					
						
							|  |  |  | try: | 
					
						
							|  |  |  |     import curses.ascii | 
					
						
							|  |  |  |     def printableChar(ucs): | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |         if curses.ascii.isprint(ucs): | 
					
						
							|  |  |  |             return ucs | 
					
						
							|  |  |  |         return '?' | 
					
						
							| 
									
										
										
										
											2010-03-16 15:51:46 +01:00
										 |  |  | except: | 
					
						
							| 
									
										
										
										
											2010-03-08 13:14:23 +01:00
										 |  |  |     def printableChar(ucs): | 
					
						
							|  |  |  |         if ucs >= 32 and ucs <= 126: | 
					
						
							|  |  |  |             return ucs | 
					
						
							|  |  |  |         return '?' | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-16 15:51:46 +01:00
										 |  |  | # Fails on SimulatorQt. | 
					
						
							| 
									
										
										
										
											2010-03-30 16:44:18 +02:00
										 |  |  | tempFileCounter = 0 | 
					
						
							| 
									
										
										
										
											2010-03-16 15:51:46 +01:00
										 |  |  | try: | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  |     # Test if 2.6 is used (Windows), trigger exception and default | 
					
						
							|  |  |  |     # to 2nd version. | 
					
						
							|  |  |  |     tempfile.NamedTemporaryFile(prefix="py_",delete=True) | 
					
						
							| 
									
										
										
										
											2010-03-16 15:51:46 +01:00
										 |  |  |     def createTempFile(): | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  |         file = tempfile.NamedTemporaryFile(prefix="py_",delete=False) | 
					
						
							| 
									
										
										
										
											2010-03-24 14:48:45 +01:00
										 |  |  |         file.close() | 
					
						
							| 
									
										
										
										
											2010-03-30 16:44:18 +02:00
										 |  |  |         return file.name, file | 
					
						
							| 
									
										
										
										
											2010-03-24 14:48:45 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-16 15:51:46 +01:00
										 |  |  | except: | 
					
						
							|  |  |  |     def createTempFile(): | 
					
						
							| 
									
										
										
										
											2010-03-30 16:44:18 +02:00
										 |  |  |         global tempFileCounter | 
					
						
							|  |  |  |         tempFileCounter += 1 | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  |         fileName = "%s/py_tmp_%d_%d" \ | 
					
						
							| 
									
										
										
										
											2011-05-31 15:34:50 +02:00
										 |  |  |             % (tempfile.gettempdir(), os.getpid(), tempFileCounter) | 
					
						
							| 
									
										
										
										
											2010-03-30 16:44:18 +02:00
										 |  |  |         return fileName, None | 
					
						
							| 
									
										
										
										
											2010-03-16 15:51:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-30 16:44:18 +02:00
										 |  |  | def removeTempFile(name, file): | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         os.remove(name) | 
					
						
							|  |  |  |     except: | 
					
						
							| 
									
										
										
										
											2010-03-24 14:48:45 +01:00
										 |  |  |         pass | 
					
						
							| 
									
										
										
										
											2009-12-09 09:53:43 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-13 13:51:44 +02:00
										 |  |  | try: | 
					
						
							|  |  |  |     import binascii | 
					
						
							|  |  |  | except: | 
					
						
							|  |  |  |     pass | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | verbosity = 0 | 
					
						
							|  |  |  | verbosity = 1 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-15 18:15:03 +01:00
										 |  |  | # Some "Enums" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Encodings | 
					
						
							|  |  |  | Unencoded8Bit, \ | 
					
						
							| 
									
										
										
										
											2010-04-08 14:38:42 +02:00
										 |  |  | Base64Encoded8BitWithQuotes, \ | 
					
						
							|  |  |  | Base64Encoded16BitWithQuotes, \ | 
					
						
							|  |  |  | Base64Encoded32BitWithQuotes, \ | 
					
						
							|  |  |  | Base64Encoded16Bit, \ | 
					
						
							|  |  |  | Base64Encoded8Bit, \ | 
					
						
							|  |  |  | Hex2EncodedLatin1, \ | 
					
						
							|  |  |  | Hex4EncodedLittleEndian, \ | 
					
						
							|  |  |  | Hex8EncodedLittleEndian, \ | 
					
						
							|  |  |  | Hex2EncodedUtf8, \ | 
					
						
							|  |  |  | Hex8EncodedBigEndian, \ | 
					
						
							| 
									
										
										
										
											2010-09-13 12:37:30 +02:00
										 |  |  | Hex4EncodedBigEndian, \ | 
					
						
							| 
									
										
										
										
											2011-07-04 18:31:31 +02:00
										 |  |  | Hex4EncodedLittleEndianWithoutQuotes, \ | 
					
						
							| 
									
										
										
										
											2011-08-19 15:47:34 +02:00
										 |  |  | Hex2EncodedLocal8Bit, \ | 
					
						
							|  |  |  | JulianDate, \ | 
					
						
							|  |  |  | MillisecondsSinceMidnight, \ | 
					
						
							|  |  |  | JulianDateAndMillisecondsSinceMidnight \ | 
					
						
							|  |  |  |     = range(17) | 
					
						
							| 
									
										
										
										
											2010-03-15 18:15:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | # Display modes | 
					
						
							| 
									
										
										
										
											2010-04-08 14:38:42 +02:00
										 |  |  | StopDisplay, \ | 
					
						
							|  |  |  | DisplayImage1, \ | 
					
						
							|  |  |  | DisplayString, \ | 
					
						
							|  |  |  | DisplayImage, \ | 
					
						
							|  |  |  | DisplayProcess \ | 
					
						
							|  |  |  |     = range(5) | 
					
						
							| 
									
										
										
										
											2010-03-15 18:15:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-14 12:57:24 +02:00
										 |  |  | def hasInferiorThreadList(): | 
					
						
							| 
									
										
										
										
											2011-09-01 15:07:19 +02:00
										 |  |  |     #return False | 
					
						
							| 
									
										
										
										
											2010-09-14 12:57:24 +02:00
										 |  |  |     try: | 
					
						
							| 
									
										
										
										
											2011-05-16 15:46:35 +02:00
										 |  |  |         a = gdb.inferiors()[0].threads() | 
					
						
							| 
									
										
										
										
											2010-09-14 12:57:24 +02:00
										 |  |  |         return True | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         return False | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-20 15:23:28 +02:00
										 |  |  | def upcast(value): | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         type = value.dynamic_type | 
					
						
							|  |  |  |         return value.cast(type) | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         return value | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-10 15:11:12 +02:00
										 |  |  | typeCache = {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-12 15:56:03 +02:00
										 |  |  | class TypeInfo: | 
					
						
							|  |  |  |     def __init__(self, type): | 
					
						
							|  |  |  |         self.size = type.sizeof | 
					
						
							|  |  |  |         self.reported = False | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typeInfoCache = {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-10 15:11:12 +02:00
										 |  |  | def lookupType(typestring): | 
					
						
							|  |  |  |     type = typeCache.get(typestring) | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  |     #warn("LOOKUP 1: %s -> %s" % (typestring, type)) | 
					
						
							| 
									
										
										
										
											2011-07-11 14:31:02 +02:00
										 |  |  |     if not type is None: | 
					
						
							|  |  |  |         return type | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ts = typestring | 
					
						
							|  |  |  |     while True: | 
					
						
							|  |  |  |         #WARN("ts: '%s'" % ts) | 
					
						
							|  |  |  |         if ts.startswith("class "): | 
					
						
							|  |  |  |             ts = ts[6:] | 
					
						
							|  |  |  |         elif ts.startswith("struct "): | 
					
						
							|  |  |  |             ts = ts[7:] | 
					
						
							|  |  |  |         elif ts.startswith("const "): | 
					
						
							|  |  |  |             ts = ts[6:] | 
					
						
							|  |  |  |         elif ts.startswith("volatile "): | 
					
						
							|  |  |  |             ts = ts[9:] | 
					
						
							|  |  |  |         elif ts.startswith("enum "): | 
					
						
							|  |  |  |             ts = ts[5:] | 
					
						
							|  |  |  |         elif ts.endswith(" const"): | 
					
						
							|  |  |  |             ts = ts[:-6] | 
					
						
							|  |  |  |         elif ts.endswith(" volatile"): | 
					
						
							|  |  |  |             ts = ts[:-9] | 
					
						
							|  |  |  |         elif ts.endswith("*const"): | 
					
						
							|  |  |  |             ts = ts[:-5] | 
					
						
							|  |  |  |         elif ts.endswith("*volatile"): | 
					
						
							|  |  |  |             ts = ts[:-8] | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             break | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ts.endswith('*'): | 
					
						
							|  |  |  |         type = lookupType(ts[0:-1]) | 
					
						
							| 
									
										
										
										
											2010-11-30 16:50:42 +01:00
										 |  |  |         if not type is None: | 
					
						
							|  |  |  |             type = type.pointer() | 
					
						
							|  |  |  |             typeCache[typestring] = type | 
					
						
							| 
									
										
										
										
											2011-07-11 14:31:02 +02:00
										 |  |  |             return type | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         #warn("LOOKING UP '%s'" % ts) | 
					
						
							|  |  |  |         type = gdb.lookup_type(ts) | 
					
						
							|  |  |  |     except RuntimeError, error: | 
					
						
							|  |  |  |         #warn("LOOKING UP '%s': %s" % (ts, error)) | 
					
						
							|  |  |  |         # See http://sourceware.org/bugzilla/show_bug.cgi?id=11912 | 
					
						
							|  |  |  |         exp = "(class '%s'*)0" % ts | 
					
						
							|  |  |  |         try: | 
					
						
							|  |  |  |             type = parseAndEvaluate(exp).type.target() | 
					
						
							|  |  |  |         except: | 
					
						
							|  |  |  |             # Can throw "RuntimeError: No type named class Foo." | 
					
						
							|  |  |  |             pass | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         #warn("LOOKING UP '%s' FAILED" % ts) | 
					
						
							| 
									
										
										
										
											2010-07-12 17:13:58 +02:00
										 |  |  |         pass | 
					
						
							| 
									
										
										
										
											2011-07-11 14:31:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # This could still be None as gdb.lookup_type("char[3]") generates | 
					
						
							|  |  |  |     # "RuntimeError: No type named char[3]" | 
					
						
							| 
									
										
										
										
											2010-06-10 15:11:12 +02:00
										 |  |  |     return type | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-06 17:01:16 +01:00
										 |  |  | def cleanAddress(addr): | 
					
						
							| 
									
										
										
										
											2010-02-16 14:38:58 +01:00
										 |  |  |     if addr is None: | 
					
						
							|  |  |  |         return "<no address>" | 
					
						
							| 
									
										
										
										
											2010-01-14 15:25:53 +01:00
										 |  |  |     # We cannot use str(addr) as it yields rubbish for char pointers | 
					
						
							|  |  |  |     # that might trigger Unicode encoding errors. | 
					
						
							| 
									
										
										
										
											2011-05-09 13:30:00 +02:00
										 |  |  |     #return addr.cast(lookupType("void").pointer()) | 
					
						
							| 
									
										
										
										
											2011-07-07 14:37:09 +02:00
										 |  |  |     # We do not use "hex(...)" as it (sometimes?) adds a "L" suffix. | 
					
						
							|  |  |  |     return "0x%x" % long(addr) | 
					
						
							| 
									
										
										
										
											2010-01-06 17:01:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-01 10:11:30 +01:00
										 |  |  | def extractTemplateArgument(type, position): | 
					
						
							|  |  |  |     level = 0 | 
					
						
							|  |  |  |     skipSpace = False | 
					
						
							|  |  |  |     inner = "" | 
					
						
							|  |  |  |     type = str(type) | 
					
						
							|  |  |  |     for c in type[type.find('<') + 1 : -1]: | 
					
						
							|  |  |  |         if c == '<': | 
					
						
							|  |  |  |             inner += c | 
					
						
							|  |  |  |             level += 1 | 
					
						
							|  |  |  |         elif c == '>': | 
					
						
							|  |  |  |             level -= 1 | 
					
						
							|  |  |  |             inner += c | 
					
						
							|  |  |  |         elif c == ',': | 
					
						
							|  |  |  |             if level == 0: | 
					
						
							|  |  |  |                 if position == 0: | 
					
						
							|  |  |  |                     return inner | 
					
						
							|  |  |  |                 position -= 1 | 
					
						
							|  |  |  |                 inner = "" | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 inner += c | 
					
						
							|  |  |  |                 skipSpace = True | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             if skipSpace and c == ' ': | 
					
						
							|  |  |  |                 pass | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 inner += c | 
					
						
							|  |  |  |                 skipSpace = False | 
					
						
							|  |  |  |     return inner | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def templateArgument(type, position): | 
					
						
							| 
									
										
										
										
											2010-11-30 17:14:44 +01:00
										 |  |  |     try: | 
					
						
							|  |  |  |         # This fails on stock 7.2 with | 
					
						
							|  |  |  |         # "RuntimeError: No type named myns::QObject.\n" | 
					
						
							|  |  |  |         return type.template_argument(position) | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         # That's something like "myns::QList<...>" | 
					
						
							| 
									
										
										
										
											2010-12-01 10:11:30 +01:00
										 |  |  |         return lookupType(extractTemplateArgument(type.strip_typedefs(), position)) | 
					
						
							| 
									
										
										
										
											2010-11-30 17:14:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:46:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-15 13:26:46 +01:00
										 |  |  | # Workaround for gdb < 7.1 | 
					
						
							|  |  |  | def numericTemplateArgument(type, position): | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         return int(type.template_argument(position)) | 
					
						
							| 
									
										
										
										
											2010-02-03 16:50:28 +01:00
										 |  |  |     except RuntimeError, error: | 
					
						
							| 
									
										
										
										
											2010-01-15 13:26:46 +01:00
										 |  |  |         # ": No type named 30." | 
					
						
							|  |  |  |         msg = str(error) | 
					
						
							|  |  |  |         return int(msg[14:-1]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:46:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  | def showException(msg, exType, exValue, exTraceback): | 
					
						
							|  |  |  |     warn("**** CAUGHT EXCEPTION: %s ****" % msg) | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         import traceback | 
					
						
							|  |  |  |         for line in traceback.format_exception(exType, exValue, exTraceback): | 
					
						
							|  |  |  |             warn("%s" % line) | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class OutputSafer: | 
					
						
							|  |  |  |     def __init__(self, d, pre = "", post = ""): | 
					
						
							|  |  |  |         self.d = d | 
					
						
							|  |  |  |         self.pre = pre | 
					
						
							|  |  |  |         self.post = post | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def __enter__(self): | 
					
						
							|  |  |  |         self.d.put(self.pre) | 
					
						
							|  |  |  |         self.savedOutput = self.d.output | 
					
						
							| 
									
										
										
										
											2011-05-09 13:41:43 +02:00
										 |  |  |         self.d.output = [] | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def __exit__(self, exType, exValue, exTraceBack): | 
					
						
							|  |  |  |         self.d.put(self.post) | 
					
						
							|  |  |  |         if self.d.passExceptions and not exType is None: | 
					
						
							|  |  |  |             showException("OUTPUTSAFER", exType, exValue, exTraceBack) | 
					
						
							|  |  |  |             self.d.output = self.savedOutput | 
					
						
							|  |  |  |         else: | 
					
						
							| 
									
										
										
										
											2011-05-09 13:41:43 +02:00
										 |  |  |             self.savedOutput.extend(self.d.output) | 
					
						
							|  |  |  |             self.d.output = self.savedOutput | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         return False | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-01 15:44:22 +01:00
										 |  |  | class NoAddress: | 
					
						
							|  |  |  |     def __init__(self, d): | 
					
						
							|  |  |  |         self.d = d | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def __enter__(self): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.savedPrintsAddress = self.d.currentPrintsAddress | 
					
						
							|  |  |  |         self.d.currentPrintsAddress = False | 
					
						
							| 
									
										
										
										
											2011-03-01 15:44:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def __exit__(self, exType, exValue, exTraceBack): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.d.currentPrintsAddress = self.savedPrintsAddress | 
					
						
							| 
									
										
										
										
											2011-03-01 15:44:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  | class SubItem: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def __init__(self, d, component): | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.d = d | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.iname = "%s.%s" % (d.currentIName, component) | 
					
						
							|  |  |  |         self.name = component | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def __enter__(self): | 
					
						
							|  |  |  |         self.d.put('{') | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         #if not self.name is None: | 
					
						
							|  |  |  |         if isinstance(self.name, str): | 
					
						
							|  |  |  |             self.d.put('name="%s",' % self.name) | 
					
						
							|  |  |  |         self.savedIName = self.d.currentIName | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.savedValue = self.d.currentValue | 
					
						
							|  |  |  |         self.savedValuePriority = self.d.currentValuePriority | 
					
						
							|  |  |  |         self.savedValueEncoding = self.d.currentValueEncoding | 
					
						
							|  |  |  |         self.savedType = self.d.currentType | 
					
						
							|  |  |  |         self.savedTypePriority = self.d.currentTypePriority | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.d.currentIName = self.iname | 
					
						
							| 
									
										
										
										
											2010-04-08 14:38:42 +02:00
										 |  |  |         self.d.currentValuePriority = -100 | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.d.currentValueEncoding = None | 
					
						
							|  |  |  |         self.d.currentType = "" | 
					
						
							| 
									
										
										
										
											2010-04-08 14:38:42 +02:00
										 |  |  |         self.d.currentTypePriority = -100 | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def __exit__(self, exType, exValue, exTraceBack): | 
					
						
							|  |  |  |         #warn(" CURRENT VALUE: %s %s %s" % (self.d.currentValue, | 
					
						
							|  |  |  |         #    self.d.currentValueEncoding, self.d.currentValuePriority)) | 
					
						
							|  |  |  |         if self.d.passExceptions and not exType is None: | 
					
						
							|  |  |  |             showException("SUBITEM", exType, exValue, exTraceBack) | 
					
						
							| 
									
										
										
										
											2010-04-08 14:38:42 +02:00
										 |  |  |         try: | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |             #warn("TYPE VALUE: %s" % self.d.currentValue) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             typeName = stripClassTag(self.d.currentType) | 
					
						
							|  |  |  |             #warn("TYPE: '%s'  DEFAULT: '%s' % (typeName, self.d.currentChildType)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if len(typeName) > 0 and typeName != self.d.currentChildType: | 
					
						
							|  |  |  |                 self.d.put('type="%s",' % typeName) # str(type.unqualified()) ? | 
					
						
							|  |  |  |                 if not typeName in typeInfoCache \ | 
					
						
							|  |  |  |                         and typeName != " ": # FIXME: Move to lookupType | 
					
						
							|  |  |  |                     typeObj = lookupType(typeName) | 
					
						
							| 
									
										
										
										
											2011-04-12 15:56:03 +02:00
										 |  |  |                     if not typeObj is None: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                         typeInfoCache[typeName] = TypeInfo(typeObj) | 
					
						
							|  |  |  |             if  self.d.currentValue is None: | 
					
						
							|  |  |  |                 self.d.put('value="<not accessible>",numchild="0",') | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 if not self.d.currentValueEncoding is None: | 
					
						
							|  |  |  |                     self.d.put('valueencoded="%d",' % self.d.currentValueEncoding) | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |                 self.d.put('value="%s",' % self.d.currentValue) | 
					
						
							| 
									
										
										
										
											2010-04-08 14:38:42 +02:00
										 |  |  |         except: | 
					
						
							|  |  |  |             pass | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.d.put('},') | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.d.currentIName = self.savedIName | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.d.currentValue = self.savedValue | 
					
						
							|  |  |  |         self.d.currentValuePriority = self.savedValuePriority | 
					
						
							|  |  |  |         self.d.currentValueEncoding = self.savedValueEncoding | 
					
						
							|  |  |  |         self.d.currentType = self.savedType | 
					
						
							|  |  |  |         self.d.currentTypePriority = self.savedTypePriority | 
					
						
							|  |  |  |         return True | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  | class TopLevelItem(SubItem): | 
					
						
							|  |  |  |     def __init__(self, d, iname): | 
					
						
							|  |  |  |         self.d = d | 
					
						
							|  |  |  |         self.iname = iname | 
					
						
							|  |  |  |         self.name = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class UnnamedSubItem(SubItem): | 
					
						
							|  |  |  |     def __init__(self, d, component): | 
					
						
							|  |  |  |         self.d = d | 
					
						
							|  |  |  |         self.iname = "%s.%s" % (self.d.currentIName, component) | 
					
						
							|  |  |  |         self.name = None | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | class Children: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def __init__(self, d, numChild = 1, childType = None, childNumChild = None, | 
					
						
							|  |  |  |             maxNumChild = None, addrBase = None, addrStep = None): | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.d = d | 
					
						
							|  |  |  |         self.numChild = numChild | 
					
						
							|  |  |  |         self.childNumChild = childNumChild | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.maxNumChild = maxNumChild | 
					
						
							|  |  |  |         self.addrBase = addrBase | 
					
						
							|  |  |  |         self.addrStep = addrStep | 
					
						
							|  |  |  |         self.printsAddress = True | 
					
						
							| 
									
										
										
										
											2011-08-22 11:17:50 +02:00
										 |  |  |         if childType is None: | 
					
						
							|  |  |  |             self.childType = None | 
					
						
							|  |  |  |         else: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.childType = stripClassTag(str(childType)) | 
					
						
							|  |  |  |             self.d.put('childtype="%s",' % self.childType) | 
					
						
							| 
									
										
										
										
											2011-08-22 11:17:50 +02:00
										 |  |  |             if childNumChild is None: | 
					
						
							|  |  |  |                 if isSimpleType(childType): | 
					
						
							|  |  |  |                     self.d.put('childnumchild="0",') | 
					
						
							|  |  |  |                     self.childNumChild = 0 | 
					
						
							|  |  |  |                 elif childType.code == PointerCode: | 
					
						
							|  |  |  |                     self.d.put('childnumchild="1",') | 
					
						
							|  |  |  |                     self.childNumChild = 1 | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 self.d.put('childnumchild="%s",' % childNumChild) | 
					
						
							|  |  |  |                 self.childNumChild = childNumChild | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         try: | 
					
						
							|  |  |  |             if not addrBase is None and not addrStep is None: | 
					
						
							|  |  |  |                 self.d.put('addrbase="0x%x",' % long(addrBase)) | 
					
						
							|  |  |  |                 self.d.put('addrstep="0x%x",' % long(addrStep)) | 
					
						
							|  |  |  |                 self.printsAddress = False | 
					
						
							|  |  |  |         except: | 
					
						
							|  |  |  |             warn("ADDRBASE: %s" % addrBase) | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         #warn("CHILDREN: %s %s %s" % (numChild, childType, childNumChild)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def __enter__(self): | 
					
						
							|  |  |  |         self.savedChildType = self.d.currentChildType | 
					
						
							|  |  |  |         self.savedChildNumChild = self.d.currentChildNumChild | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.savedNumChild = self.d.currentNumChild | 
					
						
							|  |  |  |         self.savedMaxNumChild = self.d.currentMaxNumChild | 
					
						
							|  |  |  |         self.savedPrintsAddress = self.d.currentPrintsAddress | 
					
						
							|  |  |  |         self.d.currentChildType = self.childType | 
					
						
							|  |  |  |         self.d.currentChildNumChild = self.childNumChild | 
					
						
							|  |  |  |         self.d.currentNumChild = self.numChild | 
					
						
							|  |  |  |         self.d.currentMaxNumChild = self.maxNumChild | 
					
						
							|  |  |  |         self.d.currentPrintsAddress = self.printsAddress | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.d.put("children=[") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def __exit__(self, exType, exValue, exTraceBack): | 
					
						
							|  |  |  |         if self.d.passExceptions and not exType is None: | 
					
						
							|  |  |  |             showException("CHILDREN", exType, exValue, exTraceBack) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         if not self.d.currentMaxNumChild is None: | 
					
						
							|  |  |  |             if self.d.currentMaxNumChild < self.d.currentNumChild: | 
					
						
							|  |  |  |                 self.d.put('{name="<incomplete>",value="",type="",numchild="0"},') | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.d.currentChildType = self.savedChildType | 
					
						
							|  |  |  |         self.d.currentChildNumChild = self.savedChildNumChild | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.d.currentNumChild = self.savedNumChild | 
					
						
							|  |  |  |         self.d.currentMaxNumChild = self.savedMaxNumChild | 
					
						
							|  |  |  |         self.d.currentPrintsAddress = self.savedPrintsAddress | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.d.put('],') | 
					
						
							|  |  |  |         return True | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-07 09:14:35 +01:00
										 |  |  | def value(expr): | 
					
						
							| 
									
										
										
										
											2009-12-09 09:53:43 +01:00
										 |  |  |     value = parseAndEvaluate(expr) | 
					
						
							| 
									
										
										
										
											2009-12-07 09:14:35 +01:00
										 |  |  |     try: | 
					
						
							|  |  |  |         return int(value) | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         return str(value) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | def isSimpleType(typeobj): | 
					
						
							| 
									
										
										
										
											2010-08-13 10:51:41 +02:00
										 |  |  |     code = typeobj.code | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |     return code == BoolCode \ | 
					
						
							|  |  |  |         or code == CharCode \ | 
					
						
							|  |  |  |         or code == IntCode \ | 
					
						
							|  |  |  |         or code == FloatCode \ | 
					
						
							|  |  |  |         or code == EnumCode | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | def warn(message): | 
					
						
							| 
									
										
										
										
											2010-01-14 15:25:53 +01:00
										 |  |  |     if True or verbosity > 0: | 
					
						
							|  |  |  |         print "XXX: %s\n" % message.encode("latin1") | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |     pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def check(exp): | 
					
						
							|  |  |  |     if not exp: | 
					
						
							|  |  |  |         raise RuntimeError("Check failed") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-04 14:14:14 +01:00
										 |  |  | def checkRef(ref): | 
					
						
							|  |  |  |     count = ref["_q_value"] | 
					
						
							|  |  |  |     check(count > 0) | 
					
						
							|  |  |  |     check(count < 1000000) # assume there aren't a million references to any object | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | #def couldBePointer(p, align): | 
					
						
							| 
									
										
										
										
											2010-06-10 15:11:12 +02:00
										 |  |  | #    type = lookupType("unsigned int") | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | #    ptr = gdb.Value(p).cast(type) | 
					
						
							|  |  |  | #    d = int(str(ptr)) | 
					
						
							|  |  |  | #    warn("CHECKING : %s %d " % (p, ((d & 3) == 0 and (d > 1000 or d == 0)))) | 
					
						
							|  |  |  | #    return (d & (align - 1)) and (d > 1000 or d == 0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def checkAccess(p, align = 1): | 
					
						
							|  |  |  |     return p.dereference() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def checkContents(p, expected, align = 1): | 
					
						
							|  |  |  |     if int(p.dereference()) != expected: | 
					
						
							|  |  |  |         raise RuntimeError("Contents check failed") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def checkPointer(p, align = 1): | 
					
						
							|  |  |  |     if not isNull(p): | 
					
						
							|  |  |  |         p.dereference() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:45:12 +02:00
										 |  |  | def isAccessible(p): | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         long(p) | 
					
						
							|  |  |  |         return True | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         return False | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | def isNull(p): | 
					
						
							| 
									
										
										
										
											2010-01-04 16:15:32 +01:00
										 |  |  |     # The following can cause evaluation to abort with "UnicodeEncodeError" | 
					
						
							|  |  |  |     # for invalid char *, as their "contents" is being examined | 
					
						
							|  |  |  |     #s = str(p) | 
					
						
							|  |  |  |     #return s == "0x0" or s.startswith("0x0 ") | 
					
						
							| 
									
										
										
										
											2010-08-12 13:19:25 +02:00
										 |  |  |     #try: | 
					
						
							|  |  |  |     #    # Can fail with: "RuntimeError: Cannot access memory at address 0x5" | 
					
						
							|  |  |  |     #    return p.cast(lookupType("void").pointer()) == 0 | 
					
						
							|  |  |  |     #except: | 
					
						
							|  |  |  |     #    return False | 
					
						
							| 
									
										
										
										
											2011-08-31 13:45:12 +02:00
										 |  |  |     try: | 
					
						
							|  |  |  |         # Can fail with: "RuntimeError: Cannot access memory at address 0x5" | 
					
						
							|  |  |  |         return long(p) == 0 | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         return False | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | movableTypes = set([ | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     "QBrush", "QBitArray", "QByteArray", "QCustomTypeInfo", "QChar", "QDate", | 
					
						
							|  |  |  |     "QDateTime", "QFileInfo", "QFixed", "QFixedPoint", "QFixedSize", | 
					
						
							|  |  |  |     "QHashDummyValue", "QIcon", "QImage", "QLine", "QLineF", "QLatin1Char", | 
					
						
							|  |  |  |     "QLocale", "QMatrix", "QModelIndex", "QPoint", "QPointF", "QPen", | 
					
						
							|  |  |  |     "QPersistentModelIndex", "QResourceRoot", "QRect", "QRectF", "QRegExp", | 
					
						
							|  |  |  |     "QSize", "QSizeF", "QString", "QTime", "QTextBlock", "QUrl", "QVariant", | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |     "QXmlStreamAttribute", "QXmlStreamNamespaceDeclaration", | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     "QXmlStreamNotationDeclaration", "QXmlStreamEntityDeclaration" | 
					
						
							|  |  |  | ]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def stripClassTag(typeName): | 
					
						
							|  |  |  |     if typeName.startswith("class "): | 
					
						
							|  |  |  |         return typeName[6:] | 
					
						
							|  |  |  |     if typeName.startswith("struct "): | 
					
						
							|  |  |  |         return typeName[7:] | 
					
						
							|  |  |  |     if typeName.startswith("const "): | 
					
						
							|  |  |  |         return typeName[6:] | 
					
						
							|  |  |  |     if typeName.startswith("volatile "): | 
					
						
							|  |  |  |         return typeName[9:] | 
					
						
							|  |  |  |     return typeName | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | def checkPointerRange(p, n): | 
					
						
							| 
									
										
										
										
											2009-12-10 17:45:13 +01:00
										 |  |  |     for i in xrange(n): | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |         checkPointer(p) | 
					
						
							|  |  |  |         ++p | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-19 15:01:03 +01:00
										 |  |  | def call2(value, func, args): | 
					
						
							|  |  |  |     # args is a tuple. | 
					
						
							|  |  |  |     arg = "" | 
					
						
							|  |  |  |     for i in range(len(args)): | 
					
						
							|  |  |  |         if i: | 
					
						
							|  |  |  |             arg += ',' | 
					
						
							|  |  |  |         a = args[i] | 
					
						
							|  |  |  |         if (':' in a) and not ("'" in a): | 
					
						
							|  |  |  |             arg = "'%s'" % a | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             arg += a | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     #warn("CALL: %s -> %s(%s)" % (value, func, arg)) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |     type = stripClassTag(str(value.type)) | 
					
						
							| 
									
										
										
										
											2009-12-09 09:53:43 +01:00
										 |  |  |     if type.find(":") >= 0: | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |         type = "'" + type + "'" | 
					
						
							| 
									
										
										
										
											2010-08-17 11:24:09 +02:00
										 |  |  |     # 'class' is needed, see http://sourceware.org/bugzilla/show_bug.cgi?id=11912 | 
					
						
							| 
									
										
										
										
											2010-11-19 15:01:03 +01:00
										 |  |  |     exp = "((class %s*)%s)->%s(%s)" % (type, value.address, func, arg) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |     #warn("CALL: %s" % exp) | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |     result = None | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         result = parseAndEvaluate(exp) | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         pass | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |     #warn("  -> %s" % result) | 
					
						
							|  |  |  |     return result | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-19 15:01:03 +01:00
										 |  |  | def call(value, func, *args): | 
					
						
							|  |  |  |     return call2(value, func, args) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-21 12:21:45 +02:00
										 |  |  | def makeValue(type, init): | 
					
						
							|  |  |  |     type = stripClassTag(type) | 
					
						
							|  |  |  |     if type.find(":") >= 0: | 
					
						
							|  |  |  |         type = "'" + type + "'" | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  |     # Avoid malloc symbol clash with QVector. | 
					
						
							| 
									
										
										
										
											2010-09-30 12:16:41 +02:00
										 |  |  |     gdb.execute("set $d = (%s*)calloc(sizeof(%s), 1)" % (type, type)) | 
					
						
							| 
									
										
										
										
											2010-04-21 12:21:45 +02:00
										 |  |  |     gdb.execute("set *$d = {%s}" % init) | 
					
						
							|  |  |  |     value = parseAndEvaluate("$d").dereference() | 
					
						
							|  |  |  |     #warn("  TYPE: %s" % value.type) | 
					
						
							|  |  |  |     #warn("  ADDR: %s" % value.address) | 
					
						
							|  |  |  |     #warn("  VALUE: %s" % value) | 
					
						
							|  |  |  |     return value | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def makeExpression(value): | 
					
						
							|  |  |  |     type = stripClassTag(str(value.type)) | 
					
						
							|  |  |  |     if type.find(":") >= 0: | 
					
						
							|  |  |  |         type = "'" + type + "'" | 
					
						
							|  |  |  |     #warn("  TYPE: %s" % type) | 
					
						
							|  |  |  |     #exp = "(*(%s*)(&%s))" % (type, value.address) | 
					
						
							|  |  |  |     exp = "(*(%s*)(%s))" % (type, value.address) | 
					
						
							|  |  |  |     #warn("  EXP: %s" % exp) | 
					
						
							|  |  |  |     return exp | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 13:54:57 +01:00
										 |  |  | qqNs = None | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-02 14:10:14 +01:00
										 |  |  | def qtNamespace(): | 
					
						
							| 
									
										
										
										
											2011-01-17 15:09:23 +01:00
										 |  |  |     # FIXME: This only works when call from inside a Qt function frame. | 
					
						
							| 
									
										
										
										
											2011-01-12 13:39:14 +01:00
										 |  |  |     global qqNs | 
					
						
							| 
									
										
										
										
											2010-12-20 13:54:57 +01:00
										 |  |  |     if not qqNs is None: | 
					
						
							|  |  |  |         return qqNs | 
					
						
							| 
									
										
										
										
											2009-12-02 14:10:14 +01:00
										 |  |  |     try: | 
					
						
							| 
									
										
										
										
											2010-07-14 08:21:24 +02:00
										 |  |  |         str = catchCliOutput("ptype QString::Null")[0] | 
					
						
							| 
									
										
										
										
											2010-07-14 08:25:26 +02:00
										 |  |  |         # The result looks like: | 
					
						
							| 
									
										
										
										
											2010-07-14 08:21:24 +02:00
										 |  |  |         # "type = const struct myns::QString::Null {" | 
					
						
							|  |  |  |         # "    <no data fields>" | 
					
						
							|  |  |  |         # "}" | 
					
						
							|  |  |  |         pos1 = str.find("struct") + 7 | 
					
						
							|  |  |  |         pos2 = str.find("QString::Null") | 
					
						
							| 
									
										
										
										
											2011-01-17 15:09:23 +01:00
										 |  |  |         if pos1 > -1 and pos2 > -1: | 
					
						
							|  |  |  |             qqNs = str[pos1:pos2] | 
					
						
							|  |  |  |             return qqNs | 
					
						
							|  |  |  |         return "" | 
					
						
							| 
									
										
										
										
											2010-07-14 08:21:24 +02:00
										 |  |  |     except: | 
					
						
							| 
									
										
										
										
											2010-01-11 13:14:54 +01:00
										 |  |  |         return "" | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  | # --  Determine major Qt version by calling qVersion (cached) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | qqMajorVersion = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def qtMajorVersion(): | 
					
						
							|  |  |  |     global qqMajorVersion | 
					
						
							|  |  |  |     if not qqMajorVersion is None: | 
					
						
							|  |  |  |         return qqMajorVersion | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         # -- Result is returned as character, need to subtract '0' | 
					
						
							|  |  |  |         qqMajorVersion = int(parseAndEvaluate(qtNamespace() + "qVersion()[0]")) - 48 | 
					
						
							|  |  |  |         return qqMajorVersion | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         return 0 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  | def findFirstZero(p, maximum): | 
					
						
							|  |  |  |     for i in xrange(maximum): | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |         if p.dereference() == 0: | 
					
						
							|  |  |  |             return i | 
					
						
							|  |  |  |         p = p + 1 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     return maximum + 1 | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-15 17:44:56 +01:00
										 |  |  | def extractCharArray(p, maxsize): | 
					
						
							| 
									
										
										
										
											2010-06-10 15:11:12 +02:00
										 |  |  |     t = lookupType("unsigned char").pointer() | 
					
						
							| 
									
										
										
										
											2010-03-15 17:44:56 +01:00
										 |  |  |     p = p.cast(t) | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     limit = findFirstZero(p, maxsize) | 
					
						
							| 
									
										
										
										
											2010-03-15 17:44:56 +01:00
										 |  |  |     s = "" | 
					
						
							|  |  |  |     for i in xrange(limit): | 
					
						
							|  |  |  |         s += "%c" % int(p.dereference()) | 
					
						
							|  |  |  |         p += 1 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     if i > maxsize: | 
					
						
							| 
									
										
										
										
											2010-03-15 17:44:56 +01:00
										 |  |  |         s += "..." | 
					
						
							|  |  |  |     return s | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def extractByteArray(value): | 
					
						
							|  |  |  |     d_ptr = value['d'].dereference() | 
					
						
							|  |  |  |     data = d_ptr['data'] | 
					
						
							|  |  |  |     size = d_ptr['size'] | 
					
						
							|  |  |  |     alloc = d_ptr['alloc'] | 
					
						
							|  |  |  |     check(0 <= size and size <= alloc and alloc <= 100*1000*1000) | 
					
						
							|  |  |  |     checkRef(d_ptr["ref"]) | 
					
						
							|  |  |  |     if size > 0: | 
					
						
							|  |  |  |         checkAccess(data, 4) | 
					
						
							|  |  |  |         checkAccess(data + size) == 0 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     return extractCharArray(data, min(100, size)) | 
					
						
							| 
									
										
										
										
											2010-03-15 17:44:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  | def encodeCharArray(p, maxsize, limit = -1): | 
					
						
							| 
									
										
										
										
											2010-06-10 15:11:12 +02:00
										 |  |  |     t = lookupType("unsigned char").pointer() | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |     p = p.cast(t) | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     if limit == -1: | 
					
						
							|  |  |  |         limit = findFirstZero(p, maxsize) | 
					
						
							| 
									
										
										
										
											2009-12-07 09:14:35 +01:00
										 |  |  |     s = "" | 
					
						
							| 
									
										
										
										
											2010-09-13 13:51:44 +02:00
										 |  |  |     try: | 
					
						
							|  |  |  |         # gdb.Inferior is new in gdb 7.2 | 
					
						
							|  |  |  |         inferior = gdb.inferiors()[0] | 
					
						
							|  |  |  |         s = binascii.hexlify(inferior.read_memory(p, limit)) | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         for i in xrange(limit): | 
					
						
							|  |  |  |             s += "%02x" % int(p.dereference()) | 
					
						
							|  |  |  |             p += 1 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     if limit > maxsize: | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |         s += "2e2e2e" | 
					
						
							|  |  |  |     return s | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def encodeChar2Array(p, maxsize): | 
					
						
							| 
									
										
										
										
											2010-06-10 15:11:12 +02:00
										 |  |  |     t = lookupType("unsigned short").pointer() | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |     p = p.cast(t) | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     limit = findFirstZero(p, maxsize) | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |     s = "" | 
					
						
							|  |  |  |     for i in xrange(limit): | 
					
						
							|  |  |  |         s += "%04x" % int(p.dereference()) | 
					
						
							|  |  |  |         p += 1 | 
					
						
							|  |  |  |     if i == maxsize: | 
					
						
							|  |  |  |         s += "2e002e002e00" | 
					
						
							|  |  |  |     return s | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def encodeChar4Array(p, maxsize): | 
					
						
							| 
									
										
										
										
											2010-06-10 15:11:12 +02:00
										 |  |  |     t = lookupType("unsigned int").pointer() | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |     p = p.cast(t) | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     limit = findFirstZero(p, maxsize) | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |     s = "" | 
					
						
							|  |  |  |     for i in xrange(limit): | 
					
						
							|  |  |  |         s += "%08x" % int(p.dereference()) | 
					
						
							|  |  |  |         p += 1 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     if i > maxsize: | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |         s += "2e0000002e0000002e000000" | 
					
						
							| 
									
										
										
										
											2009-12-07 09:14:35 +01:00
										 |  |  |     return s | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  | def qByteArrayData(value): | 
					
						
							|  |  |  |     if qtMajorVersion() < 5: | 
					
						
							|  |  |  |         d_ptr = value['d'].dereference() | 
					
						
							|  |  |  |         checkRef(d_ptr["ref"]) | 
					
						
							|  |  |  |         data = d_ptr['data'] | 
					
						
							|  |  |  |         size = d_ptr['size'] | 
					
						
							|  |  |  |         alloc = d_ptr['alloc'] | 
					
						
							|  |  |  |         return data, size, alloc | 
					
						
							|  |  |  |     else: # Qt5: Implement the QByteArrayData::data() accessor. | 
					
						
							|  |  |  |         qByteArrayData = value['d'].dereference() | 
					
						
							|  |  |  |         size = qByteArrayData['size'] | 
					
						
							|  |  |  |         alloc = qByteArrayData['alloc'] | 
					
						
							| 
									
										
										
										
											2011-08-01 16:58:08 +02:00
										 |  |  |         charPointerType = lookupType('char *') | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         data = qByteArrayData['d'].cast(charPointerType) \ | 
					
						
							|  |  |  |              + qByteArrayData['offset'] + charPointerType.sizeof | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  |         return data, size, alloc | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  | def encodeByteArray(value): | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  |     data, size, alloc = qByteArrayData(value) | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  |     check(0 <= size and size <= alloc and alloc <= 100*1000*1000) | 
					
						
							|  |  |  |     if size > 0: | 
					
						
							|  |  |  |         checkAccess(data, 4) | 
					
						
							|  |  |  |         checkAccess(data + size) == 0 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     return encodeCharArray(data, 100, size) | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  | def qQStringData(value): | 
					
						
							|  |  |  |     if qtMajorVersion() < 5: | 
					
						
							|  |  |  |         d_ptr = value['d'].dereference() | 
					
						
							|  |  |  |         checkRef(d_ptr['ref']) | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  |         return d_ptr['data'], int(d_ptr['size']), int(d_ptr['alloc']) | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  |     else: # Qt5: Implement the QStringArrayData::data() accessor. | 
					
						
							|  |  |  |         qStringData = value['d'].dereference() | 
					
						
							| 
									
										
										
										
											2011-08-01 16:58:08 +02:00
										 |  |  |         ushortPointerType = lookupType('ushort *') | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  |         data = qStringData['d'].cast(ushortPointerType) \ | 
					
						
							|  |  |  |             + ushortPointerType.sizeof / 2 + qStringData['offset'] | 
					
						
							|  |  |  |         return data, int(qStringData['size']), int(qStringData['alloc']) | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  | def encodeString(value): | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  |     data, size, alloc = qQStringData(value) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  |     check(0 <= size and size <= alloc and alloc <= 100*1000*1000) | 
					
						
							|  |  |  |     if size > 0: | 
					
						
							|  |  |  |         checkAccess(data, 4) | 
					
						
							| 
									
										
										
										
											2010-04-12 15:44:43 +02:00
										 |  |  |         checkAccess(data + size) == 0 | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  |     s = "" | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     limit = min(size, 1000) | 
					
						
							| 
									
										
										
										
											2010-09-13 13:51:44 +02:00
										 |  |  |     try: | 
					
						
							|  |  |  |         # gdb.Inferior is new in gdb 7.2 | 
					
						
							|  |  |  |         inferior = gdb.inferiors()[0] | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  |         s = binascii.hexlify(inferior.read_memory(data, 2 * limit)) | 
					
						
							| 
									
										
										
										
											2010-09-13 13:51:44 +02:00
										 |  |  |     except: | 
					
						
							| 
									
										
										
										
											2011-07-18 12:51:18 +02:00
										 |  |  |         p = data | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |         for i in xrange(limit): | 
					
						
							| 
									
										
										
										
											2010-09-13 13:51:44 +02:00
										 |  |  |             val = int(p.dereference()) | 
					
						
							|  |  |  |             s += "%02x" % (val % 256) | 
					
						
							|  |  |  |             s += "%02x" % (val / 256) | 
					
						
							|  |  |  |             p += 1 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |     if limit < size: | 
					
						
							|  |  |  |         s += "2e002e002e00" | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  |     return s | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  | def stripTypedefs(type): | 
					
						
							|  |  |  |     type = type.unqualified() | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     while type.code == TypedefCode: | 
					
						
							| 
									
										
										
										
											2010-06-28 09:40:35 +02:00
										 |  |  |         type = type.strip_typedefs().unqualified() | 
					
						
							|  |  |  |     return type | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  | def extractFields(type): | 
					
						
							|  |  |  |     # Insufficient, see http://sourceware.org/bugzilla/show_bug.cgi?id=10953: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     #fields = type.fields() | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  |     # Insufficient, see http://sourceware.org/bugzilla/show_bug.cgi?id=11777: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     #fields = defsype).fields() | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  |     # This seems to work. | 
					
						
							| 
									
										
										
										
											2010-07-13 11:21:28 +02:00
										 |  |  |     #warn("TYPE 0: %s" % type) | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  |     type = stripTypedefs(type) | 
					
						
							| 
									
										
										
										
											2010-12-16 13:32:47 +01:00
										 |  |  |     fields = type.fields() | 
					
						
							|  |  |  |     if len(fields): | 
					
						
							|  |  |  |         return fields | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  |     #warn("TYPE 1: %s" % type) | 
					
						
							| 
									
										
										
										
											2010-07-12 17:13:58 +02:00
										 |  |  |     # This fails for arrays. See comment in lookupType. | 
					
						
							| 
									
										
										
										
											2010-08-17 15:52:01 +02:00
										 |  |  |     type0 = lookupType(str(type)) | 
					
						
							|  |  |  |     if not type0 is None: | 
					
						
							|  |  |  |         type = type0 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     if type.code == FunctionCode: | 
					
						
							| 
									
										
										
										
											2010-09-07 16:01:07 +02:00
										 |  |  |         return [] | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  |     #warn("TYPE 2: %s" % type) | 
					
						
							|  |  |  |     fields = type.fields() | 
					
						
							| 
									
										
										
										
											2010-07-13 11:21:28 +02:00
										 |  |  |     #warn("FIELDS: %s" % fields) | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  |     return fields | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | ####################################################################### | 
					
						
							|  |  |  | # | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  | # LocalItem | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | # | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  | # Contains iname, name, and value. | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  | class LocalItem: | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |     pass | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-25 09:07:14 +02:00
										 |  |  | ####################################################################### | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # SetupCommand | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-30 16:14:41 +02:00
										 |  |  | # This is a cache mapping from 'type name' to 'display alternatives'. | 
					
						
							| 
									
										
										
										
											2010-06-25 09:07:14 +02:00
										 |  |  | qqFormats = {} | 
					
						
							| 
									
										
										
										
											2010-08-30 16:14:41 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | # This is a cache of all known dumpers. | 
					
						
							| 
									
										
										
										
											2010-08-18 10:07:54 +02:00
										 |  |  | qqDumpers = {} | 
					
						
							| 
									
										
										
										
											2010-08-30 16:14:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 18:58:06 +02:00
										 |  |  | # This is a cache of all dumpers that support writing. | 
					
						
							|  |  |  | qqEditable = {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-30 16:14:41 +02:00
										 |  |  | # This is a cache of the namespace of the currently used Qt version. | 
					
						
							|  |  |  | # FIXME: This is not available on 'bbsetup' time, only at 'bb' time. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # This is a cache of typenames->bool saying whether we are QObject | 
					
						
							|  |  |  | # derived. | 
					
						
							| 
									
										
										
										
											2010-08-23 17:24:36 +02:00
										 |  |  | qqQObjectCache = {} | 
					
						
							| 
									
										
										
										
											2010-06-25 09:07:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  | def bbsetup(args): | 
					
						
							| 
									
										
										
										
											2010-07-15 11:37:06 +02:00
										 |  |  |     module = sys.modules[__name__] | 
					
						
							|  |  |  |     for key, value in module.__dict__.items(): | 
					
						
							|  |  |  |         if key.startswith("qdump__"): | 
					
						
							|  |  |  |             name = key[7:] | 
					
						
							|  |  |  |             qqDumpers[name] = value | 
					
						
							| 
									
										
										
										
											2010-08-18 10:20:12 +02:00
										 |  |  |             qqFormats[name] = qqFormats.get(name, "") | 
					
						
							| 
									
										
										
										
											2010-07-15 11:37:06 +02:00
										 |  |  |         elif key.startswith("qform__"): | 
					
						
							|  |  |  |             name = key[7:] | 
					
						
							|  |  |  |             formats = "" | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 formats = value() | 
					
						
							|  |  |  |             except: | 
					
						
							|  |  |  |                 pass | 
					
						
							|  |  |  |             qqFormats[name] = formats | 
					
						
							| 
									
										
										
										
											2011-05-10 18:58:06 +02:00
										 |  |  |         elif key.startswith("qedit__"): | 
					
						
							|  |  |  |             name = key[7:] | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 qqEditable[name] = value | 
					
						
							|  |  |  |             except: | 
					
						
							|  |  |  |                 pass | 
					
						
							| 
									
										
										
										
											2010-07-15 11:37:06 +02:00
										 |  |  |     result = "dumpers=[" | 
					
						
							| 
									
										
										
										
											2010-12-20 13:54:57 +01:00
										 |  |  |     #qqNs = qtNamespace() # This is too early | 
					
						
							| 
									
										
										
										
											2010-07-15 11:37:06 +02:00
										 |  |  |     for key, value in qqFormats.items(): | 
					
						
							| 
									
										
										
										
											2011-05-10 18:58:06 +02:00
										 |  |  |         if qqEditable.has_key(key): | 
					
						
							|  |  |  |             result += '{type="%s",formats="%s",editable="true"},' % (key, value) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             result += '{type="%s",formats="%s"},' % (key, value) | 
					
						
							| 
									
										
										
										
											2010-12-20 13:54:57 +01:00
										 |  |  |     result += ']' | 
					
						
							|  |  |  |     #result += ',namespace="%s"' % qqNs | 
					
						
							| 
									
										
										
										
											2010-09-14 12:57:24 +02:00
										 |  |  |     result += ',hasInferiorThreadList="%s"' % int(hasInferiorThreadList()) | 
					
						
							| 
									
										
										
										
											2010-07-15 11:37:06 +02:00
										 |  |  |     return result | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  | registerCommand("bbsetup", bbsetup) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-25 09:07:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 18:58:06 +02:00
										 |  |  | ####################################################################### | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # Edit Command | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def bbedit(args): | 
					
						
							| 
									
										
										
										
											2011-05-10 20:42:22 +02:00
										 |  |  |     (type, expr, value) = args.split(",") | 
					
						
							|  |  |  |     type = base64.b16decode(type, True) | 
					
						
							| 
									
										
										
										
											2011-05-10 18:58:06 +02:00
										 |  |  |     ns = qtNamespace() | 
					
						
							| 
									
										
										
										
											2011-05-10 20:42:22 +02:00
										 |  |  |     if type.startswith(ns): | 
					
						
							|  |  |  |         type = type[len(ns):] | 
					
						
							| 
									
										
										
										
											2011-05-10 18:58:06 +02:00
										 |  |  |     type = type.replace("::", "__") | 
					
						
							| 
									
										
										
										
											2011-05-10 20:42:22 +02:00
										 |  |  |     pos = type.find('<') | 
					
						
							|  |  |  |     if pos != -1: | 
					
						
							|  |  |  |         type = type[0:pos] | 
					
						
							|  |  |  |     expr = base64.b16decode(expr, True) | 
					
						
							|  |  |  |     value = base64.b16decode(value, True) | 
					
						
							|  |  |  |     #warn("EDIT: %s %s %s %s: " % (pos, type, expr, value)) | 
					
						
							| 
									
										
										
										
											2011-05-10 18:58:06 +02:00
										 |  |  |     if qqEditable.has_key(type): | 
					
						
							|  |  |  |         qqEditable[type](expr, value) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  | registerCommand("bbedit", bbedit) | 
					
						
							| 
									
										
										
										
											2011-05-10 18:58:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | ####################################################################### | 
					
						
							|  |  |  | # | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  | # Frame Command | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | # | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-10 14:28:25 +02:00
										 |  |  | def bb(args): | 
					
						
							| 
									
										
										
										
											2011-05-09 13:41:43 +02:00
										 |  |  |     output = 'data=[' + "".join(Dumper(args).output) + '],typeinfo=[' | 
					
						
							| 
									
										
										
										
											2011-04-12 15:56:03 +02:00
										 |  |  |     for typeName, typeInfo in typeInfoCache.iteritems(): | 
					
						
							|  |  |  |         if not typeInfo.reported: | 
					
						
							|  |  |  |             output += '{name="' + base64.b64encode(typeName) | 
					
						
							|  |  |  |             output += '",size="' + str(typeInfo.size) + '"},' | 
					
						
							|  |  |  |             typeInfo.reported = True | 
					
						
							|  |  |  |     output += ']'; | 
					
						
							|  |  |  |     return output | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  | registerCommand("bb", bb) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def p1(args): | 
					
						
							|  |  |  |     import cProfile | 
					
						
							|  |  |  |     cProfile.run('bb("%s")' % args, "/tmp/bbprof") | 
					
						
							|  |  |  |     import pstats | 
					
						
							|  |  |  |     pstats.Stats('/tmp/bbprof').sort_stats('time').print_stats() | 
					
						
							|  |  |  |     return "" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | registerCommand("p1", p1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def p2(args): | 
					
						
							|  |  |  |     import timeit | 
					
						
							|  |  |  |     return timeit.repeat('bb("%s")' % args, | 
					
						
							|  |  |  |         'from __main__ import bb', number=10) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | registerCommand("p2", p2) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # The Dumper Class | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-15 17:44:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | class Dumper: | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |     def __init__(self, args): | 
					
						
							| 
									
										
										
										
											2011-05-09 13:41:43 +02:00
										 |  |  |         self.output = [] | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.currentIName = "" | 
					
						
							|  |  |  |         self.currentPrintsAddress = True | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.currentChildType = "" | 
					
						
							|  |  |  |         self.currentChildNumChild = -1 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.currentMaxNumChild = -1 | 
					
						
							|  |  |  |         self.currentNumChild = -1 | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         self.currentValue = None | 
					
						
							|  |  |  |         self.currentValuePriority = -100 | 
					
						
							|  |  |  |         self.currentValueEncoding = None | 
					
						
							|  |  |  |         self.currentType = None | 
					
						
							|  |  |  |         self.currentTypePriority = -100 | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |         self.typeformats = {} | 
					
						
							|  |  |  |         self.formats = {} | 
					
						
							|  |  |  |         self.expandedINames = "" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         options = [] | 
					
						
							|  |  |  |         varList = [] | 
					
						
							|  |  |  |         watchers = "" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-20 13:54:57 +01:00
										 |  |  |         resultVarName = "" | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |         for arg in args.split(' '): | 
					
						
							|  |  |  |             pos = arg.find(":") + 1 | 
					
						
							|  |  |  |             if arg.startswith("options:"): | 
					
						
							|  |  |  |                 options = arg[pos:].split(",") | 
					
						
							|  |  |  |             elif arg.startswith("vars:"): | 
					
						
							|  |  |  |                 if len(arg[pos:]) > 0: | 
					
						
							|  |  |  |                     varList = arg[pos:].split(",") | 
					
						
							|  |  |  |             elif arg.startswith("resultvarname:"): | 
					
						
							|  |  |  |                 resultVarName = arg[pos:] | 
					
						
							|  |  |  |             elif arg.startswith("expanded:"): | 
					
						
							|  |  |  |                 self.expandedINames = set(arg[pos:].split(",")) | 
					
						
							|  |  |  |             elif arg.startswith("typeformats:"): | 
					
						
							|  |  |  |                 for f in arg[pos:].split(","): | 
					
						
							|  |  |  |                     pos = f.find("=") | 
					
						
							|  |  |  |                     if pos != -1: | 
					
						
							|  |  |  |                         type = base64.b16decode(f[0:pos], True) | 
					
						
							|  |  |  |                         self.typeformats[type] = int(f[pos+1:]) | 
					
						
							|  |  |  |             elif arg.startswith("formats:"): | 
					
						
							|  |  |  |                 for f in arg[pos:].split(","): | 
					
						
							|  |  |  |                     pos = f.find("=") | 
					
						
							|  |  |  |                     if pos != -1: | 
					
						
							|  |  |  |                         self.formats[f[0:pos]] = int(f[pos+1:]) | 
					
						
							|  |  |  |             elif arg.startswith("watchers:"): | 
					
						
							|  |  |  |                 watchers = base64.b16decode(arg[pos:], True) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         self.useFancy = "fancy" in options | 
					
						
							|  |  |  |         self.passExceptions = "pe" in options | 
					
						
							|  |  |  |         self.autoDerefPointers = "autoderef" in options | 
					
						
							| 
									
										
										
										
											2010-09-13 08:32:12 +02:00
										 |  |  |         self.partialUpdate = "partial" in options | 
					
						
							| 
									
										
										
										
											2011-05-26 16:35:36 +02:00
										 |  |  |         self.tooltipOnly = "tooltiponly" in options | 
					
						
							|  |  |  |         self.noLocals = "nolocals" in options | 
					
						
							| 
									
										
										
										
											2010-07-20 18:59:51 +02:00
										 |  |  |         self.ns = qtNamespace() | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         #warn("NAMESPACE: '%s'" % self.ns) | 
					
						
							|  |  |  |         #warn("VARIABLES: %s" % varList) | 
					
						
							|  |  |  |         #warn("EXPANDED INAMES: %s" % self.expandedINames) | 
					
						
							| 
									
										
										
										
											2010-09-07 16:36:12 +02:00
										 |  |  |         #warn("WATCHERS: %s" % watchers) | 
					
						
							| 
									
										
										
										
											2011-05-26 16:35:36 +02:00
										 |  |  |         #warn("PARTIAL: %s" % self.partialUpdate) | 
					
						
							|  |  |  |         #warn("NO LOCALS: %s" % self.noLocals) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |         module = sys.modules[__name__] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         # | 
					
						
							|  |  |  |         # Locals | 
					
						
							|  |  |  |         # | 
					
						
							| 
									
										
										
										
											2011-05-27 15:02:25 +02:00
										 |  |  |         locals = [] | 
					
						
							| 
									
										
										
										
											2010-09-13 08:32:12 +02:00
										 |  |  |         fullUpdateNeeded = True | 
					
						
							| 
									
										
										
										
											2011-05-27 11:02:57 +02:00
										 |  |  |         if self.partialUpdate and len(varList) == 1 and not self.tooltipOnly: | 
					
						
							| 
									
										
										
										
											2010-09-13 08:32:12 +02:00
										 |  |  |             #warn("PARTIAL: %s" % varList) | 
					
						
							|  |  |  |             parts = varList[0].split('.') | 
					
						
							|  |  |  |             #warn("PARTIAL PARTS: %s" % parts) | 
					
						
							|  |  |  |             name = parts[1] | 
					
						
							|  |  |  |             #warn("PARTIAL VAR: %s" % name) | 
					
						
							|  |  |  |             #fullUpdateNeeded = False | 
					
						
							|  |  |  |             try: | 
					
						
							|  |  |  |                 frame = gdb.selected_frame() | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 item = LocalItem() | 
					
						
							|  |  |  |                 item.iname = "local." + name | 
					
						
							|  |  |  |                 item.name = name | 
					
						
							| 
									
										
										
										
											2010-09-13 08:32:12 +02:00
										 |  |  |                 item.value = frame.read_var(name) | 
					
						
							|  |  |  |                 locals = [item] | 
					
						
							|  |  |  |                 #warn("PARTIAL LOCALS: %s" % locals) | 
					
						
							|  |  |  |                 fullUpdateNeeded = False | 
					
						
							|  |  |  |             except: | 
					
						
							|  |  |  |                 pass | 
					
						
							|  |  |  |             varList = [] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-26 16:35:36 +02:00
										 |  |  |         if fullUpdateNeeded and not self.tooltipOnly and not self.noLocals: | 
					
						
							| 
									
										
										
										
											2010-09-13 08:32:12 +02:00
										 |  |  |             locals = listOfLocals(varList) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # Take care of the return value of the last function call. | 
					
						
							|  |  |  |         if len(resultVarName) > 0: | 
					
						
							|  |  |  |             try: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 item = LocalItem() | 
					
						
							|  |  |  |                 item.name = resultVarName | 
					
						
							|  |  |  |                 item.iname = "return." + resultVarName | 
					
						
							|  |  |  |                 item.value = parseAndEvaluate(resultVarName) | 
					
						
							|  |  |  |                 locals.append(item) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |             except: | 
					
						
							|  |  |  |                 # Don't bother. It's only supplementary information anyway. | 
					
						
							|  |  |  |                 pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for item in locals: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             value = upcast(item.value) | 
					
						
							|  |  |  |             with OutputSafer(self, "", ""): | 
					
						
							|  |  |  |                 self.anonNumber = -1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 type = value.type.unqualified() | 
					
						
							|  |  |  |                 typeName = str(type) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |                 # Special handling for char** argv. | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |                 if type.code == PointerCode \ | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                         and item.iname == "local.argv" \ | 
					
						
							|  |  |  |                         and typeName == "char **": | 
					
						
							|  |  |  |                     n = 0 | 
					
						
							|  |  |  |                     p = value | 
					
						
							|  |  |  |                     # p is 0 for "optimized out" cases. Or contains rubbish. | 
					
						
							|  |  |  |                     try: | 
					
						
							|  |  |  |                         if not isNull(p): | 
					
						
							|  |  |  |                             while not isNull(p.dereference()) and n <= 100: | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |                                 p += 1 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                                 n += 1 | 
					
						
							|  |  |  |                     except: | 
					
						
							|  |  |  |                         pass | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     with TopLevelItem(self, item.iname): | 
					
						
							|  |  |  |                         self.put('iname="local.argv",name="argv",') | 
					
						
							|  |  |  |                         self.putItemCount(n, 100) | 
					
						
							|  |  |  |                         self.putType(typeName) | 
					
						
							|  |  |  |                         self.putNumChild(n) | 
					
						
							|  |  |  |                         if self.currentIName in self.expandedINames: | 
					
						
							|  |  |  |                             p = value | 
					
						
							|  |  |  |                             with Children(self, n): | 
					
						
							|  |  |  |                                 for i in xrange(n): | 
					
						
							|  |  |  |                                     self.putSubItem(i, p.dereference()) | 
					
						
							|  |  |  |                                     p += 1 | 
					
						
							|  |  |  |                     continue | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 else: | 
					
						
							|  |  |  |                     # A "normal" local variable or parameter. | 
					
						
							|  |  |  |                     with TopLevelItem(self, item.iname): | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |                         self.put('iname="%s",' % item.iname) | 
					
						
							|  |  |  |                         self.put('name="%s",' % item.name) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                         self.putItem(value) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         # | 
					
						
							|  |  |  |         # Watchers | 
					
						
							|  |  |  |         # | 
					
						
							|  |  |  |         with OutputSafer(self, ",", ""): | 
					
						
							|  |  |  |             if len(watchers) > 0: | 
					
						
							|  |  |  |                 for watcher in watchers.split("##"): | 
					
						
							|  |  |  |                     (exp, iname) = watcher.split("#") | 
					
						
							| 
									
										
										
										
											2010-06-11 12:22:32 +02:00
										 |  |  |                     self.handleWatch(exp, iname) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-23 11:28:15 +02:00
										 |  |  |         #print('data=[' + locals + sep + watchers + ']\n') | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-23 17:24:36 +02:00
										 |  |  |     def checkForQObjectBase(self, type): | 
					
						
							|  |  |  |         name = str(type) | 
					
						
							|  |  |  |         if name in qqQObjectCache: | 
					
						
							|  |  |  |             return qqQObjectCache[name] | 
					
						
							|  |  |  |         if name == self.ns + "QObject": | 
					
						
							|  |  |  |             qqQObjectCache[name] = True | 
					
						
							|  |  |  |             return True | 
					
						
							|  |  |  |         fields = type.strip_typedefs().fields() | 
					
						
							| 
									
										
										
										
											2011-08-23 09:22:15 +02:00
										 |  |  |         #fields = extractFields(type) | 
					
						
							| 
									
										
										
										
											2010-08-23 17:24:36 +02:00
										 |  |  |         if len(fields) == 0: | 
					
						
							|  |  |  |             qqQObjectCache[name] = False | 
					
						
							|  |  |  |             return False | 
					
						
							|  |  |  |         base = fields[0].type.strip_typedefs() | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         if base.code != StructCode: | 
					
						
							|  |  |  |             return False | 
					
						
							| 
									
										
										
										
											2010-09-03 10:58:41 +02:00
										 |  |  |         # Prevent infinite recursion in Qt 3.3.8 | 
					
						
							|  |  |  |         if str(base) == name: | 
					
						
							|  |  |  |             return False | 
					
						
							| 
									
										
										
										
											2010-08-23 17:24:36 +02:00
										 |  |  |         result = self.checkForQObjectBase(base) | 
					
						
							|  |  |  |         qqQObjectCache[name] = result | 
					
						
							|  |  |  |         return result | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def handleWatch(self, exp, iname): | 
					
						
							|  |  |  |         exp = str(exp) | 
					
						
							| 
									
										
										
										
											2011-04-08 13:21:18 +02:00
										 |  |  |         escapedExp = base64.b64encode(exp); | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |         #warn("HANDLING WATCH %s, INAME: '%s'" % (exp, iname)) | 
					
						
							|  |  |  |         if exp.startswith("[") and exp.endswith("]"): | 
					
						
							|  |  |  |             #warn("EVAL: EXP: %s" % exp) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             with TopLevelItem(self, iname): | 
					
						
							| 
									
										
										
										
											2010-10-12 10:47:07 +02:00
										 |  |  |                 self.put('iname="%s",' % iname) | 
					
						
							| 
									
										
										
										
											2011-04-08 13:21:18 +02:00
										 |  |  |                 self.put('wname="%s",' % escapedExp) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |                 try: | 
					
						
							|  |  |  |                     list = eval(exp) | 
					
						
							|  |  |  |                     self.putValue("") | 
					
						
							| 
									
										
										
										
											2011-07-11 13:33:57 +02:00
										 |  |  |                     self.putNoType() | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |                     self.putNumChild(len(list)) | 
					
						
							|  |  |  |                     # This is a list of expressions to evaluate | 
					
						
							|  |  |  |                     with Children(self, len(list)): | 
					
						
							|  |  |  |                         itemNumber = 0 | 
					
						
							|  |  |  |                         for item in list: | 
					
						
							| 
									
										
										
										
											2010-06-11 12:22:32 +02:00
										 |  |  |                             self.handleWatch(item, "%s.%d" % (iname, itemNumber)) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |                             itemNumber += 1 | 
					
						
							|  |  |  |                 except RuntimeError, error: | 
					
						
							|  |  |  |                     warn("EVAL: ERROR CAUGHT %s" % error) | 
					
						
							|  |  |  |                     self.putValue("<syntax error>") | 
					
						
							| 
									
										
										
										
											2011-07-11 13:33:57 +02:00
										 |  |  |                     self.putNoType() | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |                     self.putNumChild(0) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     self.put("children=[],") | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |             return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         with TopLevelItem(self, iname): | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |             self.put('iname="%s",' % iname) | 
					
						
							| 
									
										
										
										
											2011-04-08 13:21:18 +02:00
										 |  |  |             self.put('wname="%s",' % escapedExp) | 
					
						
							| 
									
										
										
										
											2010-07-23 18:20:13 +02:00
										 |  |  |             if len(exp) == 0: # The <Edit> case | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |                 self.putValue(" ") | 
					
						
							| 
									
										
										
										
											2011-07-11 13:33:57 +02:00
										 |  |  |                 self.putNoType() | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |                 self.putNumChild(0) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |             else: | 
					
						
							|  |  |  |                 try: | 
					
						
							|  |  |  |                     value = parseAndEvaluate(exp) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     self.putItem(value) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  |                 except RuntimeError: | 
					
						
							| 
									
										
										
										
											2010-09-07 16:36:12 +02:00
										 |  |  |                     self.currentType = " " | 
					
						
							|  |  |  |                     self.currentValue = "<no such value>" | 
					
						
							|  |  |  |                     self.currentChildNumChild = -1 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     self.currentNumChild = 0 | 
					
						
							| 
									
										
										
										
											2010-09-07 16:36:12 +02:00
										 |  |  |                     self.putNumChild(0) | 
					
						
							| 
									
										
										
										
											2010-06-10 14:52:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def put(self, value): | 
					
						
							| 
									
										
										
										
											2011-05-09 13:41:43 +02:00
										 |  |  |         self.output.append(value) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def putField(self, name, value): | 
					
						
							| 
									
										
										
										
											2010-02-10 15:30:50 +01:00
										 |  |  |         self.put('%s="%s",' % (name, value)) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-14 10:28:51 +01:00
										 |  |  |     def childRange(self): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         if self.currentMaxNumChild is None: | 
					
						
							|  |  |  |             return xrange(0, self.currentNumChild) | 
					
						
							|  |  |  |         return xrange(min(self.currentMaxNumChild, self.currentNumChild)) | 
					
						
							| 
									
										
										
										
											2009-12-14 10:28:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-29 11:10:05 +02:00
										 |  |  |     # Convenience function. | 
					
						
							| 
									
										
										
										
											2010-11-19 11:48:52 +01:00
										 |  |  |     def putItemCount(self, count, maximum = 1000000000): | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |         # This needs to override the default value, so don't use 'put' directly. | 
					
						
							| 
									
										
										
										
											2010-11-19 11:48:52 +01:00
										 |  |  |         if count > maximum: | 
					
						
							|  |  |  |             self.putValue('<>%s items>' % maximum) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             self.putValue('<%s items>' % count) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |     def putType(self, type, priority = 0): | 
					
						
							| 
									
										
										
										
											2010-07-06 12:43:48 +02:00
										 |  |  |         # Higher priority values override lower ones. | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         if priority >= self.currentTypePriority: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.currentType = str(type) | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |             self.currentTypePriority = priority | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-11 13:33:57 +02:00
										 |  |  |     def putNoType(self): | 
					
						
							|  |  |  |         # FIXME: replace with something that does not need special handling | 
					
						
							|  |  |  |         # in SubItem.__exit__(). | 
					
						
							|  |  |  |         self.putBetterType(" ") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:45:12 +02:00
										 |  |  |     def putInaccessible(self): | 
					
						
							|  |  |  |         #self.putBetterType(" ") | 
					
						
							|  |  |  |         self.putNumChild(0) | 
					
						
							|  |  |  |         self.currentValue = None | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-28 16:31:31 +02:00
										 |  |  |     def putBetterType(self, type, priority = 0): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.currentType = str(type) | 
					
						
							| 
									
										
										
										
											2011-06-28 16:31:31 +02:00
										 |  |  |         self.currentTypePriority = self.currentTypePriority + 1 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |     def putAddress(self, addr): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         if self.currentPrintsAddress: | 
					
						
							| 
									
										
										
										
											2011-05-23 17:40:58 +02:00
										 |  |  |             try: | 
					
						
							|  |  |  |                 # addr can be "None", long(None) fails. | 
					
						
							|  |  |  |                 self.put('addr="0x%x",' % long(addr)) | 
					
						
							|  |  |  |             except: | 
					
						
							|  |  |  |                 pass | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |     def putNumChild(self, numchild): | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         #warn("NUM CHILD: '%s' '%s'" % (numchild, self.currentChildNumChild)) | 
					
						
							|  |  |  |         if numchild != self.currentChildNumChild: | 
					
						
							| 
									
										
										
										
											2010-02-10 15:30:50 +01:00
										 |  |  |             self.put('numchild="%s",' % numchild) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |     def putValue(self, value, encoding = None, priority = 0): | 
					
						
							| 
									
										
										
										
											2010-06-29 11:10:05 +02:00
										 |  |  |         # Higher priority values override lower ones. | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         if priority >= self.currentValuePriority: | 
					
						
							|  |  |  |             self.currentValue = value | 
					
						
							|  |  |  |             self.currentValuePriority = priority | 
					
						
							|  |  |  |             self.currentValueEncoding = encoding | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-07 16:21:41 +02:00
										 |  |  |     def putPointerValue(self, value): | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |         # Use a lower priority | 
					
						
							| 
									
										
										
										
											2011-02-03 18:23:07 +01:00
										 |  |  |         if value is None: | 
					
						
							|  |  |  |             self.putValue(" ", None, -1) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             self.putValue("0x%x" % value.dereference().cast( | 
					
						
							|  |  |  |                 lookupType("unsigned long")), None, -1) | 
					
						
							| 
									
										
										
										
											2010-04-07 16:21:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  |     def putStringValue(self, value, priority = 0): | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |         if not value is None: | 
					
						
							| 
									
										
										
										
											2010-01-11 17:57:50 +01:00
										 |  |  |             str = encodeString(value) | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  |             self.putValue(str, Hex4EncodedLittleEndian, priority) | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-15 17:44:56 +01:00
										 |  |  |     def putDisplay(self, format, value = None, cmd = None): | 
					
						
							|  |  |  |         self.put('editformat="%s",' % format) | 
					
						
							|  |  |  |         if cmd is None: | 
					
						
							|  |  |  |             if not value is None: | 
					
						
							|  |  |  |                 self.put('editvalue="%s",' % value) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             self.put('editvalue="%s|%s",' % (cmd, value)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  |     def putByteArrayValue(self, value): | 
					
						
							|  |  |  |         str = encodeByteArray(value) | 
					
						
							| 
									
										
										
										
											2010-06-29 11:10:05 +02:00
										 |  |  |         self.putValue(str, Hex2EncodedLatin1) | 
					
						
							| 
									
										
										
										
											2010-01-06 17:01:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  |     def putName(self, name): | 
					
						
							| 
									
										
										
										
											2010-02-10 15:30:50 +01:00
										 |  |  |         self.put('name="%s",' % name) | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def isExpanded(self): | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |         #warn("IS EXPANDED: %s in %s" % (item.iname, self.expandedINames)) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         #if item.iname is None: | 
					
						
							|  |  |  |         #    raise "Illegal iname 'None'" | 
					
						
							|  |  |  |         #if item.iname.startswith("None"): | 
					
						
							|  |  |  |         #    raise "Illegal iname '%s'" % item.iname | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |         #warn("   --> %s" % (item.iname in self.expandedINames)) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         return self.currentIName in self.expandedINames | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def isExpandedSubItem(self, component): | 
					
						
							|  |  |  |         iname = "%s.%s" % (self.currentIName, component) | 
					
						
							|  |  |  |         #warn("IS EXPANDED: %s in %s" % (iname, self.expandedINames)) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |         return iname in self.expandedINames | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def stripNamespaceFromType(self, typeName): | 
					
						
							|  |  |  |         type = stripClassTag(typeName) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |         if len(self.ns) > 0 and type.startswith(self.ns): | 
					
						
							|  |  |  |             type = type[len(self.ns):] | 
					
						
							|  |  |  |         pos = type.find("<") | 
					
						
							| 
									
										
										
										
											2010-03-08 13:33:07 +01:00
										 |  |  |         # FIXME: make it recognize  foo<A>::bar<B>::iterator? | 
					
						
							|  |  |  |         while pos != -1: | 
					
						
							|  |  |  |             pos1 = type.rfind(">", pos) | 
					
						
							|  |  |  |             type = type[0:pos] + type[pos1+1:] | 
					
						
							|  |  |  |             pos = type.find("<") | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |         return type | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def isMovableType(self, type): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         if type.code == PointerCode: | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  |             return True | 
					
						
							|  |  |  |         if isSimpleType(type): | 
					
						
							|  |  |  |             return True | 
					
						
							| 
									
										
										
										
											2011-08-31 13:45:12 +02:00
										 |  |  |         return self.stripNamespaceFromType(str(type)) in movableTypes | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def putIntItem(self, name, value): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         with SubItem(self, name): | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |             self.putValue(value) | 
					
						
							| 
									
										
										
										
											2011-03-01 16:49:41 +01:00
										 |  |  |             self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |             self.putType("int") | 
					
						
							|  |  |  |             self.putNumChild(0) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def putBoolItem(self, name, value): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         with SubItem(self, name): | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |             self.putValue(value) | 
					
						
							|  |  |  |             self.putType("bool") | 
					
						
							|  |  |  |             self.putNumChild(0) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def currentItemFormat(self): | 
					
						
							|  |  |  |         format = self.formats.get(self.currentIName) | 
					
						
							| 
									
										
										
										
											2010-03-12 11:14:50 +01:00
										 |  |  |         if format is None: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             format = self.typeformats.get(stripClassTag(str(self.currentType))) | 
					
						
							| 
									
										
										
										
											2010-03-12 11:14:50 +01:00
										 |  |  |         return format | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def putSubItem(self, component, value): | 
					
						
							|  |  |  |         with SubItem(self, component): | 
					
						
							|  |  |  |             self.putItem(value) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def putNamedSubItem(self, component, value, name): | 
					
						
							|  |  |  |         with SubItem(self, component): | 
					
						
							| 
									
										
										
										
											2009-12-03 13:58:14 +01:00
										 |  |  |             self.putName(name) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putItem(value) | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def putCallItem(self, name, value, func, *args): | 
					
						
							|  |  |  |         result = call2(value, func, args) | 
					
						
							|  |  |  |         with SubItem(self, name): | 
					
						
							|  |  |  |             self.putItem(result) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def putItem(self, value): | 
					
						
							|  |  |  |         if value is None: | 
					
						
							| 
									
										
										
										
											2010-01-08 11:03:00 +01:00
										 |  |  |             # Happens for non-available watchers in gdb versions that | 
					
						
							|  |  |  |             # need to use gdb.execute instead of gdb.parse_and_eval | 
					
						
							|  |  |  |             self.putValue("<not available>") | 
					
						
							|  |  |  |             self.putType("<unknown>") | 
					
						
							|  |  |  |             self.putNumChild(0) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-16 16:57:53 +02:00
										 |  |  |         type = value.type.unqualified() | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         typeName = str(type) | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-15 15:05:03 +02:00
										 |  |  |         try: | 
					
						
							|  |  |  |             if value.is_optimized_out: | 
					
						
							|  |  |  |                 self.putValue("<optimized out>") | 
					
						
							|  |  |  |                 self.putType(typeName) | 
					
						
							|  |  |  |                 self.putNumChild(0) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  |         except: | 
					
						
							|  |  |  |             pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         # FIXME: Gui shows references stripped? | 
					
						
							|  |  |  |         #warn(" ") | 
					
						
							|  |  |  |         #warn("REAL INAME: %s " % self.currentIName) | 
					
						
							|  |  |  |         #warn("REAL TYPE: %s " % value.type) | 
					
						
							|  |  |  |         #warn("REAL CODE: %s " % value.type.code) | 
					
						
							|  |  |  |         #warn("REAL VALUE: %s " % value) | 
					
						
							| 
									
										
										
										
											2011-08-16 16:57:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |         if type.code == ReferenceCode: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             #try: | 
					
						
							| 
									
										
										
										
											2010-06-01 13:13:27 +02:00
										 |  |  |                 # This throws "RuntimeError: Attempt to dereference a | 
					
						
							|  |  |  |                 # generic pointer." with MinGW's gcc 4.5 when it "identifies" | 
					
						
							|  |  |  |                 # a "QWidget &" as "void &". | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putItem(value.cast(type.target())) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  |             #except RuntimeError: | 
					
						
							|  |  |  |             #    pass | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if type.code == IntCode or type.code == CharCode: | 
					
						
							| 
									
										
										
										
											2011-02-28 17:35:28 +01:00
										 |  |  |             self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2010-11-18 19:15:39 +01:00
										 |  |  |             self.putValue(int(value)) | 
					
						
							|  |  |  |             self.putNumChild(0) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |         if type.code == FloatCode or type.code == BoolCode: | 
					
						
							| 
									
										
										
										
											2011-02-28 17:35:28 +01:00
										 |  |  |             self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putType(typeName) | 
					
						
							|  |  |  |             self.putValue(value) | 
					
						
							| 
									
										
										
										
											2010-11-16 17:09:25 +01:00
										 |  |  |             self.putNumChild(0) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |         if type.code == EnumCode: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putType(typeName) | 
					
						
							|  |  |  |             self.putValue("%s (%d)" % (value, value)) | 
					
						
							| 
									
										
										
										
											2011-03-01 16:49:41 +01:00
										 |  |  |             self.putNumChild(0) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |         if type.code == TypedefCode: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putItem(value.cast(type.strip_typedefs())) | 
					
						
							|  |  |  |             self.putBetterType(typeName) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         format = self.formats.get(self.currentIName) | 
					
						
							|  |  |  |         if format is None: | 
					
						
							|  |  |  |             format = self.typeformats.get(stripClassTag(typeName)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |         if type.code == ArrayCode: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             targettype = type.target() | 
					
						
							| 
									
										
										
										
											2011-07-07 18:02:53 +02:00
										 |  |  |             self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2011-07-07 18:02:53 +02:00
										 |  |  |             self.putNumChild(1) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             format = self.currentItemFormat() | 
					
						
							| 
									
										
										
										
											2011-07-07 18:02:53 +02:00
										 |  |  |             if format == 0: | 
					
						
							|  |  |  |                 # Explicitly requested Latin1 formatting. | 
					
						
							|  |  |  |                 self.putValue(encodeCharArray(value, 100), Hex2EncodedLatin1) | 
					
						
							|  |  |  |             elif format == 1: | 
					
						
							|  |  |  |                 # Explicitly requested UTF-8 formatting. | 
					
						
							|  |  |  |                 self.putValue(encodeCharArray(value, 100), Hex2EncodedUtf8) | 
					
						
							| 
									
										
										
										
											2011-07-15 14:29:07 +02:00
										 |  |  |             elif format == 2: | 
					
						
							|  |  |  |                 # Explicitly requested Local 8-bit formatting. | 
					
						
							|  |  |  |                 self.putValue(encodeCharArray(value, 100), Hex2EncodedLocal8Bit) | 
					
						
							| 
									
										
										
										
											2011-04-18 16:15:39 +02:00
										 |  |  |             else: | 
					
						
							| 
									
										
										
										
											2011-07-07 18:02:53 +02:00
										 |  |  |                 self.putValue("@0x%x" % long(value.cast(targettype.pointer()))) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             if self.currentIName in self.expandedINames: | 
					
						
							|  |  |  |                 i = 0 | 
					
						
							|  |  |  |                 with Children(self, childType=targettype, | 
					
						
							|  |  |  |                         addrBase=value.cast(targettype.pointer()), | 
					
						
							|  |  |  |                         addrStep=targettype.sizeof): | 
					
						
							|  |  |  |                     self.putFields(value) | 
					
						
							|  |  |  |                     i = i + 1 | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |             return | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |         if type.code == PointerCode: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             #warn("POINTER: %s" % value) | 
					
						
							| 
									
										
										
										
											2010-02-26 14:25:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:45:12 +02:00
										 |  |  |             if not isAccessible(value): | 
					
						
							|  |  |  |                 self.currentValue = None | 
					
						
							|  |  |  |                 self.putNumChild(0) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |             if isNull(value): | 
					
						
							| 
									
										
										
										
											2010-07-06 10:57:59 +02:00
										 |  |  |                 #warn("NULL POINTER") | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putAddress(value.address) | 
					
						
							|  |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  |                 self.putValue("0x0") | 
					
						
							|  |  |  |                 self.putNumChild(0) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 return | 
					
						
							| 
									
										
										
										
											2010-07-02 09:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             innerType = type.target() | 
					
						
							|  |  |  |             innerTypeName = str(innerType.unqualified()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |             if innerType.code == VoidCode: | 
					
						
							| 
									
										
										
										
											2010-07-06 10:57:59 +02:00
										 |  |  |                 #warn("VOID POINTER: %s" % format) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2010-07-01 08:56:06 +02:00
										 |  |  |                 self.putValue(str(value)) | 
					
						
							|  |  |  |                 self.putNumChild(0) | 
					
						
							| 
									
										
										
										
											2011-02-28 17:35:28 +01:00
										 |  |  |                 self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 return | 
					
						
							| 
									
										
										
										
											2010-07-01 08:56:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |             if format == 0: | 
					
						
							|  |  |  |                 # Explicitly requested bald pointer. | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  |                 self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 self.putPointerValue(value.address) | 
					
						
							|  |  |  |                 self.putNumChild(1) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 if self.currentIName in self.expandedINames: | 
					
						
							| 
									
										
										
										
											2010-08-30 11:59:09 +02:00
										 |  |  |                     with Children(self): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                         with SubItem(self, '*'): | 
					
						
							|  |  |  |                             self.putItem(value.dereference()) | 
					
						
							|  |  |  |                             #self.putAddress(value) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 return | 
					
						
							| 
									
										
										
										
											2010-03-11 18:55:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |             if format == 1: | 
					
						
							|  |  |  |                 # Explicityly requested Latin1 formatting. | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |                 self.putValue(encodeCharArray(value, 100), Hex2EncodedLatin1) | 
					
						
							|  |  |  |                 self.putNumChild(0) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if format == 2: | 
					
						
							|  |  |  |                 # Explicityly requested UTF-8 formatting. | 
					
						
							|  |  |  |                 self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2011-05-16 15:14:30 +02:00
										 |  |  |                 self.putValue(encodeCharArray(value, 100), Hex2EncodedUtf8) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 self.putNumChild(0) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if format == 3: | 
					
						
							| 
									
										
										
										
											2011-07-04 18:31:31 +02:00
										 |  |  |                 # Explicityly requested local 8 bit formatting. | 
					
						
							|  |  |  |                 self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2011-07-04 18:31:31 +02:00
										 |  |  |                 self.putValue(encodeCharArray(value, 100), Hex2EncodedLocal8Bit) | 
					
						
							|  |  |  |                 self.putNumChild(0) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if format == 4: | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 # Explitly requested UTF-16 formatting. | 
					
						
							|  |  |  |                 self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 self.putValue(encodeChar2Array(value, 100), Hex4EncodedBigEndian) | 
					
						
							|  |  |  |                 self.putNumChild(0) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-04 18:31:31 +02:00
										 |  |  |             if format == 5: | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 # Explitly requested UCS-4 formatting. | 
					
						
							|  |  |  |                 self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 self.putValue(encodeChar4Array(value, 100), Hex8EncodedBigEndian) | 
					
						
							|  |  |  |                 self.putNumChild(0) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             if (typeName.replace("(anonymous namespace)", "").find("(") != -1): | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 # A function pointer with format None. | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putValue(str(value)) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 self.putNumChild(0) | 
					
						
							|  |  |  |                 return | 
					
						
							| 
									
										
										
										
											2010-02-26 14:25:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-05 10:48:14 +01:00
										 |  |  |             #warn("AUTODEREF: %s" % self.autoDerefPointers) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             #warn("INAME: %s" % self.currentIName) | 
					
						
							|  |  |  |             if self.autoDerefPointers or self.currentIName.endswith('.this'): | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 ## Generic pointer type with format None | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 #warn("GENERIC AUTODEREF POINTER: %s AT %s TO %s" | 
					
						
							|  |  |  |                 #    % (type, value.address, innerTypeName)) | 
					
						
							| 
									
										
										
										
											2010-10-22 12:06:30 +02:00
										 |  |  |                 # Never dereference char types. | 
					
						
							| 
									
										
										
										
											2011-03-01 15:44:22 +01:00
										 |  |  |                 if innerTypeName != "char" \ | 
					
						
							|  |  |  |                         and innerTypeName != "signed char" \ | 
					
						
							|  |  |  |                         and innerTypeName != "unsigned char"  \ | 
					
						
							|  |  |  |                         and innerTypeName != "wchar_t": | 
					
						
							| 
									
										
										
										
											2010-10-22 12:06:30 +02:00
										 |  |  |                     self.putType(innerType) | 
					
						
							|  |  |  |                     savedCurrentChildType = self.currentChildType | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     self.currentChildType = stripClassTag(innerTypeName) | 
					
						
							|  |  |  |                     self.putItem(value.dereference()) | 
					
						
							| 
									
										
										
										
											2010-10-22 12:06:30 +02:00
										 |  |  |                     self.currentChildType = savedCurrentChildType | 
					
						
							|  |  |  |                     self.putPointerValue(value.address) | 
					
						
							| 
									
										
										
										
											2011-04-06 18:39:56 +02:00
										 |  |  |                     self.put('origaddr="%s",' % value) | 
					
						
							| 
									
										
										
										
											2010-10-22 12:06:30 +02:00
										 |  |  |                     return | 
					
						
							| 
									
										
										
										
											2010-01-05 10:48:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-11 14:36:01 +01:00
										 |  |  |             # Fall back to plain pointer printing. | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |             #warn("GENERIC PLAIN POINTER: %s" % value.type) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |             self.putAddress(value.address) | 
					
						
							|  |  |  |             self.putNumChild(1) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             if self.currentIName in self.expandedINames: | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |                 with Children(self): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     with SubItem(self, "*"): | 
					
						
							|  |  |  |                         self.put('name="*",') | 
					
						
							|  |  |  |                         self.putItem(value.dereference()) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |             self.putPointerValue(value.address) | 
					
						
							|  |  |  |             return | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         if typeName.startswith("<anon"): | 
					
						
							| 
									
										
										
										
											2010-03-16 18:35:26 +01:00
										 |  |  |             # Anonymous union. We need a dummy name to distinguish | 
					
						
							|  |  |  |             # multiple anonymous unions in the struct. | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putType(type) | 
					
						
							| 
									
										
										
										
											2010-03-16 18:35:26 +01:00
										 |  |  |             self.putValue("{...}") | 
					
						
							|  |  |  |             self.anonNumber += 1 | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |             with Children(self, 1): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 self.listAnonymous(value, "#%d" % self.anonNumber, type) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-19 13:10:33 +02:00
										 |  |  |         if type.code != StructCode: | 
					
						
							| 
									
										
										
										
											2011-08-23 09:22:15 +02:00
										 |  |  |             warn("WRONG ASSUMPTION HERE: %s " % type.code) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             check(False) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  |         if self.useFancy and (format is None or format >= 1): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             self.putAddress(value.address) | 
					
						
							|  |  |  |             self.putType(typeName) | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             if typeName in qqDumpers: | 
					
						
							|  |  |  |                 qqDumpers[typeName](self, value) | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  |                 return | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             nsStrippedType = self.stripNamespaceFromType(typeName)\ | 
					
						
							|  |  |  |                 .replace("::", "__") | 
					
						
							|  |  |  |             #warn(" STRIPPED: %s" % nsStrippedType) | 
					
						
							|  |  |  |             #warn(" DUMPERS: %s" % (nsStrippedType in qqDumpers)) | 
					
						
							|  |  |  |             if nsStrippedType in qqDumpers: | 
					
						
							|  |  |  |                 qqDumpers[nsStrippedType](self, value) | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             # Is this derived from QObject? | 
					
						
							|  |  |  |             if self.checkForQObjectBase(type): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 qdump__QObject(self, value) | 
					
						
							| 
									
										
										
										
											2011-09-01 10:28:32 +02:00
										 |  |  |                 return | 
					
						
							| 
									
										
										
										
											2010-03-16 18:35:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         #warn("GENERIC STRUCT: %s" % type) | 
					
						
							|  |  |  |         #warn("INAME: %s " % self.currentIName) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |         #warn("INAMES: %s " % self.expandedINames) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         #warn("EXPANDED: %s " % (self.currentIName in self.expandedINames)) | 
					
						
							| 
									
										
										
										
											2011-08-19 14:19:33 +02:00
										 |  |  |         fields = extractFields(type) | 
					
						
							|  |  |  |         #fields = type.fields() | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.putType(typeName) | 
					
						
							|  |  |  |         self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |         self.putValue("{...}") | 
					
						
							| 
									
										
										
										
											2009-11-26 15:11:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |         if False: | 
					
						
							|  |  |  |             numfields = 0 | 
					
						
							|  |  |  |             for field in fields: | 
					
						
							|  |  |  |                 bitpos = getattr(field, "bitpos", None) | 
					
						
							|  |  |  |                 if not bitpos is None: | 
					
						
							|  |  |  |                     ++numfields | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             numfields = len(fields) | 
					
						
							|  |  |  |         self.putNumChild(numfields) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         if self.currentIName in self.expandedINames: | 
					
						
							| 
									
										
										
										
											2010-08-30 11:43:50 +02:00
										 |  |  |             innerType = None | 
					
						
							|  |  |  |             if len(fields) == 1 and fields[0].name is None: | 
					
						
							| 
									
										
										
										
											2011-06-20 15:23:28 +02:00
										 |  |  |                 innerType = type.target() | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             with Children(self, 1, childType=innerType): | 
					
						
							|  |  |  |                 self.putFields(value) | 
					
						
							| 
									
										
										
										
											2010-04-23 10:25:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def putPlainChildren(self, value): | 
					
						
							| 
									
										
										
										
											2010-11-19 11:04:36 +01:00
										 |  |  |         self.putValue(" ", None, -99) | 
					
						
							|  |  |  |         self.putNumChild(1) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |         self.putAddress(value.address) | 
					
						
							|  |  |  |         if self.currentIName in self.expandedINames: | 
					
						
							| 
									
										
										
										
											2010-11-19 11:04:36 +01:00
										 |  |  |             with Children(self): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                self.putFields(value) | 
					
						
							| 
									
										
										
										
											2010-11-19 11:04:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def putFields(self, value, dumpBase = True): | 
					
						
							| 
									
										
										
										
											2010-07-01 09:37:28 +02:00
										 |  |  |             type = stripTypedefs(value.type) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |             # Insufficient, see http://sourceware.org/bugzilla/show_bug.cgi?id=10953: | 
					
						
							|  |  |  |             #fields = type.fields() | 
					
						
							|  |  |  |             fields = extractFields(type) | 
					
						
							|  |  |  |             #warn("TYPE: %s" % type) | 
					
						
							|  |  |  |             #warn("FIELDS: %s" % fields) | 
					
						
							| 
									
										
										
										
											2010-04-23 10:25:32 +02:00
										 |  |  |             baseNumber = 0 | 
					
						
							|  |  |  |             for field in fields: | 
					
						
							|  |  |  |                 #warn("FIELD: %s" % field) | 
					
						
							|  |  |  |                 #warn("  BITSIZE: %s" % field.bitsize) | 
					
						
							|  |  |  |                 #warn("  ARTIFICIAL: %s" % field.artificial) | 
					
						
							|  |  |  |                 bitpos = getattr(field, "bitpos", None) | 
					
						
							|  |  |  |                 if bitpos is None: # FIXME: Is check correct? | 
					
						
							|  |  |  |                     continue  # A static class member(?). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if field.name is None: | 
					
						
							| 
									
										
										
										
											2010-07-01 09:37:28 +02:00
										 |  |  |                     innerType = type.target() | 
					
						
							| 
									
										
										
										
											2010-04-23 10:25:32 +02:00
										 |  |  |                     p = value.cast(innerType.pointer()) | 
					
						
							| 
									
										
										
										
											2010-07-01 09:37:28 +02:00
										 |  |  |                     for i in xrange(type.sizeof / innerType.sizeof): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                         with SubItem(self, i): | 
					
						
							|  |  |  |                             self.putItem(p.dereference()) | 
					
						
							| 
									
										
										
										
											2010-04-23 10:25:32 +02:00
										 |  |  |                         p = p + 1 | 
					
						
							|  |  |  |                     continue | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 # Ignore vtable pointers for virtual inheritance. | 
					
						
							|  |  |  |                 if field.name.startswith("_vptr."): | 
					
						
							| 
									
										
										
										
											2011-08-23 09:22:15 +02:00
										 |  |  |                     with SubItem(self, "[vptr]"): | 
					
						
							|  |  |  |                         # int (**)(void) | 
					
						
							|  |  |  |                         n = 20 | 
					
						
							|  |  |  |                         self.putType(" ") | 
					
						
							|  |  |  |                         self.putValue(value[field.name]) | 
					
						
							|  |  |  |                         self.putNumChild(n) | 
					
						
							|  |  |  |                         if self.isExpanded(): | 
					
						
							|  |  |  |                             with Children(self): | 
					
						
							|  |  |  |                                 p = value[field.name] | 
					
						
							|  |  |  |                                 for i in xrange(n): | 
					
						
							|  |  |  |                                     if long(p.dereference()) != 0: | 
					
						
							|  |  |  |                                         with SubItem(self, i): | 
					
						
							|  |  |  |                                             self.putItem(p.dereference()) | 
					
						
							|  |  |  |                                             self.putType(" ") | 
					
						
							|  |  |  |                                             p = p + 1 | 
					
						
							| 
									
										
										
										
											2010-04-23 10:25:32 +02:00
										 |  |  |                     continue | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 #warn("FIELD NAME: %s" % field.name) | 
					
						
							|  |  |  |                 #warn("FIELD TYPE: %s" % field.type) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 if field.is_base_class: | 
					
						
							| 
									
										
										
										
											2010-04-23 10:25:32 +02:00
										 |  |  |                     # Field is base type. We cannot use field.name as part | 
					
						
							|  |  |  |                     # of the iname as it might contain spaces and other | 
					
						
							|  |  |  |                     # strange characters. | 
					
						
							| 
									
										
										
										
											2011-03-01 15:44:22 +01:00
										 |  |  |                     if dumpBase: | 
					
						
							|  |  |  |                         baseNumber += 1 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                         with UnnamedSubItem(self, "@%d" % baseNumber): | 
					
						
							|  |  |  |                             self.put('iname="%s",' % self.currentIName) | 
					
						
							|  |  |  |                             self.put('name="%s",' % field.name) | 
					
						
							|  |  |  |                             self.putItem(value.cast(field.type)) | 
					
						
							| 
									
										
										
										
											2010-04-23 10:25:32 +02:00
										 |  |  |                 elif len(field.name) == 0: | 
					
						
							|  |  |  |                     # Anonymous union. We need a dummy name to distinguish | 
					
						
							|  |  |  |                     # multiple anonymous unions in the struct. | 
					
						
							|  |  |  |                     self.anonNumber += 1 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     self.listAnonymous(value, "#%d" % self.anonNumber, | 
					
						
							| 
									
										
										
										
											2010-04-23 10:25:32 +02:00
										 |  |  |                         field.type) | 
					
						
							|  |  |  |                 else: | 
					
						
							|  |  |  |                     # Named field. | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     with SubItem(self, field.name): | 
					
						
							|  |  |  |                         #bitsize = getattr(field, "bitsize", None) | 
					
						
							|  |  |  |                         #if not bitsize is None: | 
					
						
							|  |  |  |                         #    self.put("bitsize=\"%s\",bitpos=\"%s\"," | 
					
						
							|  |  |  |                         #            % (bitsize, bitpos)) | 
					
						
							|  |  |  |                         self.putItem(upcast(value[field.name])) | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-25 14:30:43 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |     def listAnonymous(self, value, name, type): | 
					
						
							| 
									
										
										
										
											2010-02-25 14:30:43 +01:00
										 |  |  |         for field in type.fields(): | 
					
						
							| 
									
										
										
										
											2010-03-17 11:44:04 +01:00
										 |  |  |             #warn("FIELD NAME: %s" % field.name) | 
					
						
							| 
									
										
										
										
											2010-02-25 14:30:43 +01:00
										 |  |  |             if len(field.name) > 0: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 with SubItem(self, field.name): | 
					
						
							| 
									
										
										
										
											2011-02-28 17:35:28 +01:00
										 |  |  |                     #self.putAddress(value.address) | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     self.putItem(value[field.name]) | 
					
						
							| 
									
										
										
										
											2010-02-25 14:30:43 +01:00
										 |  |  |             else: | 
					
						
							|  |  |  |                 # Further nested. | 
					
						
							| 
									
										
										
										
											2010-03-16 18:35:26 +01:00
										 |  |  |                 self.anonNumber += 1 | 
					
						
							|  |  |  |                 name = "#%d" % self.anonNumber | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                 #iname = "%s.%s" % (selitem.iname, name) | 
					
						
							|  |  |  |                 #child = SameItem(item.value, iname) | 
					
						
							|  |  |  |                 with SubItem(self, name): | 
					
						
							| 
									
										
										
										
											2010-10-08 14:54:01 +02:00
										 |  |  |                     self.put('name="%s",' % name) | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |                     self.putValue(" ") | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     fieldTypeName = str(field.type) | 
					
						
							|  |  |  |                     if fieldTypeName.endswith("<anonymous union>"): | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |                         self.putType("<anonymous union>") | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                     elif fieldTypeName.endswith("<anonymous struct>"): | 
					
						
							| 
									
										
										
										
											2010-06-28 14:06:17 +02:00
										 |  |  |                         self.putType("<anonymous struct>") | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |                     else: | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                         self.putType(fieldTypeName) | 
					
						
							| 
									
										
										
										
											2010-04-08 14:08:19 +02:00
										 |  |  |                     with Children(self, 1): | 
					
						
							| 
									
										
										
										
											2011-08-17 14:55:41 +02:00
										 |  |  |                         self.listAnonymous(value, name, field.type) | 
					
						
							| 
									
										
										
										
											2010-02-25 14:30:43 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-13 12:37:30 +02:00
										 |  |  | ####################################################################### | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # ThreadNames Command | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-01 15:07:19 +02:00
										 |  |  | def threadnames(arg): | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  |     ns = qtNamespace() | 
					
						
							|  |  |  |     out = '[' | 
					
						
							|  |  |  |     oldthread = gdb.selected_thread() | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         for thread in gdb.inferiors()[0].threads(): | 
					
						
							|  |  |  |             maximalStackDepth = int(arg) | 
					
						
							|  |  |  |             thread.switch() | 
					
						
							|  |  |  |             e = gdb.selected_frame () | 
					
						
							|  |  |  |             while True: | 
					
						
							|  |  |  |                 maximalStackDepth -= 1 | 
					
						
							|  |  |  |                 if maximalStackDepth < 0: | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                 e = e.older() | 
					
						
							|  |  |  |                 if e == None or e.name() == None: | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                 if e.name() == ns + "QThreadPrivate::start": | 
					
						
							|  |  |  |                     try: | 
					
						
							|  |  |  |                         thrptr = e.read_var("thr").dereference() | 
					
						
							|  |  |  |                         obtype = lookupType(ns + "QObjectPrivate").pointer() | 
					
						
							|  |  |  |                         d_ptr = thrptr["d_ptr"]["d"].cast(obtype).dereference() | 
					
						
							|  |  |  |                         objectName = d_ptr["objectName"] | 
					
						
							|  |  |  |                         out += '{valueencoded="'; | 
					
						
							|  |  |  |                         out += str(Hex4EncodedLittleEndianWithoutQuotes)+'",id="' | 
					
						
							|  |  |  |                         out += str(thread.num) + '",value="' | 
					
						
							|  |  |  |                         out += encodeString(objectName) | 
					
						
							|  |  |  |                         out += '"},' | 
					
						
							|  |  |  |                     except: | 
					
						
							|  |  |  |                         pass | 
					
						
							|  |  |  |     except: | 
					
						
							|  |  |  |         pass | 
					
						
							|  |  |  |     oldthread.switch() | 
					
						
							| 
									
										
										
										
											2011-09-01 15:07:19 +02:00
										 |  |  |     return out + ']' | 
					
						
							| 
									
										
										
										
											2010-09-13 12:37:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  | registerCommand("threadnames", threadnames) | 
					
						
							| 
									
										
										
										
											2010-09-13 12:37:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-25 14:30:43 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-12 10:39:33 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # Mixed C++/Qml debugging | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | ####################################################################### | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  | def qmlb(args): | 
					
						
							|  |  |  |     # executeCommand(command, to_string=True).split("\n") | 
					
						
							| 
									
										
										
										
											2011-01-12 10:39:33 +01:00
										 |  |  |     warm("RUNNING: break -f QScript::FunctionWrapper::proxyCall") | 
					
						
							|  |  |  |     output = catchCliOutput("rbreak -f QScript::FunctionWrapper::proxyCall") | 
					
						
							|  |  |  |     warn("OUTPUT: %s " % output) | 
					
						
							|  |  |  |     bp = output[0] | 
					
						
							|  |  |  |     warn("BP: %s " % bp) | 
					
						
							|  |  |  |     # BP: ['Breakpoint 3 at 0xf166e7: file .../qscriptfunction.cpp, line 75.\\n'] \n" | 
					
						
							|  |  |  |     pos = bp.find(' ') + 1 | 
					
						
							|  |  |  |     warn("POS: %s " % pos) | 
					
						
							|  |  |  |     nr = bp[bp.find(' ') + 1 : bp.find(' at ')] | 
					
						
							|  |  |  |     warn("NR: %s " % nr) | 
					
						
							|  |  |  |     return bp | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-28 17:38:52 +02:00
										 |  |  | registerCommand("qmlb", qmlb) |