summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLysandros Nikolaou <lisandrosnik@gmail.com>2023-05-24 16:18:17 (GMT)
committerGitHub <noreply@github.com>2023-05-24 16:18:17 (GMT)
commitc90a862cdcf55dc1753c6466e5fa4a467a13ae24 (patch)
tree61b79498a0d900e2c653c88447409139079c0d53
parent9d457e115447b2079a1f66950d3c76cb77febf38 (diff)
downloadcpython-c90a862cdcf55dc1753c6466e5fa4a467a13ae24.zip
cpython-c90a862cdcf55dc1753c6466e5fa4a467a13ae24.tar.gz
cpython-c90a862cdcf55dc1753c6466e5fa4a467a13ae24.tar.bz2
gh-104866: Tokenize should emit NEWLINE after exiting block with comment (#104870)
-rw-r--r--Lib/test/test_tokenize.py17
-rw-r--r--Parser/tokenizer.c9
2 files changed, 23 insertions, 3 deletions
diff --git a/Lib/test/test_tokenize.py b/Lib/test/test_tokenize.py
index fd9c919..251ce2b 100644
--- a/Lib/test/test_tokenize.py
+++ b/Lib/test/test_tokenize.py
@@ -1057,6 +1057,23 @@ async def f():
DEDENT '' (6, 12) (6, 12)
""")
+ def test_newline_after_parenthesized_block_with_comment(self):
+ self.check_tokenize('''\
+[
+ # A comment here
+ 1
+]
+''', """\
+ OP '[' (1, 0) (1, 1)
+ NL '\\n' (1, 1) (1, 2)
+ COMMENT '# A comment here' (2, 4) (2, 20)
+ NL '\\n' (2, 20) (2, 21)
+ NUMBER '1' (3, 4) (3, 5)
+ NL '\\n' (3, 5) (3, 6)
+ OP ']' (4, 0) (4, 1)
+ NEWLINE '\\n' (4, 1) (4, 2)
+ """)
+
class GenerateTokensTest(TokenizeTest):
def check_tokenize(self, s, expected):
# Format the tokens in s in a table format.
diff --git a/Parser/tokenizer.c b/Parser/tokenizer.c
index 472d417..1e8f785 100644
--- a/Parser/tokenizer.c
+++ b/Parser/tokenizer.c
@@ -2007,6 +2007,9 @@ tok_get_normal_mode(struct tok_state *tok, tokenizer_mode* current_tok, struct t
tok->atbol = 1;
if (blankline || tok->level > 0) {
if (tok->tok_extra_tokens) {
+ if (tok->comment_newline) {
+ tok->comment_newline = 0;
+ }
p_start = tok->start;
p_end = tok->cur;
return MAKE_TOKEN(NL);
@@ -2015,9 +2018,9 @@ tok_get_normal_mode(struct tok_state *tok, tokenizer_mode* current_tok, struct t
}
if (tok->comment_newline && tok->tok_extra_tokens) {
tok->comment_newline = 0;
- p_start = tok->start;
- p_end = tok->cur;
- return MAKE_TOKEN(NL);
+ p_start = tok->start;
+ p_end = tok->cur;
+ return MAKE_TOKEN(NL);
}
p_start = tok->start;
p_end = tok->cur - 1; /* Leave '\n' out of the string */