diff options
| author | Benjamin Peterson <benjamin@python.org> | 2015-04-27 21:44:22 -0400 | 
|---|---|---|
| committer | Benjamin Peterson <benjamin@python.org> | 2015-04-27 21:44:22 -0400 | 
| commit | 1dfd247c1ba947e99a482eeacfb8cbdecdd45b72 (patch) | |
| tree | 24aede540fb2fac7e3fe6502f295b9e4d50bd10b | |
| parent | 48050cbbe7cc62e76dbd0fdbf391c183f1c2e30a (diff) | |
| download | cpython-git-1dfd247c1ba947e99a482eeacfb8cbdecdd45b72.tar.gz | |
remove the concept of an unoptimized function scope from the compiler, since it can't happen anymore
| -rw-r--r-- | Include/symtable.h | 5 | ||||
| -rw-r--r-- | Lib/symtable.py | 9 | ||||
| -rw-r--r-- | Modules/symtablemodule.c | 3 | ||||
| -rw-r--r-- | Python/compile.c | 7 | ||||
| -rw-r--r-- | Python/symtable.c | 16 | 
5 files changed, 4 insertions, 36 deletions
| diff --git a/Include/symtable.h b/Include/symtable.h index 1cfd8844e5..1409cd91ce 100644 --- a/Include/symtable.h +++ b/Include/symtable.h @@ -43,7 +43,6 @@ typedef struct _symtable_entry {      PyObject *ste_children;  /* list of child blocks */      PyObject *ste_directives;/* locations of global and nonlocal statements */      _Py_block_ty ste_type;   /* module, class, or function */ -    int ste_unoptimized;     /* false if namespace is optimized */      int ste_nested;      /* true if block is nested */      unsigned ste_free : 1;        /* true if block has free variables */      unsigned ste_child_free : 1;  /* true if a child block has free vars, @@ -108,10 +107,6 @@ PyAPI_FUNC(void) PySymtable_Free(struct symtable *);  #define FREE 4  #define CELL 5 -/* The following two names are used for the ste_unoptimized bit field */ -#define OPT_IMPORT_STAR 1 -#define OPT_TOPLEVEL 2  /* top-level names, including eval and exec */ -  #define GENERATOR 1  #define GENERATOR_EXPRESSION 2 diff --git a/Lib/symtable.py b/Lib/symtable.py index e23313b031..84fec4aa66 100644 --- a/Lib/symtable.py +++ b/Lib/symtable.py @@ -2,7 +2,7 @@  import _symtable  from _symtable import (USE, DEF_GLOBAL, DEF_LOCAL, DEF_PARAM, -     DEF_IMPORT, DEF_BOUND, OPT_IMPORT_STAR, SCOPE_OFF, SCOPE_MASK, FREE, +     DEF_IMPORT, DEF_BOUND, SCOPE_OFF, SCOPE_MASK, FREE,       LOCAL, GLOBAL_IMPLICIT, GLOBAL_EXPLICIT, CELL)  import weakref @@ -74,8 +74,7 @@ class SymbolTable(object):          return self._table.lineno      def is_optimized(self): -        return bool(self._table.type == _symtable.TYPE_FUNCTION -                    and not self._table.optimized) +        return bool(self._table.type == _symtable.TYPE_FUNCTION)      def is_nested(self):          return bool(self._table.nested) @@ -87,10 +86,6 @@ class SymbolTable(object):          """Return true if the scope uses exec.  Deprecated method."""          return False -    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() diff --git a/Modules/symtablemodule.c b/Modules/symtablemodule.c index cdb4ffcbd8..f84cc78b73 100644 --- a/Modules/symtablemodule.c +++ b/Modules/symtablemodule.c @@ -84,9 +84,6 @@ PyInit__symtable(void)      PyModule_AddIntConstant(m, "TYPE_CLASS", ClassBlock);      PyModule_AddIntConstant(m, "TYPE_MODULE", ModuleBlock); -    PyModule_AddIntMacro(m, OPT_IMPORT_STAR); -    PyModule_AddIntMacro(m, OPT_TOPLEVEL); -      PyModule_AddIntMacro(m, LOCAL);      PyModule_AddIntMacro(m, GLOBAL_EXPLICIT);      PyModule_AddIntMacro(m, GLOBAL_IMPLICIT); diff --git a/Python/compile.c b/Python/compile.c index d5009e18fa..855ec464af 100644 --- a/Python/compile.c +++ b/Python/compile.c @@ -2753,8 +2753,7 @@ compiler_nameop(struct compiler *c, identifier name, expr_context_ty ctx)              optype = OP_FAST;          break;      case GLOBAL_IMPLICIT: -        if (c->u->u_ste->ste_type == FunctionBlock && -            !c->u->u_ste->ste_unoptimized) +        if (c->u->u_ste->ste_type == FunctionBlock)              optype = OP_GLOBAL;          break;      case GLOBAL_EXPLICIT: @@ -4185,9 +4184,7 @@ compute_code_flags(struct compiler *c)      int flags = 0;      Py_ssize_t n;      if (ste->ste_type == FunctionBlock) { -        flags |= CO_NEWLOCALS; -        if (!ste->ste_unoptimized) -            flags |= CO_OPTIMIZED; +        flags |= CO_NEWLOCALS | CO_OPTIMIZED;          if (ste->ste_nested)              flags |= CO_NESTED;          if (ste->ste_generator) diff --git a/Python/symtable.c b/Python/symtable.c index 951267342b..fbbe77f625 100644 --- a/Python/symtable.c +++ b/Python/symtable.c @@ -47,7 +47,6 @@ ste_new(struct symtable *st, identifier name, _Py_block_ty block,      ste->ste_directives = NULL;      ste->ste_type = block; -    ste->ste_unoptimized = 0;      ste->ste_nested = 0;      ste->ste_free = 0;      ste->ste_varargs = 0; @@ -113,7 +112,6 @@ static PyMemberDef ste_memberlist[] = {      {"symbols",  T_OBJECT, OFF(ste_symbols), READONLY},      {"varnames", T_OBJECT, OFF(ste_varnames), READONLY},      {"children", T_OBJECT, OFF(ste_children), READONLY}, -    {"optimized",T_INT,    OFF(ste_unoptimized), READONLY},      {"nested",   T_INT,    OFF(ste_nested), READONLY},      {"type",     T_INT,    OFF(ste_type), READONLY},      {"lineno",   T_INT,    OFF(ste_lineno), READONLY}, @@ -271,7 +269,6 @@ PySymtable_BuildObject(mod_ty mod, PyObject *filename, PyFutureFeatures *future)      }      st->st_top = st->st_cur; -    st->st_cur->ste_unoptimized = OPT_TOPLEVEL;      switch (mod->kind) {      case Module_kind:          seq = mod->v.Module.body; @@ -1245,21 +1242,9 @@ symtable_visit_stmt(struct symtable *st, stmt_ty s)          break;      case Import_kind:          VISIT_SEQ(st, alias, s->v.Import.names); -        /* XXX Don't have the lineno available inside -           visit_alias */ -        if (st->st_cur->ste_unoptimized && !st->st_cur->ste_opt_lineno) { -            st->st_cur->ste_opt_lineno = s->lineno; -            st->st_cur->ste_opt_col_offset = s->col_offset; -        }          break;      case ImportFrom_kind:          VISIT_SEQ(st, alias, s->v.ImportFrom.names); -        /* XXX Don't have the lineno available inside -           visit_alias */ -        if (st->st_cur->ste_unoptimized && !st->st_cur->ste_opt_lineno) { -            st->st_cur->ste_opt_lineno = s->lineno; -            st->st_cur->ste_opt_col_offset = s->col_offset; -        }          break;      case Global_kind: {          int i; @@ -1615,7 +1600,6 @@ symtable_visit_alias(struct symtable *st, alias_ty a)              Py_DECREF(store_name);              return 0;          } -        st->st_cur->ste_unoptimized |= OPT_IMPORT_STAR;          Py_DECREF(store_name);          return 1;      } | 
