]> git.rkrishnan.org Git - tahoe-lafs/tahoe-lafs.git/commitdiff
Sun Oct 9 05:47:10 BST 2011 david-sarah@jacaranda.org
authorDaira Hopwood <daira@jacaranda.org>
Thu, 5 Sep 2013 18:11:16 +0000 (19:11 +0100)
committerDaira Hopwood <daira@jacaranda.org>
Thu, 5 Sep 2013 18:11:16 +0000 (19:11 +0100)
  * check-miscaptures.py: handle destructuring function arguments correctly. refs #1555

misc/coding_tools/check-miscaptures.py

index 81422adb81632a0accad1d29b7fcc08caddf10b9..9820a8a3b45e50e0eb2a31006d6a50d905a737df 100644 (file)
@@ -88,10 +88,8 @@ def collect_captured(ast, assigned, captured, in_function_yet):
         if isinstance(ast, (Lambda, Function)):
             # Formal parameters of the function are excluded from
             # captures we care about in subnodes of the function body.
-            assigned = assigned.copy()
-            for argname in ast.argnames:
-                if argname in assigned:
-                    del assigned[argname]
+            new_assigned = assigned.copy()
+            remove_argnames(ast.argnames, new_assigned)
 
             if len(new_assigned) > 0:
                 for child in childnodes[len(ast.defaults):]:
@@ -109,6 +107,14 @@ def collect_captured(ast, assigned, captured, in_function_yet):
                 collect_captured(child, assigned, captured, True)
 
 
+def remove_argnames(names, fromset):
+    for element in names:
+        if element in fromset:
+            del fromset[element]
+        elif isinstance(element, (tuple, list)):
+            remove_argnames(element, fromset)
+
+
 def make_result(funcnode, var_name, var_lineno):
     if hasattr(funcnode, 'name'):
         func_name = 'function %r' % (funcnode.name,)