[Python-checkins] r55803 - in python/branches/release25-maint: Lib/test/test_compile.py Python/ast.c

georg.brandl python-checkins at python.org
Thu Jun 7 15:23:29 CEST 2007


Author: georg.brandl
Date: Thu Jun 7 15:23:28 2007
New Revision: 55803
Modified:
 python/branches/release25-maint/Lib/test/test_compile.py
 python/branches/release25-maint/Python/ast.c
Log:
Disallow function calls like foo(None=1).
Backport from py3k rev. 55708 by Guido.
 (backport from rev. 55802)
Modified: python/branches/release25-maint/Lib/test/test_compile.py
==============================================================================
--- python/branches/release25-maint/Lib/test/test_compile.py	(original)
+++ python/branches/release25-maint/Lib/test/test_compile.py	Thu Jun 7 15:23:28 2007
@@ -37,6 +37,9 @@
 def test_syntax_error(self):
 self.assertRaises(SyntaxError, compile, "1+*3", "filename", "exec")
 
+ def test_none_keyword_arg(self):
+ self.assertRaises(SyntaxError, compile, "f(None=1)", "<string>", "exec")
+
 def test_duplicate_global_local(self):
 try:
 exec 'def f(a): global a; a = 1'
Modified: python/branches/release25-maint/Python/ast.c
==============================================================================
--- python/branches/release25-maint/Python/ast.c	(original)
+++ python/branches/release25-maint/Python/ast.c	Thu Jun 7 15:23:28 2007
@@ -1855,13 +1855,18 @@
 * then is very confusing.
 */
 if (e->kind == Lambda_kind) {
- ast_error(CHILD(ch, 0), "lambda cannot contain assignment");
- return NULL;
+ ast_error(CHILD(ch, 0),
+ "lambda cannot contain assignment");
+ return NULL;
 } else if (e->kind != Name_kind) {
- ast_error(CHILD(ch, 0), "keyword can't be an expression");
- return NULL;
+ ast_error(CHILD(ch, 0), "keyword can't be an expression");
+ return NULL;
 }
 		key = e->v.Name.id;
+ if (!strcmp(PyString_AS_STRING(key), "None")) {
+ ast_error(CHILD(ch, 0), "assignment to None");
+ return NULL;
+ }
 		e = ast_for_expr(c, CHILD(ch, 2));
 if (!e)
 return NULL;


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /