[Lldb-commits] [lldb] r273963 - Fixup the "shadow" example command to use the function that takes an execution context now that the @lldb.command decorator does the right thing for the command function that takes 5 arguments.
Greg Clayton via lldb-commits
lldb-commits at lists.llvm.org
Mon Jun 27 17:06:35 PDT 2016
Author: gclayton
Date: Mon Jun 27 19:06:35 2016
New Revision: 273963
URL: http://llvm.org/viewvc/llvm-project?rev=273963&view=rev
Log:
Fixup the "shadow" example command to use the function that takes an execution context now that the @lldb.command decorator does the right thing for the command function that takes 5 arguments.
A few fixes:
- Check the process state to make sure it is stopped
- Grab the frame from the "exe_ctx" so this will work during breakpoint callbacks
- Print out the SBDeclaration objects of the variables that shadow each other so we can see the source locations of which variable declarations are shodowing each other.
Modified:
lldb/trunk/examples/python/shadow.py
Modified: lldb/trunk/examples/python/shadow.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/examples/python/shadow.py?rev=273963&r1=273962&r2=273963&view=diff
==============================================================================
--- lldb/trunk/examples/python/shadow.py (original)
+++ lldb/trunk/examples/python/shadow.py Mon Jun 27 19:06:35 2016
@@ -4,20 +4,14 @@ import lldb
import shlex
@lldb.command("shadow")
-def check_shadow_command(debugger, command, result, dict):
- target = debugger.GetSelectedTarget()
- if not target:
- print >>result, "invalid target"
- return
- process = target.GetProcess()
- if not process:
- print >>result, "invalid process"
- return
- thread = process.GetSelectedThread()
- if not thread:
- print >>result, "invalid thread"
- return
- frame = thread.GetSelectedFrame()
+def check_shadow_command(debugger, command, exe_ctx, result, dict):
+ '''Check the currently selected stack frame for shadowed variables'''
+ process = exe_ctx.GetProcess()
+ state = process.GetState()
+ if state != lldb.eStateStopped:
+ print >>result, "process must be stopped, state is %s" % lldb.SBDebugger.StateAsCString(state)
+ return
+ frame = exe_ctx.GetFrame()
if not frame:
print >>result, "invalid frame"
return
@@ -26,8 +20,9 @@ def check_shadow_command(debugger, comma
# TODO: add support for using arguments that are passed to this command...
# Make a dictionary of variable name to "SBBlock and SBValue"
- var_dict = {}
+ shadow_dict = {}
+ num_shadowed_variables = 0
# Get the deepest most block from the current frame
block = frame.GetBlock()
# Iterate through the block and all of its parents
@@ -36,24 +31,27 @@ def check_shadow_command(debugger, comma
block_vars = block.GetVariables(frame, True, True, True, 0)
# Iterate through all variables in the current block
for block_var in block_vars:
- # Get the variable name and see if we already have a variable by this name?
- block_var_name = block_var.GetName()
- if block_var_name in var_dict:
- # We already have seen a variable with this name, so it is shadowed
- shadow_block_and_vars = var_dict[block_var_name]
- for shadow_block_and_var in shadow_block_and_vars:
- print shadow_block_and_var[0], shadow_block_and_var[1]
- print 'is shadowed by:'
- print block, block_var
# Since we can have multiple shadowed variables, we our variable
# name dictionary to have an array or "block + variable" pairs so
# We can correctly print out all shadowed variables and whow which
# blocks they come from
- if block_var_name in var_dict:
- var_dict[block_var_name].append([block, block_var])
+ block_var_name = block_var.GetName()
+ if block_var_name in shadow_dict:
+ shadow_dict[block_var_name].append(block_var)
else:
- var_dict[block_var_name] = [[block, block_var]]
+ shadow_dict[block_var_name] = [block_var]
# Get the parent block and continue
block = block.GetParent()
-
+
+ num_shadowed_variables = 0
+ if shadow_dict:
+ for name in shadow_dict.keys():
+ shadow_vars = shadow_dict[name]
+ if len(shadow_vars) > 1:
+ print '"%s" is shadowed by the following declarations:' % (name)
+ num_shadowed_variables += 1
+ for shadow_var in shadow_vars:
+ print >>result, str(shadow_var.GetDeclaration())
+ if num_shadowed_variables == 0:
+ print >>result, 'no variables are shadowed'
More information about the lldb-commits
mailing list