diff options
author | Devang Patel <dpatel@apple.com> | 2011-01-26 19:14:14 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2011-01-26 19:14:14 +0000 |
commit | a3722e67d99c8586dea6d5244d778aa0f484291b (patch) | |
tree | 9b6364495d164ae34dcd494bea03fc06deb7dd76 /utils | |
parent | cfe33c46aa50f04adb0431243e7d25f79b719ac6 (diff) | |
download | external_llvm-a3722e67d99c8586dea6d5244d778aa0f484291b.zip external_llvm-a3722e67d99c8586dea6d5244d778aa0f484291b.tar.gz external_llvm-a3722e67d99c8586dea6d5244d778aa0f484291b.tar.bz2 |
- Do not try to print nameless variable's info.
- Print a summary of breakpoints in the beginning.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@124308 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rwxr-xr-x | utils/CollectDebugInfoUsingLLDB.py | 50 |
1 files changed, 28 insertions, 22 deletions
diff --git a/utils/CollectDebugInfoUsingLLDB.py b/utils/CollectDebugInfoUsingLLDB.py index 9dba66a..6987b0f 100755 --- a/utils/CollectDebugInfoUsingLLDB.py +++ b/utils/CollectDebugInfoUsingLLDB.py @@ -87,30 +87,40 @@ def print_vars (tag, vars, fname, line, file, frame, target, thread): bp_loc.SetEnabled(False); for i in range(vars.GetSize()): - file.write(tag) - file.write(fname) - file.write(':') - file.write(str(line)) - file.write(' ') - file.write(str(tid)) - file.write(':') - file.write(str(bid)) - file.write(' ') - v = vars.GetValueAtIndex(i) - file.write(v.GetName()) - file.write(' ') - AlreadyPrintedValues.clear() - print_var_value (v, file, frame) - file.write('\n') + v = vars.GetValueAtIndex(i) + if v.GetName() is not None: + file.write(tag) + file.write(fname) + file.write(':') + file.write(str(line)) + file.write(' ') + file.write(str(tid)) + file.write(':') + file.write(str(bid)) + file.write(' ') + file.write(v.GetName()) + file.write(' ') + AlreadyPrintedValues.clear() + print_var_value (v, file, frame) + file.write('\n') # set_breakpoints - set breakpoints as listed in input file. -def set_breakpoints (target, breakpoint_filename): +def set_breakpoints (target, breakpoint_filename, file): f = open(breakpoint_filename, "r") lines = f.readlines() for l in range(len(lines)): c = lines[l].split() # print "setting break point - ", c bp = target.BreakpointCreateByLocation (str(c[0]), int(c[1])) + file.write("#Breakpoint ") + file.write(str(c[0])) + file.write(':') + file.write(str(c[1])) + file.write(' ') + file.write(str(bp.GetThreadID())) + file.write(':') + file.write(str(bp.GetID())) + file.write('\n') f.close() # stopeed_at_breakpoint - Return True if process is stopeed at a @@ -139,16 +149,12 @@ target = debugger.CreateTargetWithFileAndArch (sys.argv[1], lldb.LLDB_ARCH_DEFAU if target.IsValid(): #print "target is valid" - set_breakpoints (target, sys.argv[2]) - #main_bp = target.BreakpointCreateByLocation ("byval-alignment.c", 11) - #main_bp2 = target.BreakpointCreateByLocation ("byval-alignment.c", 20) - - ##print main_bp + file=open(str(sys.argv[3]), 'w') + set_breakpoints (target, sys.argv[2], file) # Launch the process. Since we specified synchronous mode, we won't return # from this function until we hit the breakpoint at main process = target.LaunchProcess ([''], [''], "/dev/stdout", 0, False) - file=open(str(sys.argv[3]), 'w') # Make sure the launch went ok while stopped_at_breakpoint(process): thread = process.GetThreadAtIndex (0) |