diff options
author | Jeremy Hylton <jeremy@alum.mit.edu> | 2001-04-16 18:43:18 +0000 |
---|---|---|
committer | Jeremy Hylton <jeremy@alum.mit.edu> | 2001-04-16 18:43:18 +0000 |
commit | ab3cdd4eeb7f5b9af1fd108e9e9a4b12598bea2e (patch) | |
tree | ce9c7b9cc8d91722490b3fbcb083f66ec590c3c6 /Lib/symtable.py | |
parent | 112471e26d035da4cfa3488b0a9e512ff5e6c5d5 (diff) | |
download | cpython-ab3cdd4eeb7f5b9af1fd108e9e9a4b12598bea2e.tar.gz |
Fix three PyChecker-detected gotchas.
Import OPT_ symbols from _symtable.
Define has_exec() and has_import_star().
Diffstat (limited to 'Lib/symtable.py')
-rw-r--r-- | Lib/symtable.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/Lib/symtable.py b/Lib/symtable.py index 135cd569b6..210c33978f 100644 --- a/Lib/symtable.py +++ b/Lib/symtable.py @@ -4,7 +4,8 @@ from __future__ import nested_scopes import _symtable from _symtable import USE, DEF_GLOBAL, DEF_LOCAL, DEF_PARAM, \ DEF_STAR, DEF_DOUBLESTAR, DEF_INTUPLE, DEF_FREE, \ - DEF_FREE_GLOBAL, DEF_FREE_CLASS, DEF_IMPORT, DEF_BOUND + DEF_FREE_GLOBAL, DEF_FREE_CLASS, DEF_IMPORT, DEF_BOUND, \ + OPT_IMPORT_STAR, OPT_EXEC, OPT_BARE_EXEC import weakref @@ -97,7 +98,12 @@ class SymbolTable: return bool(self._table.children) def has_exec(self): - return bool() + """Return true if the scope uses exec""" + return bool(self._table.optimized & (OPT_EXEC | OPT_BARE_EXEC)) + + def has_import_star(self): + """Return true if the scope uses import *""" + return bool(self._table.optimized & OPT_IMPORT_STAR) def get_identifiers(self): return self._table.symbols.keys() @@ -190,10 +196,10 @@ class Symbol: or (self.__flags & DEF_FREE_GLOBAL)) def is_vararg(self): - return bool(self.flag & DEF_STAR) + return bool(self.__flags & DEF_STAR) def is_keywordarg(self): - return bool(self.__flags & DEF_STARSTAR) + return bool(self.__flags & DEF_DOUBLESTAR) def is_local(self): return bool(self.__flags & DEF_BOUND) |