diff options
author | Jeremy Hylton <jeremy@alum.mit.edu> | 2001-11-09 19:50:08 +0000 |
---|---|---|
committer | Jeremy Hylton <jeremy@alum.mit.edu> | 2001-11-09 19:50:08 +0000 |
commit | 778e26546284f956cbf8a85a8b7a0bf28c194410 (patch) | |
tree | c81d319729f7e05c96fb85d939edb8636240ca99 | |
parent | 734c7fb13165e9c299c2522f06da5b31a50af941 (diff) | |
download | cpython-git-778e26546284f956cbf8a85a8b7a0bf28c194410.tar.gz |
Fix SF buf #480096: Assign to __debug__ still allowed
Easy enough to catch assignment in the compiler. The perverse user
can still change the value of __debug__, but that may be the least he
can do.
-rw-r--r-- | Lib/test/test_compile.py | 14 | ||||
-rw-r--r-- | Python/compile.c | 9 |
2 files changed, 20 insertions, 3 deletions
diff --git a/Lib/test/test_compile.py b/Lib/test/test_compile.py index 9f20ba1377..e976a30dd5 100644 --- a/Lib/test/test_compile.py +++ b/Lib/test/test_compile.py @@ -1,6 +1,17 @@ from test_support import verbose, TestFailed if verbose: + print "Testing whether compiler catches assignment to __debug__" + +try: + compile('__debug__ = 1', '?', 'single') +except SyntaxError: + pass + +import __builtin__ +setattr(__builtin__, '__debug__', 'sure') + +if verbose: print 'Running tests on argument handling' try: @@ -21,7 +32,8 @@ try: except SyntaxError: pass -print "testing complex args" +if verbose: + print "testing complex args" def comp_args((a, b)): print a,b diff --git a/Python/compile.c b/Python/compile.c index c8a56699bc..1a46064dd4 100644 --- a/Python/compile.c +++ b/Python/compile.c @@ -5459,8 +5459,13 @@ symtable_assign(struct symtable *st, node *n, int def_flag) n = CHILD(n, 1); goto loop; } else if (TYPE(tmp) == NAME) { - if (strcmp(STR(tmp), "__debug__") == 0) - symtable_warn(st, ASSIGN_DEBUG); + if (strcmp(STR(tmp), "__debug__") == 0) { + PyErr_SetString(PyExc_SyntaxError, + ASSIGN_DEBUG); + PyErr_SyntaxLocation(st->st_filename, + st->st_cur->ste_opt_lineno); + st->st_errors++; + } symtable_add_def(st, STR(tmp), DEF_LOCAL | def_flag); } return; |