[Python-checkins] r82537 - in python/branches/py3k: Lib/test/test_parser.py Misc/NEWS Modules/parsermodule.c
mark.dickinson
python-checkins at python.org
Sun Jul 4 18:37:31 CEST 2010
Author: mark.dickinson
Date: Sun Jul 4 18:37:31 2010
New Revision: 82537
Log:
Issue #9128: Fix validation of class decorators in parser module.
Modified:
python/branches/py3k/Lib/test/test_parser.py
python/branches/py3k/Misc/NEWS
python/branches/py3k/Modules/parsermodule.c
Modified: python/branches/py3k/Lib/test/test_parser.py
==============================================================================
--- python/branches/py3k/Lib/test/test_parser.py (original)
+++ python/branches/py3k/Lib/test/test_parser.py Sun Jul 4 18:37:31 2010
@@ -149,6 +149,13 @@
def test_class_defs(self):
self.check_suite("class foo():pass")
self.check_suite("class foo(object):pass")
+ self.check_suite("@class_decorator\n"
+ "class foo():pass")
+ self.check_suite("@class_decorator(arg)\n"
+ "class foo():pass")
+ self.check_suite("@decorator1\n"
+ "@decorator2\n"
+ "class foo():pass")
def test_import_from_statement(self):
self.check_suite("from sys.path import *")
Modified: python/branches/py3k/Misc/NEWS
==============================================================================
--- python/branches/py3k/Misc/NEWS (original)
+++ python/branches/py3k/Misc/NEWS Sun Jul 4 18:37:31 2010
@@ -468,6 +468,8 @@
Library
-------
+- Issue #9128: Fix validation of class decorators in parser module.
+
- Issue #9094: python -m pickletools will now disassemble pickle files
listed in the command line arguments. See output of python -m
pickletools -h for more details.
Modified: python/branches/py3k/Modules/parsermodule.c
==============================================================================
--- python/branches/py3k/Modules/parsermodule.c (original)
+++ python/branches/py3k/Modules/parsermodule.c Sun Jul 4 18:37:31 2010
@@ -2509,14 +2509,15 @@
static int
validate_decorated(node *tree)
{
- int nch = NCH(tree);
- int ok = (validate_ntype(tree, decorated)
- && (nch == 2)
- && validate_decorators(RCHILD(tree, -2))
- && (validate_funcdef(RCHILD(tree, -1))
- || validate_class(RCHILD(tree, -1)))
- );
- return ok;
+ int nch = NCH(tree);
+ int ok = (validate_ntype(tree, decorated)
+ && (nch == 2)
+ && validate_decorators(RCHILD(tree, -2)));
+ if (TYPE(RCHILD(tree, -1)) == funcdef)
+ ok = ok && validate_funcdef(RCHILD(tree, -1));
+ else
+ ok = ok && validate_class(RCHILD(tree, -1));
+ return ok;
}
static int
More information about the Python-checkins
mailing list