summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2002-01-15 21:06:07 (GMT)
committerGuido van Rossum <guido@python.org>2002-01-15 21:06:07 (GMT)
commit340cbe74b9e26823cdc7e7803e5fbdb9e6946f6e (patch)
treededaef6fc6209d078062c27560fd24a39f30ae46
parent7668957508a1129c2171e520471c453098588834 (diff)
downloadcpython-340cbe74b9e26823cdc7e7803e5fbdb9e6946f6e.zip
cpython-340cbe74b9e26823cdc7e7803e5fbdb9e6946f6e.tar.gz
cpython-340cbe74b9e26823cdc7e7803e5fbdb9e6946f6e.tar.bz2
A tentative fix for SF bug #503837 (Roeland Rengelink):
type.__module__ problems (again?) This simply initializes the __module__ local in a class statement from the __name__ global. I'm not 100% sure that this is the correct fix, although it usually does the right thing. The problem is that if the class statement executes in a custom namespace, the __name__ global may be taken from __builtins__, in which case it would have the value __builtin__, or it may not exist at all (if the custom namespace also has a custom __builtins__), in which case the class statement will fail. Nevertheless, unless someone finds a better solution, this is a 2.2.1 bugfix too.
-rw-r--r--Python/compile.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/Python/compile.c b/Python/compile.c
index ca3a47d..9180832 100644
--- a/Python/compile.c
+++ b/Python/compile.c
@@ -3926,6 +3926,9 @@ compile_classdef(struct compiling *c, node *n)
/* classdef: 'class' NAME ['(' testlist ')'] ':' suite */
c->c_name = STR(CHILD(n, 1));
c->c_private = c->c_name;
+ /* Initialize local __module__ from global __name__ */
+ com_addop_name(c, LOAD_GLOBAL, "__name__");
+ com_addop_name(c, STORE_NAME, "__module__");
ch = CHILD(n, NCH(n)-1); /* The suite */
doc = get_docstring(c, ch);
if (doc != NULL) {