summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeal Norwitz <nnorwitz@gmail.com>2005-12-11 20:12:40 (GMT)
committerNeal Norwitz <nnorwitz@gmail.com>2005-12-11 20:12:40 (GMT)
commitf8d403dd972a354fadc939d54dc0a1c45ffda327 (patch)
tree13fd4898edc4b4ada740831a9b280320f5b00da1
parent8ad64aaacc22d68d6d93c3c12f7e67e9962de09b (diff)
downloadcpython-f8d403dd972a354fadc939d54dc0a1c45ffda327.zip
cpython-f8d403dd972a354fadc939d54dc0a1c45ffda327.tar.gz
cpython-f8d403dd972a354fadc939d54dc0a1c45ffda327.tar.bz2
SF #1377897, Bus error in ast
If a line had multiple semi-colons and ended with a semi-colon, we would loop too many times and access a NULL node. Exit the loop early if there are no more children.
-rw-r--r--Lib/test/test_grammar.py4
-rw-r--r--Python/ast.c5
2 files changed, 9 insertions, 0 deletions
diff --git a/Lib/test/test_grammar.py b/Lib/test/test_grammar.py
index 820fab5..aa76b44 100644
--- a/Lib/test/test_grammar.py
+++ b/Lib/test/test_grammar.py
@@ -276,6 +276,10 @@ check_syntax("lambda x: x = 2")
### simple_stmt: small_stmt (';' small_stmt)* [';']
print 'simple_stmt'
x = 1; pass; del x
+def foo():
+ # verify statments that end with semi-colons
+ x = 1; pass; del x;
+foo()
### small_stmt: expr_stmt | print_stmt | pass_stmt | del_stmt | flow_stmt | import_stmt | global_stmt | access_stmt | exec_stmt
# Tested below
diff --git a/Python/ast.c b/Python/ast.c
index 89ec217..04b2b3e 100644
--- a/Python/ast.c
+++ b/Python/ast.c
@@ -2562,6 +2562,11 @@ ast_for_suite(struct compiling *c, const node *n)
ch = CHILD(ch, 0);
REQ(ch, simple_stmt);
for (j = 0; j < NCH(ch); j += 2) {
+ /* statement terminates with a semi-colon ';' */
+ if (NCH(CHILD(ch, j)) == 0) {
+ assert((j + 1) == NCH(ch));
+ break;
+ }
s = ast_for_stmt(c, CHILD(ch, j));
if (!s)
goto error;