[Lldb-commits] [PATCH] D92601: [lldb] Refactor the Symbolicator initializer
Jonas Devlieghere via Phabricator via lldb-commits
lldb-commits at lists.llvm.org
Thu Dec 3 12:56:36 PST 2020
JDevlieghere created this revision.
JDevlieghere added a reviewer: jingham.
JDevlieghere requested review of this revision.
We found out that we have clients relying on the old signature of the Symbolicator initializer. Make the signature compatible again and provide a factory method to initialize the class correctly based on whether you have a target or want the symbolicator to create one for you.
https://reviews.llvm.org/D92601
Files:
lldb/examples/python/symbolication.py
Index: lldb/examples/python/symbolication.py
===================================================================
--- lldb/examples/python/symbolication.py
+++ lldb/examples/python/symbolication.py
@@ -437,18 +437,22 @@
class Symbolicator:
- def __init__(self, debugger):
- """A class the represents the information needed to symbolicate addresses in a program"""
+ def __init__(self, debugger=None, target=None, images=list()):
+ """A class the represents the information needed to symbolicate
+ addresses in a program.
+
+ Do not call this initializer directly, but rather use the factory
+ methods.
+ """
self.debugger = debugger
- self.target = None
- self.images = list() # a list of images to be used when symbolicating
+ self.target = target
+ self.images = images # a list of images to be used when symbolicating
self.addr_mask = 0xffffffffffffffff
@classmethod
def InitWithSBTarget(cls, target):
- obj = cls()
- obj.target = target
- obj.images = list()
+ """Initialize a new Symbolicator with an existing SBTarget."""
+ obj = cls(target=target)
triple = target.triple
if triple:
arch = triple.split('-')[0]
@@ -460,6 +464,13 @@
obj.images.append(image)
return obj
+ @classmethod
+ def InitWithSBDebugger(cls, debugger, images):
+ """Initialize a new Symbolicator with an existing debugger and list of
+ images. The Symbolicator will create the target."""
+ obj = cls(debugger=debugger, images=images)
+ return obj
+
def __str__(self):
s = "Symbolicator:\n"
if self.target:
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D92601.309342.patch
Type: text/x-patch
Size: 1742 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20201203/825392d5/attachment.bin>
More information about the lldb-commits
mailing list