summaryrefslogtreecommitdiff
path: root/pycodestyle.py
diff options
context:
space:
mode:
authorAnthony Sottile <asottile@umich.edu>2022-11-21 14:22:37 -0500
committerGitHub <noreply@github.com>2022-11-21 14:22:37 -0500
commitb38878283c6e4898df7bf438fb4dc03cd204ca14 (patch)
treea70f3ce5cd62cc4546c87232f5e6db9db50cea71 /pycodestyle.py
parent7498309c2d59ff2ac69e6fae264f507a4ee2feb3 (diff)
parent798d620cd461a1e7abac1cbba5aab66274aa3229 (diff)
downloadpep8-b38878283c6e4898df7bf438fb4dc03cd204ca14.tar.gz
Merge pull request #1123 from PyCQA/fix-E741-again
fix ambiguous identifiers in lambda bodies inside braces
Diffstat (limited to 'pycodestyle.py')
-rwxr-xr-xpycodestyle.py13
1 files changed, 9 insertions, 4 deletions
diff --git a/pycodestyle.py b/pycodestyle.py
index b75eed0..f06f923 100755
--- a/pycodestyle.py
+++ b/pycodestyle.py
@@ -1517,7 +1517,7 @@ def ambiguous_identifier(logical_line, tokens):
E742: class I(object):
E743: def l(x):
"""
- is_func_def = False # Set to true if 'def' or 'lambda' is found
+ func_depth = None # set to brace depth if 'def' or 'lambda' is found
seen_colon = False # set to true if we're done with function parameters
brace_depth = 0
idents_to_avoid = ('l', 'O', 'I')
@@ -1527,8 +1527,13 @@ def ambiguous_identifier(logical_line, tokens):
ident = pos = None
# find function definitions
if prev_text in {'def', 'lambda'}:
- is_func_def = True
- elif is_func_def and text == ':' and brace_depth == 0:
+ func_depth = brace_depth
+ seen_colon = False
+ elif (
+ func_depth is not None and
+ text == ':' and
+ brace_depth == func_depth
+ ):
seen_colon = True
# update parameter parentheses level
if text in '([{':
@@ -1548,7 +1553,7 @@ def ambiguous_identifier(logical_line, tokens):
pos = start
# function / lambda parameter definitions
if (
- is_func_def and
+ func_depth is not None and
not seen_colon and
index < len(tokens) - 1 and tokens[index + 1][1] in ':,=)' and
prev_text in {'lambda', ',', '*', '**', '('} and