From dcaf329e40923d22aefefeaf48babd422a5ad384 Mon Sep 17 00:00:00 2001 From: Benjamin Peterson Date: Tue, 3 Mar 2009 00:54:05 +0000 Subject: instead of hacking __locals__ in during bytecode generation, put it in the symtable --- Python/symtable.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'Python/symtable.c') diff --git a/Python/symtable.c b/Python/symtable.c index 17876ea0eb..732b85cf17 100644 --- a/Python/symtable.c +++ b/Python/symtable.c @@ -186,7 +186,8 @@ static int symtable_visit_annotations(struct symtable *st, stmt_ty s); static identifier top = NULL, lambda = NULL, genexpr = NULL, - listcomp = NULL, setcomp = NULL, dictcomp = NULL, __class__ = NULL; + listcomp = NULL, setcomp = NULL, dictcomp = NULL, + __class__ = NULL, __locals__ = NULL; #define GET_IDENTIFIER(VAR) \ ((VAR) ? (VAR) : ((VAR) = PyUnicode_InternFromString(# VAR))) @@ -1050,7 +1051,9 @@ symtable_visit_stmt(struct symtable *st, stmt_ty s) (void *)s, s->lineno)) return 0; if (!GET_IDENTIFIER(__class__) || - !symtable_add_def(st, __class__, DEF_LOCAL)) { + !symtable_add_def(st, __class__, DEF_LOCAL) || + !GET_IDENTIFIER(__locals__) || + !symtable_add_def(st, __locals__, DEF_PARAM)) { symtable_exit_block(st, s); return 0; } -- cgit v1.2.1