[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