forked from llvm/llvm-project
- Notifications
You must be signed in to change notification settings - Fork 339
/
Copy pathlldbDataFormatters.py
117 lines (98 loc) · 4.26 KB
/
lldbDataFormatters.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
"""
LLDB Formatters for LLVM data types.
Load into LLDB with 'command script import /path/to/lldbDataFormatters.py'
"""
def__lldb_init_module(debugger, internal_dict):
debugger.HandleCommand('type category define -e llvm -l c++')
debugger.HandleCommand('type synthetic add -w llvm '
'-l lldbDataFormatters.SmallVectorSynthProvider '
'-x "^llvm::SmallVectorImpl<.+>$"')
debugger.HandleCommand('type synthetic add -w llvm '
'-l lldbDataFormatters.SmallVectorSynthProvider '
'-x "^llvm::SmallVector<.+,.+>$"')
debugger.HandleCommand('type synthetic add -w llvm '
'-l lldbDataFormatters.ArrayRefSynthProvider '
'-x "^llvm::ArrayRef<.+>$"')
debugger.HandleCommand('type summary add -w llvm '
'-F lldbDataFormatters.OptionalSummaryProvider '
'-x "^llvm::Optional<.+>$"')
debugger.HandleCommand('type summary add -w llvm '
'-F lldbDataFormatters.SmallStringSummaryProvider '
'-x "^llvm::SmallString<.+>$"')
# Pretty printer for llvm::SmallVector/llvm::SmallVectorImpl
classSmallVectorSynthProvider:
def__init__(self, valobj, dict):
self.valobj=valobj;
self.update() # initialize this provider
defnum_children(self):
returnself.size.GetValueAsUnsigned(0)
defget_child_index(self, name):
try:
returnint(name.lstrip('[').rstrip(']'))
except:
return-1;
defget_child_at_index(self, index):
# Do bounds checking.
ifindex<0:
returnNone
ifindex>=self.num_children():
returnNone;
offset=index*self.type_size
returnself.begin.CreateChildAtOffset('['+str(index)+']',
offset, self.data_type)
defupdate(self):
self.begin=self.valobj.GetChildMemberWithName('BeginX')
self.size=self.valobj.GetChildMemberWithName('Size')
the_type=self.valobj.GetType()
# If this is a reference type we have to dereference it to get to the
# template parameter.
ifthe_type.IsReferenceType():
the_type=the_type.GetDereferencedType()
self.data_type=the_type.GetTemplateArgumentType(0)
self.type_size=self.data_type.GetByteSize()
assertself.type_size!=0
classArrayRefSynthProvider:
""" Provider for llvm::ArrayRef """
def__init__(self, valobj, dict):
self.valobj=valobj;
self.update() # initialize this provider
defnum_children(self):
returnself.length
defget_child_index(self, name):
try:
returnint(name.lstrip('[').rstrip(']'))
except:
return-1;
defget_child_at_index(self, index):
ifindex<0orindex>=self.num_children():
returnNone;
offset=index*self.type_size
returnself.data.CreateChildAtOffset('['+str(index) +']',
offset, self.data_type)
defupdate(self):
self.data=self.valobj.GetChildMemberWithName('Data')
length_obj=self.valobj.GetChildMemberWithName('Length')
self.length=length_obj.GetValueAsUnsigned(0)
self.data_type=self.data.GetType().GetPointeeType()
self.type_size=self.data_type.GetByteSize()
assertself.type_size!=0
defOptionalSummaryProvider(valobj, internal_dict):
storage=valobj.GetChildMemberWithName('Storage')
ifnotstorage:
storage=valobj
failure=2
hasVal=storage.GetChildMemberWithName('hasVal').GetValueAsUnsigned(failure)
ifhasVal==failure:
return'<could not read llvm::Optional>'
ifhasVal==0:
return'None'
underlying_type=storage.GetType().GetTemplateArgumentType(0)
storage=storage.GetChildMemberWithName('storage')
returnstr(storage.Cast(underlying_type))
defSmallStringSummaryProvider(valobj, internal_dict):
num_elements=valobj.GetNumChildren()
res="\""
foriinrange(0, num_elements):
res+=valobj.GetChildAtIndex(i).GetValue().strip("'")
res+="\""
returnres