summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--checkers/variables.py32
-rw-r--r--test/input/func_used_before_assignment_py30.py8
2 files changed, 8 insertions, 32 deletions
diff --git a/checkers/variables.py b/checkers/variables.py
index 4ad82c4..6ab6927 100644
--- a/checkers/variables.py
+++ b/checkers/variables.py
@@ -508,30 +508,14 @@ builtins. Remember that you should avoid to define new builtins when possible.'
if defframe.root().lookup(name)[1]:
maybee0601 = False
else:
- # check if we have a nonlocal
- frame = node.frame()
- frame_parent = frame.parent
- if (isinstance(frame, astroid.Function) and
- isinstance(frame_parent, astroid.Function)):
- # detect that the name exists
- # in the upper level
- defined_higher = False
- for assign in frame_parent.get_children():
- if not isinstance(assign, astroid.Assign):
- continue
- for target in assign.targets:
- if (isinstance(target, astroid.AssName) and
- target.name == name):
- defined_higher = True
- break
- if defined_higher:
- break
- for child in frame.get_children():
- if not isinstance(child, astroid.Nonlocal):
- continue
- if name in child.names and defined_higher:
- maybee0601 = False
- break
+ # check if we have a nonlocal
+ if name in defframe.locals:
+ for child in defframe.get_children():
+ if not isinstance(child, astroid.Nonlocal):
+ continue
+ if name in child.names:
+ maybee0601 = False
+ break
if (maybee0601
and stmt.fromlineno <= defstmt.fromlineno
and not is_defined_before(node)
diff --git a/test/input/func_used_before_assignment_py30.py b/test/input/func_used_before_assignment_py30.py
index 04987f3..3765d6b 100644
--- a/test/input/func_used_before_assignment_py30.py
+++ b/test/input/func_used_before_assignment_py30.py
@@ -17,11 +17,3 @@ def test_fail():
def wrap():
cnt = cnt + 1
wrap()
-
-def test2_fail():
- """ uses nonlocal, but without an
- outer label defined. """
- def wrap():
- nonlocal cnt
- cnt = cnt + 1
- wrap()