From: Georg Brandl Date: Mon, 19 Mar 2007 18:56:50 +0000 (+0000) Subject: "from ... import x" should not be a syntax error... make X-Git-Tag: v3.0a1~1111 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e66c8c7c127370ab7d0055f98053caad48cbc135;p=python "from ... import x" should not be a syntax error... make import_stmt accept ELLIPSes and DOTs. --- diff --git a/Grammar/Grammar b/Grammar/Grammar index e4cd3e07fe..41d8be8a9e 100644 --- a/Grammar/Grammar +++ b/Grammar/Grammar @@ -55,7 +55,8 @@ yield_stmt: yield_expr raise_stmt: 'raise' [test [',' test [',' test]]] import_stmt: import_name | import_from import_name: 'import' dotted_as_names -import_from: ('from' ('.'* dotted_name | '.'+) +# note below: the ('.' | '...') is necessary because '...' is tokenized as ELLIPSIS +import_from: ('from' (('.' | '...')* dotted_name | ('.' | '...')+) 'import' ('*' | '(' import_as_names ')' | import_as_names)) import_as_name: NAME ['as' NAME] dotted_as_name: dotted_name ['as' NAME] diff --git a/Python/ast.c b/Python/ast.c index 8180b4224d..777c00ec0b 100644 --- a/Python/ast.c +++ b/Python/ast.c @@ -2406,8 +2406,8 @@ ast_for_import_stmt(struct compiling *c, const node *n) /* import_stmt: import_name | import_from import_name: 'import' dotted_as_names - import_from: 'from' ('.'* dotted_name | '.') 'import' - ('*' | '(' import_as_names ')' | import_as_names) + import_from: 'from' (('.' | '...')* dotted_name | ('.' | '...')+) + 'import' ('*' | '(' import_as_names ')' | import_as_names) */ int lineno; int col_offset; @@ -2445,6 +2445,10 @@ ast_for_import_stmt(struct compiling *c, const node *n) mod = alias_for_import_name(c, CHILD(n, idx)); idx++; break; + } else if (TYPE(CHILD(n, idx)) == ELLIPSIS) { + /* three consecutive dots are tokenized as one ELLIPSIS */ + ndots += 3; + continue; } else if (TYPE(CHILD(n, idx)) != DOT) { break; }