diff options
Diffstat (limited to 'Python/compile.c')
| -rw-r--r-- | Python/compile.c | 537 | 
1 files changed, 332 insertions, 205 deletions
| diff --git a/Python/compile.c b/Python/compile.c index 6d66255..ff62487 100644 --- a/Python/compile.c +++ b/Python/compile.c @@ -94,6 +94,7 @@ enum {      COMPILER_SCOPE_MODULE,      COMPILER_SCOPE_CLASS,      COMPILER_SCOPE_FUNCTION, +    COMPILER_SCOPE_LAMBDA,      COMPILER_SCOPE_COMPREHENSION,  }; @@ -119,8 +120,8 @@ struct compiler_unit {      PyObject *u_private;        /* for private name mangling */ -    int u_argcount;        /* number of arguments for block */ -    int u_kwonlyargcount; /* number of keyword only arguments for block */ +    Py_ssize_t u_argcount;        /* number of arguments for block */ +    Py_ssize_t u_kwonlyargcount; /* number of keyword only arguments for block */      /* Pointer to the most recently allocated block.  By following b_list         members, you can reach all early allocated blocks. */      basicblock *u_blocks; @@ -149,8 +150,7 @@ handled by the symbol analysis pass.  */  struct compiler { -    const char *c_filename; -    PyObject *c_filename_obj; +    PyObject *c_filename;      struct symtable *c_st;      PyFutureFeatures *c_future; /* pointer to module's __future__ */      PyCompilerFlags *c_flags; @@ -170,7 +170,7 @@ static basicblock *compiler_new_block(struct compiler *);  static int compiler_next_instr(struct compiler *, basicblock *);  static int compiler_addop(struct compiler *, int);  static int compiler_addop_o(struct compiler *, int, PyObject *, PyObject *); -static int compiler_addop_i(struct compiler *, int, int); +static int compiler_addop_i(struct compiler *, int, Py_ssize_t);  static int compiler_addop_j(struct compiler *, int, basicblock *, int);  static basicblock *compiler_use_new_block(struct compiler *);  static int compiler_error(struct compiler *, const char *); @@ -195,17 +195,18 @@ static int inplace_binop(struct compiler *, operator_ty);  static int expr_constant(struct compiler *, expr_ty);  static int compiler_with(struct compiler *, stmt_ty, int); -static int compiler_call_helper(struct compiler *c, int n, +static int compiler_call_helper(struct compiler *c, Py_ssize_t n,                                  asdl_seq *args,                                  asdl_seq *keywords,                                  expr_ty starargs,                                  expr_ty kwargs);  static int compiler_try_except(struct compiler *, stmt_ty); +static int compiler_set_qualname(struct compiler *);  static PyCodeObject *assemble(struct compiler *, int addNone);  static PyObject *__doc__; -#define COMPILER_CAPSULE_NAME_COMPILER_UNIT "compile.c compiler unit" +#define CAPSULE_NAME "compile.c compiler unit"  PyObject *  _Py_Mangle(PyObject *privateobj, PyObject *ident) @@ -288,8 +289,8 @@ compiler_init(struct compiler *c)  }  PyCodeObject * -PyAST_CompileEx(mod_ty mod, const char *filename, PyCompilerFlags *flags, -                int optimize, PyArena *arena) +PyAST_CompileObject(mod_ty mod, PyObject *filename, PyCompilerFlags *flags, +                   int optimize, PyArena *arena)  {      struct compiler c;      PyCodeObject *co = NULL; @@ -304,12 +305,10 @@ PyAST_CompileEx(mod_ty mod, const char *filename, PyCompilerFlags *flags,      if (!compiler_init(&c))          return NULL; +    Py_INCREF(filename);      c.c_filename = filename; -    c.c_filename_obj = PyUnicode_DecodeFSDefault(filename); -    if (!c.c_filename_obj) -        goto finally;      c.c_arena = arena; -    c.c_future = PyFuture_FromAST(mod, filename); +    c.c_future = PyFuture_FromASTObject(mod, filename);      if (c.c_future == NULL)          goto finally;      if (!flags) { @@ -323,7 +322,7 @@ PyAST_CompileEx(mod_ty mod, const char *filename, PyCompilerFlags *flags,      c.c_optimize = (optimize == -1) ? Py_OptimizeFlag : optimize;      c.c_nestlevel = 0; -    c.c_st = PySymtable_Build(mod, filename, c.c_future); +    c.c_st = PySymtable_BuildObject(mod, filename, c.c_future);      if (c.c_st == NULL) {          if (!PyErr_Occurred())              PyErr_SetString(PyExc_SystemError, "no symtable"); @@ -339,6 +338,21 @@ PyAST_CompileEx(mod_ty mod, const char *filename, PyCompilerFlags *flags,  }  PyCodeObject * +PyAST_CompileEx(mod_ty mod, const char *filename_str, PyCompilerFlags *flags, +                int optimize, PyArena *arena) +{ +    PyObject *filename; +    PyCodeObject *co; +    filename = PyUnicode_DecodeFSDefault(filename_str); +    if (filename == NULL) +        return NULL; +    co = PyAST_CompileObject(mod, filename, flags, optimize, arena); +    Py_DECREF(filename); +    return co; + +} + +PyCodeObject *  PyNode_Compile(struct _node *n, const char *filename)  {      PyCodeObject *co = NULL; @@ -360,8 +374,7 @@ compiler_free(struct compiler *c)          PySymtable_Free(c->c_st);      if (c->c_future)          PyObject_Free(c->c_future); -    if (c->c_filename_obj) -        Py_DECREF(c->c_filename_obj); +    Py_XDECREF(c->c_filename);      Py_DECREF(c->c_stack);  } @@ -375,7 +388,7 @@ list2dict(PyObject *list)      n = PyList_Size(list);      for (i = 0; i < n; i++) { -        v = PyLong_FromLong(i); +        v = PyLong_FromSsize_t(i);          if (!v) {              Py_DECREF(dict);              return NULL; @@ -403,7 +416,7 @@ each key.  */  static PyObject * -dictbytype(PyObject *src, int scope_type, int flag, int offset) +dictbytype(PyObject *src, int scope_type, int flag, Py_ssize_t offset)  {      Py_ssize_t i = offset, scope, num_keys, key_i;      PyObject *k, *v, *dest = PyDict_New(); @@ -437,7 +450,7 @@ dictbytype(PyObject *src, int scope_type, int flag, int offset)          scope = (vi >> SCOPE_OFFSET) & SCOPE_MASK;          if (scope == scope_type || vi & flag) { -            PyObject *tuple, *item = PyLong_FromLong(i); +            PyObject *tuple, *item = PyLong_FromSsize_t(i);              if (item == NULL) {                  Py_DECREF(sorted_keys);                  Py_DECREF(dest); @@ -535,6 +548,37 @@ compiler_enter_scope(struct compiler *c, identifier name,          compiler_unit_free(u);          return 0;      } +    if (u->u_ste->ste_needs_class_closure) { +        /* Cook up an implicit __class__ cell. */ +        _Py_IDENTIFIER(__class__); +        PyObject *tuple, *name, *zero; +        int res; +        assert(u->u_scope_type == COMPILER_SCOPE_CLASS); +        assert(PyDict_Size(u->u_cellvars) == 0); +        name = _PyUnicode_FromId(&PyId___class__); +        if (!name) { +            compiler_unit_free(u); +            return 0; +        } +        tuple = PyTuple_Pack(2, name, Py_TYPE(name)); +        if (!tuple) { +            compiler_unit_free(u); +            return 0; +        } +        zero = PyLong_FromLong(0); +        if (!zero) { +            Py_DECREF(tuple); +            compiler_unit_free(u); +            return 0; +        } +        res = PyDict_SetItem(u->u_cellvars, tuple, zero); +        Py_DECREF(tuple); +        Py_DECREF(zero); +        if (res < 0) { +            compiler_unit_free(u); +            return 0; +        } +    }      u->u_freevars = dictbytype(u->u_ste->ste_symbols, FREE, DEF_FREE_CLASS,                                 PyDict_Size(u->u_cellvars)); @@ -564,7 +608,7 @@ compiler_enter_scope(struct compiler *c, identifier name,      /* Push the old compiler_unit on the stack. */      if (c->u) { -        PyObject *capsule = PyCapsule_New(c->u, COMPILER_CAPSULE_NAME_COMPILER_UNIT, NULL); +        PyObject *capsule = PyCapsule_New(c->u, CAPSULE_NAME, NULL);          if (!capsule || PyList_Append(c->c_stack, capsule) < 0) {              Py_XDECREF(capsule);              compiler_unit_free(u); @@ -580,13 +624,18 @@ compiler_enter_scope(struct compiler *c, identifier name,      if (compiler_use_new_block(c) == NULL)          return 0; +    if (u->u_scope_type != COMPILER_SCOPE_MODULE) { +        if (!compiler_set_qualname(c)) +            return 0; +    } +      return 1;  }  static void  compiler_exit_scope(struct compiler *c)  { -    int n; +    Py_ssize_t n;      PyObject *capsule;      c->c_nestlevel--; @@ -595,7 +644,7 @@ compiler_exit_scope(struct compiler *c)      n = PyList_GET_SIZE(c->c_stack) - 1;      if (n >= 0) {          capsule = PyList_GET_ITEM(c->c_stack, n); -        c->u = (struct compiler_unit *)PyCapsule_GetPointer(capsule, COMPILER_CAPSULE_NAME_COMPILER_UNIT); +        c->u = (struct compiler_unit *)PyCapsule_GetPointer(capsule, CAPSULE_NAME);          assert(c->u);          /* we are deleting from a list so this really shouldn't fail */          if (PySequence_DelItem(c->c_stack, n) < 0) @@ -607,57 +656,77 @@ compiler_exit_scope(struct compiler *c)  } -static PyObject * -compiler_scope_qualname(struct compiler *c) +static int +compiler_set_qualname(struct compiler *c)  { -    Py_ssize_t stack_size, i;      _Py_static_string(dot, "."); -    _Py_static_string(locals, "<locals>"); -    struct compiler_unit *u; -    PyObject *capsule, *name, *seq, *dot_str, *locals_str; +    _Py_static_string(dot_locals, ".<locals>"); +    Py_ssize_t stack_size; +    struct compiler_unit *u = c->u; +    PyObject *name, *base, *dot_str, *dot_locals_str; -    u = c->u; -    if (u->u_qualname != NULL) { -        Py_INCREF(u->u_qualname); -        return u->u_qualname; -    } +    base = NULL; +    stack_size = PyList_GET_SIZE(c->c_stack); +    assert(stack_size >= 1); +    if (stack_size > 1) { +        int scope, force_global = 0; +        struct compiler_unit *parent; +        PyObject *mangled, *capsule; + +        capsule = PyList_GET_ITEM(c->c_stack, stack_size - 1); +        parent = (struct compiler_unit *)PyCapsule_GetPointer(capsule, CAPSULE_NAME); +        assert(parent); + +        if (u->u_scope_type == COMPILER_SCOPE_FUNCTION || u->u_scope_type == COMPILER_SCOPE_CLASS) { +            assert(u->u_name); +            mangled = _Py_Mangle(parent->u_private, u->u_name); +            if (!mangled) +                return 0; +            scope = PyST_GetScope(parent->u_ste, mangled); +            Py_DECREF(mangled); +            assert(scope != GLOBAL_IMPLICIT); +            if (scope == GLOBAL_EXPLICIT) +                force_global = 1; +        } -    seq = PyList_New(0); -    if (seq == NULL) -        return NULL; +        if (!force_global) { +            if (parent->u_scope_type == COMPILER_SCOPE_FUNCTION +                || parent->u_scope_type == COMPILER_SCOPE_LAMBDA) { +                dot_locals_str = _PyUnicode_FromId(&dot_locals); +                if (dot_locals_str == NULL) +                    return 0; +                base = PyUnicode_Concat(parent->u_qualname, dot_locals_str); +                if (base == NULL) +                    return 0; +            } +            else { +                Py_INCREF(parent->u_qualname); +                base = parent->u_qualname; +            } +        } +    } -    stack_size = PyList_GET_SIZE(c->c_stack); -    for (i = 0; i < stack_size; i++) { -        capsule = PyList_GET_ITEM(c->c_stack, i); -        u = (struct compiler_unit *)PyCapsule_GetPointer(capsule, COMPILER_CAPSULE_NAME_COMPILER_UNIT); -        assert(u); -        if (u->u_scope_type == COMPILER_SCOPE_MODULE) -            continue; -        if (PyList_Append(seq, u->u_name)) -            goto _error; -        if (u->u_scope_type == COMPILER_SCOPE_FUNCTION) { -            locals_str = _PyUnicode_FromId(&locals); -            if (locals_str == NULL) -                goto _error; -            if (PyList_Append(seq, locals_str)) -                goto _error; +    if (base != NULL) { +        dot_str = _PyUnicode_FromId(&dot); +        if (dot_str == NULL) { +            Py_DECREF(base); +            return 0;          } +        name = PyUnicode_Concat(base, dot_str); +        Py_DECREF(base); +        if (name == NULL) +            return 0; +        PyUnicode_Append(&name, u->u_name); +        if (name == NULL) +            return 0; +    } +    else { +        Py_INCREF(u->u_name); +        name = u->u_name;      } -    u = c->u; -    if (PyList_Append(seq, u->u_name)) -        goto _error; -    dot_str = _PyUnicode_FromId(&dot); -    if (dot_str == NULL) -        goto _error; -    name = PyUnicode_Join(dot_str, seq); -    Py_DECREF(seq);      u->u_qualname = name; -    Py_XINCREF(name); -    return name; -_error: -    Py_XDECREF(seq); -    return NULL; +    return 1;  }  /* Allocate a new block and return a pointer to it. @@ -784,8 +853,8 @@ compiler_set_lineno(struct compiler *c, int off)      b->b_instr[off].i_lineno = c->u->u_lineno;  } -static int -opcode_stack_effect(int opcode, int oparg) +int +PyCompile_OpcodeStackEffect(int opcode, int oparg)  {      switch (opcode) {          case POP_TOP: @@ -862,8 +931,6 @@ opcode_stack_effect(int opcode, int oparg)              return 7;          case WITH_CLEANUP:              return -1; /* XXX Sometimes more */ -        case STORE_LOCALS: -            return -1;          case RETURN_VALUE:              return -1;          case IMPORT_STAR: @@ -970,17 +1037,16 @@ opcode_stack_effect(int opcode, int oparg)          case LOAD_CLOSURE:              return 1;          case LOAD_DEREF: +        case LOAD_CLASSDEREF:              return 1;          case STORE_DEREF:              return -1;          case DELETE_DEREF:              return 0;          default: -            fprintf(stderr, "opcode = %d\n", opcode); -            Py_FatalError("opcode_stack_effect()"); - +            return PY_INVALID_STACK_EFFECT;      } -    return 0; /* not reachable */ +    return PY_INVALID_STACK_EFFECT; /* not reachable */  }  /* Add an opcode with no argument. @@ -1006,7 +1072,7 @@ compiler_addop(struct compiler *c, int opcode)      return 1;  } -static int +static Py_ssize_t  compiler_add_o(struct compiler *c, PyObject *dict, PyObject *o)  {      PyObject *t, *v; @@ -1060,7 +1126,7 @@ compiler_add_o(struct compiler *c, PyObject *dict, PyObject *o)          if (PyErr_Occurred())              return -1;          arg = PyDict_Size(dict); -        v = PyLong_FromLong(arg); +        v = PyLong_FromSsize_t(arg);          if (!v) {              Py_DECREF(t);              return -1; @@ -1082,7 +1148,7 @@ static int  compiler_addop_o(struct compiler *c, int opcode, PyObject *dict,                       PyObject *o)  { -    int arg = compiler_add_o(c, dict, o); +    Py_ssize_t arg = compiler_add_o(c, dict, o);      if (arg < 0)          return 0;      return compiler_addop_i(c, opcode, arg); @@ -1092,7 +1158,7 @@ static int  compiler_addop_name(struct compiler *c, int opcode, PyObject *dict,                      PyObject *o)  { -    int arg; +    Py_ssize_t arg;      PyObject *mangled = _Py_Mangle(c->u->u_private, o);      if (!mangled)          return 0; @@ -1108,16 +1174,22 @@ compiler_addop_name(struct compiler *c, int opcode, PyObject *dict,  */  static int -compiler_addop_i(struct compiler *c, int opcode, int oparg) +compiler_addop_i(struct compiler *c, int opcode, Py_ssize_t oparg)  {      struct instr *i;      int off; + +    /* Integer arguments are limit to 16-bit. There is an extension for 32-bit +       integer arguments. */ +    assert((-2147483647-1) <= oparg); +    assert(oparg <= 2147483647); +      off = compiler_next_instr(c, c->u->u_curblock);      if (off < 0)          return 0;      i = &c->u->u_curblock->b_instr[off];      i->i_opcode = opcode; -    i->i_oparg = oparg; +    i->i_oparg = Py_SAFE_DOWNCAST(oparg, Py_ssize_t, int);      i->i_hasarg = 1;      compiler_set_lineno(c, off);      return 1; @@ -1330,19 +1402,22 @@ compiler_mod(struct compiler *c, mod_ty mod)  static int  get_ref_type(struct compiler *c, PyObject *name)  { -    int scope = PyST_GetScope(c->u->u_ste, name); +    int scope; +    if (c->u->u_scope_type == COMPILER_SCOPE_CLASS && +        !PyUnicode_CompareWithASCIIString(name, "__class__")) +        return CELL; +    scope = PyST_GetScope(c->u->u_ste, name);      if (scope == 0) {          char buf[350];          PyOS_snprintf(buf, sizeof(buf), -                      "unknown scope for %.100s in %.100s(%s) in %s\n" +                      "unknown scope for %.100s in %.100s(%s)\n"                        "symbols: %s\nlocals: %s\nglobals: %s", -                      PyBytes_AS_STRING(name), -                      PyBytes_AS_STRING(c->u->u_name), -                      PyObject_REPR(c->u->u_ste->ste_id), -                      c->c_filename, -                      PyObject_REPR(c->u->u_ste->ste_symbols), -                      PyObject_REPR(c->u->u_varnames), -                      PyObject_REPR(c->u->u_names) +                      PyUnicode_AsUTF8(name), +                      PyUnicode_AsUTF8(c->u->u_name), +                      PyUnicode_AsUTF8(PyObject_Repr(c->u->u_ste->ste_id)), +                      PyUnicode_AsUTF8(PyObject_Repr(c->u->u_ste->ste_symbols)), +                      PyUnicode_AsUTF8(PyObject_Repr(c->u->u_varnames)), +                      PyUnicode_AsUTF8(PyObject_Repr(c->u->u_names))          );          Py_FatalError(buf);      } @@ -1365,9 +1440,9 @@ compiler_lookup_arg(PyObject *dict, PyObject *name)  }  static int -compiler_make_closure(struct compiler *c, PyCodeObject *co, int args, PyObject *qualname) +compiler_make_closure(struct compiler *c, PyCodeObject *co, Py_ssize_t args, PyObject *qualname)  { -    int i, free = PyCode_GetNumFree(co); +    Py_ssize_t i, free = PyCode_GetNumFree(co);      if (qualname == NULL)          qualname = co->co_name; @@ -1399,11 +1474,11 @@ compiler_make_closure(struct compiler *c, PyCodeObject *co, int args, PyObject *              fprintf(stderr,                  "lookup %s in %s %d %d\n"                  "freevars of %s: %s\n", -                PyObject_REPR(name), -                PyBytes_AS_STRING(c->u->u_name), +                PyUnicode_AsUTF8(PyObject_Repr(name)), +                PyUnicode_AsUTF8(c->u->u_name),                  reftype, arg, -                _PyUnicode_AsString(co->co_name), -                PyObject_REPR(co->co_freevars)); +                PyUnicode_AsUTF8(co->co_name), +                PyUnicode_AsUTF8(PyObject_Repr(co->co_freevars)));              Py_FatalError("compiler_make_closure()");          }          ADDOP_I(c, LOAD_CLOSURE, arg); @@ -1457,9 +1532,16 @@ compiler_visit_argannotation(struct compiler *c, identifier id,      expr_ty annotation, PyObject *names)  {      if (annotation) { +        PyObject *mangled;          VISIT(c, expr, annotation); -        if (PyList_Append(names, id)) +        mangled = _Py_Mangle(c->u->u_private, id); +        if (!mangled) +            return -1; +        if (PyList_Append(names, mangled) < 0) { +            Py_DECREF(mangled);              return -1; +        } +        Py_DECREF(mangled);      }      return 0;  } @@ -1494,22 +1576,22 @@ compiler_visit_annotations(struct compiler *c, arguments_ty args,         */      static identifier return_str;      PyObject *names; -    int len; +    Py_ssize_t len;      names = PyList_New(0);      if (!names)          return -1;      if (compiler_visit_argannotations(c, args->args, names))          goto error; -    if (args->varargannotation && -        compiler_visit_argannotation(c, args->vararg, -                                     args->varargannotation, names)) +    if (args->vararg && args->vararg->annotation && +        compiler_visit_argannotation(c, args->vararg->arg, +                                     args->vararg->annotation, names))          goto error;      if (compiler_visit_argannotations(c, args->kwonlyargs, names))          goto error; -    if (args->kwargannotation && -        compiler_visit_argannotation(c, args->kwarg, -                                     args->kwargannotation, names)) +    if (args->kwarg && args->kwarg->annotation && +        compiler_visit_argannotation(c, args->kwarg->arg, +                                     args->kwarg->annotation, names))          goto error;      if (!return_str) { @@ -1531,7 +1613,7 @@ compiler_visit_annotations(struct compiler *c, arguments_ty args,      if (len) {          /* convert names to a tuple and place on stack */          PyObject *elt; -        int i; +        Py_ssize_t i;          PyObject *s = PyTuple_New(len);          if (!s)              goto error; @@ -1545,7 +1627,9 @@ compiler_visit_annotations(struct compiler *c, arguments_ty args,          len++; /* include the just-pushed tuple */      }      Py_DECREF(names); -    return len; + +    /* We just checked that len <= 65535, see above */ +    return Py_SAFE_DOWNCAST(len, Py_ssize_t, int);  error:      Py_DECREF(names); @@ -1561,13 +1645,16 @@ compiler_function(struct compiler *c, stmt_ty s)      expr_ty returns = s->v.FunctionDef.returns;      asdl_seq* decos = s->v.FunctionDef.decorator_list;      stmt_ty st; -    int i, n, docstring, kw_default_count = 0, arglength; +    Py_ssize_t i, n, arglength; +    int docstring, kw_default_count = 0;      int num_annotations;      assert(s->kind == FunctionDef_kind);      if (!compiler_decorators(c, decos))          return 0; +    if (args->defaults) +        VISIT_SEQ(c, expr, args->defaults);      if (args->kwonlyargs) {          int res = compiler_visit_kwonlydefaults(c, args->kwonlyargs,                                                  args->kw_defaults); @@ -1575,8 +1662,6 @@ compiler_function(struct compiler *c, stmt_ty s)              return 0;          kw_default_count = res;      } -    if (args->defaults) -        VISIT_SEQ(c, expr, args->defaults);      num_annotations = compiler_visit_annotations(c, args, returns);      if (num_annotations < 0)          return 0; @@ -1605,9 +1690,10 @@ compiler_function(struct compiler *c, stmt_ty s)          VISIT_IN_SCOPE(c, stmt, st);      }      co = assemble(c, 1); -    qualname = compiler_scope_qualname(c); +    qualname = c->u->u_qualname; +    Py_INCREF(qualname);      compiler_exit_scope(c); -    if (qualname == NULL || co == NULL) { +    if (co == NULL) {          Py_XDECREF(qualname);          Py_XDECREF(co);          return 0; @@ -1661,12 +1747,6 @@ compiler_class(struct compiler *c, stmt_ty s)          Py_INCREF(s->v.ClassDef.name);          Py_XDECREF(c->u->u_private);          c->u->u_private = s->v.ClassDef.name; -        /* force it to have one mandatory argument */ -        c->u->u_argcount = 1; -        /* load the first argument (__locals__) ... */ -        ADDOP_I(c, LOAD_FAST, 0); -        /* ... and store it into f_locals */ -        ADDOP_IN_SCOPE(c, STORE_LOCALS);          /* load (global) __name__ ... */          str = PyUnicode_InternFromString("__name__");          if (!str || !compiler_nameop(c, str, Load)) { @@ -1683,14 +1763,8 @@ compiler_class(struct compiler *c, stmt_ty s)              return 0;          }          Py_DECREF(str); -        /* store the __qualname__ */ -        str = compiler_scope_qualname(c); -        if (!str) { -            compiler_exit_scope(c); -            return 0; -        } -        ADDOP_O(c, LOAD_CONST, str, consts); -        Py_DECREF(str); +        assert(c->u->u_qualname); +        ADDOP_O(c, LOAD_CONST, c->u->u_qualname, consts);          str = PyUnicode_InternFromString("__qualname__");          if (!str || !compiler_nameop(c, str, Store)) {              Py_XDECREF(str); @@ -1703,24 +1777,28 @@ compiler_class(struct compiler *c, stmt_ty s)              compiler_exit_scope(c);              return 0;          } -        /* return the (empty) __class__ cell */ -        str = PyUnicode_InternFromString("__class__"); -        if (str == NULL) { -            compiler_exit_scope(c); -            return 0; -        } -        i = compiler_lookup_arg(c->u->u_cellvars, str); -        Py_DECREF(str); -        if (i == -1) { -            /* This happens when nobody references the cell */ -            PyErr_Clear(); -            /* Return None */ -            ADDOP_O(c, LOAD_CONST, Py_None, consts); -        } -        else { +        if (c->u->u_ste->ste_needs_class_closure) { +            /* return the (empty) __class__ cell */ +            str = PyUnicode_InternFromString("__class__"); +            if (str == NULL) { +                compiler_exit_scope(c); +                return 0; +            } +            i = compiler_lookup_arg(c->u->u_cellvars, str); +            Py_DECREF(str); +            if (i < 0) { +                compiler_exit_scope(c); +                return 0; +            } +            assert(i == 0);              /* Return the cell where to store __class__ */              ADDOP_I(c, LOAD_CLOSURE, i);          } +        else { +            assert(PyDict_Size(c->u->u_cellvars) == 0); +            /* This happens when nobody references the cell. Return None. */ +            ADDOP_O(c, LOAD_CONST, Py_None, consts); +        }          ADDOP_IN_SCOPE(c, RETURN_VALUE);          /* create the code object */          co = assemble(c, 1); @@ -1787,7 +1865,8 @@ compiler_lambda(struct compiler *c, expr_ty e)      PyCodeObject *co;      PyObject *qualname;      static identifier name; -    int kw_default_count = 0, arglength; +    int kw_default_count = 0; +    Py_ssize_t arglength;      arguments_ty args = e->v.Lambda.args;      assert(e->kind == Lambda_kind); @@ -1797,15 +1876,15 @@ compiler_lambda(struct compiler *c, expr_ty e)              return 0;      } +    if (args->defaults) +        VISIT_SEQ(c, expr, args->defaults);      if (args->kwonlyargs) {          int res = compiler_visit_kwonlydefaults(c, args->kwonlyargs,                                                  args->kw_defaults);          if (res < 0) return 0;          kw_default_count = res;      } -    if (args->defaults) -        VISIT_SEQ(c, expr, args->defaults); -    if (!compiler_enter_scope(c, name, COMPILER_SCOPE_FUNCTION, +    if (!compiler_enter_scope(c, name, COMPILER_SCOPE_LAMBDA,                                (void *)e, e->lineno))          return 0; @@ -1818,15 +1897,16 @@ compiler_lambda(struct compiler *c, expr_ty e)      c->u->u_kwonlyargcount = asdl_seq_LEN(args->kwonlyargs);      VISIT_IN_SCOPE(c, expr, e->v.Lambda.body);      if (c->u->u_ste->ste_generator) { -        ADDOP_IN_SCOPE(c, POP_TOP); +        co = assemble(c, 0);      }      else {          ADDOP_IN_SCOPE(c, RETURN_VALUE); +        co = assemble(c, 1);      } -    co = assemble(c, 1); -    qualname = compiler_scope_qualname(c); +    qualname = c->u->u_qualname; +    Py_INCREF(qualname);      compiler_exit_scope(c); -    if (qualname == NULL || co == NULL) +    if (co == NULL)          return 0;      arglength = asdl_seq_LEN(args->defaults); @@ -1949,10 +2029,9 @@ compiler_while(struct compiler *c, stmt_ty s)         if there is no else clause ?      */ -    if (constant == -1) { +    if (constant == -1)          compiler_use_next_block(c, anchor); -        ADDOP(c, POP_BLOCK); -    } +    ADDOP(c, POP_BLOCK);      compiler_pop_fblock(c, LOOP, loop);      if (orelse != NULL) /* what if orelse is just pass? */          VISIT_SEQ(c, stmt, s->v.While.orelse); @@ -2097,7 +2176,7 @@ static int  compiler_try_except(struct compiler *c, stmt_ty s)  {      basicblock *body, *orelse, *except, *end; -    int i, n; +    Py_ssize_t i, n;      body = compiler_new_block(c);      except = compiler_new_block(c); @@ -2263,7 +2342,7 @@ compiler_import(struct compiler *c, stmt_ty s)         module names.         XXX Perhaps change the representation to make this case simpler?       */ -    int i, n = asdl_seq_LEN(s->v.Import.names); +    Py_ssize_t i, n = asdl_seq_LEN(s->v.Import.names);      for (i = 0; i < n; i++) {          alias_ty alias = (alias_ty)asdl_seq_GET(s->v.Import.names, i); @@ -2288,8 +2367,11 @@ compiler_import(struct compiler *c, stmt_ty s)              identifier tmp = alias->name;              Py_ssize_t dot = PyUnicode_FindChar(                  alias->name, '.', 0, PyUnicode_GET_LENGTH(alias->name), 1); -            if (dot != -1) +            if (dot != -1) {                  tmp = PyUnicode_Substring(alias->name, 0, dot); +                if (tmp == NULL) +                    return 0; +            }              r = compiler_nameop(c, tmp, Store);              if (dot != -1) {                  Py_DECREF(tmp); @@ -2304,7 +2386,7 @@ compiler_import(struct compiler *c, stmt_ty s)  static int  compiler_from_import(struct compiler *c, stmt_ty s)  { -    int i, n = asdl_seq_LEN(s->v.ImportFrom.names); +    Py_ssize_t i, n = asdl_seq_LEN(s->v.ImportFrom.names);      PyObject *names = PyTuple_New(n);      PyObject *level; @@ -2380,6 +2462,7 @@ compiler_assert(struct compiler *c, stmt_ty s)  {      static PyObject *assertion_error = NULL;      basicblock *end; +    PyObject* msg;      if (c->c_optimize)          return 1; @@ -2390,11 +2473,17 @@ compiler_assert(struct compiler *c, stmt_ty s)      }      if (s->v.Assert.test->kind == Tuple_kind &&          asdl_seq_LEN(s->v.Assert.test->v.Tuple.elts) > 0) { -        const char* msg = -            "assertion is always true, perhaps remove parentheses?"; -        if (PyErr_WarnExplicit(PyExc_SyntaxWarning, msg, c->c_filename, -                               c->u->u_lineno, NULL, NULL) == -1) +        msg = PyUnicode_FromString("assertion is always true, " +                                   "perhaps remove parentheses?"); +        if (msg == NULL)              return 0; +        if (PyErr_WarnExplicitObject(PyExc_SyntaxWarning, msg, +                                     c->c_filename, c->u->u_lineno, +                                     NULL, NULL) == -1) { +            Py_DECREF(msg); +            return 0; +        } +        Py_DECREF(msg);      }      VISIT(c, expr, s->v.Assert.test);      end = compiler_new_block(c); @@ -2414,7 +2503,7 @@ compiler_assert(struct compiler *c, stmt_ty s)  static int  compiler_visit_stmt(struct compiler *c, stmt_ty s)  { -    int i, n; +    Py_ssize_t i, n;      /* Always assign a lineno to the next instruction for a stmt. */      c->u->u_lineno = s->lineno; @@ -2462,12 +2551,12 @@ compiler_visit_stmt(struct compiler *c, stmt_ty s)          if (s->v.Raise.exc) {              VISIT(c, expr, s->v.Raise.exc);              n++; -        if (s->v.Raise.cause) { -        VISIT(c, expr, s->v.Raise.cause); -        n++; -        } +            if (s->v.Raise.cause) { +                VISIT(c, expr, s->v.Raise.cause); +                n++; +            }          } -        ADDOP_I(c, RAISE_VARARGS, n); +        ADDOP_I(c, RAISE_VARARGS, (int)n);          break;      case Try_kind:          return compiler_try(c, s); @@ -2627,7 +2716,8 @@ inplace_binop(struct compiler *c, operator_ty op)  static int  compiler_nameop(struct compiler *c, identifier name, expr_context_ty ctx)  { -    int op, scope, arg; +    int op, scope; +    Py_ssize_t arg;      enum { OP_FAST, OP_GLOBAL, OP_DEREF, OP_NAME } optype;      PyObject *dict = c->u->u_names; @@ -2638,6 +2728,10 @@ compiler_nameop(struct compiler *c, identifier name, expr_context_ty ctx)      if (!mangled)          return 0; +    assert(PyUnicode_CompareWithASCIIString(name, "None") && +           PyUnicode_CompareWithASCIIString(name, "True") && +           PyUnicode_CompareWithASCIIString(name, "False")); +      op = 0;      optype = OP_NAME;      scope = PyST_GetScope(c->u->u_ste, mangled); @@ -2673,7 +2767,9 @@ compiler_nameop(struct compiler *c, identifier name, expr_context_ty ctx)      switch (optype) {      case OP_DEREF:          switch (ctx) { -        case Load: op = LOAD_DEREF; break; +        case Load: +            op = (c->u->u_ste->ste_type == ClassBlock) ? LOAD_CLASSDEREF : LOAD_DEREF; +            break;          case Store: op = STORE_DEREF; break;          case AugLoad:          case AugStore: @@ -2747,7 +2843,8 @@ static int  compiler_boolop(struct compiler *c, expr_ty e)  {      basicblock *end; -    int jumpi, i, n; +    int jumpi; +    Py_ssize_t i, n;      asdl_seq *s;      assert(e->kind == BoolOp_kind); @@ -2773,7 +2870,7 @@ compiler_boolop(struct compiler *c, expr_ty e)  static int  compiler_list(struct compiler *c, expr_ty e)  { -    int n = asdl_seq_LEN(e->v.List.elts); +    Py_ssize_t n = asdl_seq_LEN(e->v.List.elts);      if (e->v.List.ctx == Store) {          int i, seen_star = 0;          for (i = 0; i < n; i++) { @@ -2806,7 +2903,7 @@ compiler_list(struct compiler *c, expr_ty e)  static int  compiler_tuple(struct compiler *c, expr_ty e)  { -    int n = asdl_seq_LEN(e->v.Tuple.elts); +    Py_ssize_t n = asdl_seq_LEN(e->v.Tuple.elts);      if (e->v.Tuple.ctx == Store) {          int i, seen_star = 0;          for (i = 0; i < n; i++) { @@ -2839,7 +2936,7 @@ compiler_tuple(struct compiler *c, expr_ty e)  static int  compiler_compare(struct compiler *c, expr_ty e)  { -    int i, n; +    Py_ssize_t i, n;      basicblock *cleanup = NULL;      /* XXX the logic can be cleaned up for 1 or multiple comparisons */ @@ -2895,11 +2992,11 @@ compiler_call(struct compiler *c, expr_ty e)  /* shared code between compiler_call and compiler_class */  static int  compiler_call_helper(struct compiler *c, -                     int n, /* Args already pushed */ -             asdl_seq *args, -             asdl_seq *keywords, -             expr_ty starargs, -             expr_ty kwargs) +                     Py_ssize_t n, /* Args already pushed */ +                     asdl_seq *args, +                     asdl_seq *keywords, +                     expr_ty starargs, +                     expr_ty kwargs)  {      int code = 0; @@ -2960,7 +3057,7 @@ compiler_comprehension_generator(struct compiler *c,      comprehension_ty gen;      basicblock *start, *anchor, *skip, *if_cleanup; -    int i, n; +    Py_ssize_t i, n;      start = compiler_new_block(c);      skip = compiler_new_block(c); @@ -3085,9 +3182,10 @@ compiler_comprehension(struct compiler *c, expr_ty e, int type, identifier name,      }      co = assemble(c, 1); -    qualname = compiler_scope_qualname(c); +    qualname = c->u->u_qualname; +    Py_INCREF(qualname);      compiler_exit_scope(c); -    if (qualname == NULL || co == NULL) +    if (co == NULL)          goto error;      if (!compiler_make_closure(c, co, 0, qualname)) @@ -3197,12 +3295,18 @@ expr_constant(struct compiler *c, expr_ty e)      case Name_kind:          /* optimize away names that can't be reassigned */          id = PyUnicode_AsUTF8(e->v.Name.id); -        if (strcmp(id, "True") == 0) return 1; -        if (strcmp(id, "False") == 0) return 0; -        if (strcmp(id, "None") == 0) return 0; -        if (strcmp(id, "__debug__") == 0) -            return ! c->c_optimize; -        /* fall through */ +        if (id && strcmp(id, "__debug__") == 0) +            return !c->c_optimize; +        return -1; +    case NameConstant_kind: { +        PyObject *o = e->v.NameConstant.value; +        if (o == Py_None) +            return 0; +        else if (o == Py_True) +            return 1; +        else if (o == Py_False) +            return 0; +    }      default:          return -1;      } @@ -3226,9 +3330,9 @@ expr_constant(struct compiler *c, expr_ty e)         BLOCK     finally:         if an exception was raised: -       exc = copy of (exception, instance, traceback) +           exc = copy of (exception, instance, traceback)         else: -       exc = (None, None, None) +           exc = (None, None, None)         exit(*exc)   */  static int @@ -3292,7 +3396,7 @@ compiler_with(struct compiler *c, stmt_ty s, int pos)  static int  compiler_visit_expr(struct compiler *c, expr_ty e)  { -    int i, n; +    Py_ssize_t i, n;      /* If expr e has a different line number than the last expr/stmt,         set a new line number for the next instruction. @@ -3321,6 +3425,8 @@ compiler_visit_expr(struct compiler *c, expr_ty e)          return compiler_ifexp(c, e);      case Dict_kind:          n = asdl_seq_LEN(e->v.Dict.values); +        /* BUILD_MAP parameter is only used to preallocate the dictionary, +           it doesn't need to be exact */          ADDOP_I(c, BUILD_MAP, (n>0xFFFF ? 0xFFFF : n));          for (i = 0; i < n; i++) {              VISIT(c, expr, @@ -3378,6 +3484,9 @@ compiler_visit_expr(struct compiler *c, expr_ty e)      case Ellipsis_kind:          ADDOP_O(c, LOAD_CONST, Py_Ellipsis, consts);          break; +    case NameConstant_kind: +        ADDOP_O(c, LOAD_CONST, e->v.NameConstant.value, consts); +        break;      /* The following exprs can be assignment targets. */      case Attribute_kind:          if (e->v.Attribute.ctx != AugStore) @@ -3547,12 +3656,12 @@ compiler_error(struct compiler *c, const char *errstr)      PyObject *loc;      PyObject *u = NULL, *v = NULL; -    loc = PyErr_ProgramText(c->c_filename, c->u->u_lineno); +    loc = PyErr_ProgramTextObject(c->c_filename, c->u->u_lineno);      if (!loc) {          Py_INCREF(Py_None);          loc = Py_None;      } -    u = Py_BuildValue("(OiiO)", c->c_filename_obj, c->u->u_lineno, +    u = Py_BuildValue("(OiiO)", c->c_filename, c->u->u_lineno,                        c->u->u_col_offset, loc);      if (!u)          goto exit; @@ -3665,7 +3774,7 @@ compiler_visit_slice(struct compiler *c, slice_ty s, expr_context_ty ctx)      case ExtSlice_kind:          kindname = "extended slice";          if (ctx != AugStore) { -            int i, n = asdl_seq_LEN(s->v.ExtSlice.dims); +            Py_ssize_t i, n = asdl_seq_LEN(s->v.ExtSlice.dims);              for (i = 0; i < n; i++) {                  slice_ty sub = (slice_ty)asdl_seq_GET(                      s->v.ExtSlice.dims, i); @@ -3724,7 +3833,7 @@ dfs(struct compiler *c, basicblock *b, struct assembler *a)  static int  stackdepth_walk(struct compiler *c, basicblock *b, int depth, int maxdepth)  { -    int i, target_depth; +    int i, target_depth, effect;      struct instr *instr;      if (b->b_seen || b->b_startdepth >= depth)          return maxdepth; @@ -3732,7 +3841,13 @@ stackdepth_walk(struct compiler *c, basicblock *b, int depth, int maxdepth)      b->b_startdepth = depth;      for (i = 0; i < b->b_iused; i++) {          instr = &b->b_instr[i]; -        depth += opcode_stack_effect(instr->i_opcode, instr->i_oparg); +        effect = PyCompile_OpcodeStackEffect(instr->i_opcode, instr->i_oparg); +        if (effect == PY_INVALID_STACK_EFFECT) { +            fprintf(stderr, "opcode = %d\n", instr->i_opcode); +            Py_FatalError("PyCompile_OpcodeStackEffect()"); +        } +        depth += effect; +          if (depth > maxdepth)              maxdepth = depth;          assert(depth >= 0); /* invalid code or bug in stackdepth() */ @@ -3740,12 +3855,16 @@ stackdepth_walk(struct compiler *c, basicblock *b, int depth, int maxdepth)              target_depth = depth;              if (instr->i_opcode == FOR_ITER) {                  target_depth = depth-2; -            } else if (instr->i_opcode == SETUP_FINALLY || -                       instr->i_opcode == SETUP_EXCEPT) { +            } +            else if (instr->i_opcode == SETUP_FINALLY || +                     instr->i_opcode == SETUP_EXCEPT) {                  target_depth = depth+3;                  if (target_depth > maxdepth)                      maxdepth = target_depth;              } +            else if (instr->i_opcode == JUMP_IF_TRUE_OR_POP || +                     instr->i_opcode == JUMP_IF_FALSE_OR_POP) +                depth = depth - 1;              maxdepth = stackdepth_walk(c, instr->i_target,                                         target_depth, maxdepth);              if (instr->i_opcode == JUMP_ABSOLUTE || @@ -3790,7 +3909,7 @@ assemble_init(struct assembler *a, int nblocks, int firstlineno)      a->a_lnotab = PyBytes_FromStringAndSize(NULL, DEFAULT_LNOTAB_SIZE);      if (!a->a_lnotab)          return 0; -    if (nblocks > PY_SIZE_MAX / sizeof(basicblock *)) { +    if ((size_t)nblocks > PY_SIZE_MAX / sizeof(basicblock *)) {          PyErr_NoMemory();          return 0;      } @@ -3843,7 +3962,7 @@ static int  assemble_lnotab(struct assembler *a, struct instr *i)  {      int d_bytecode, d_lineno; -    int len; +    Py_ssize_t len;      unsigned char *lnotab;      d_bytecode = a->a_offset - a->a_lineno_off; @@ -4034,7 +4153,7 @@ assemble_jump_offsets(struct assembler *a, struct compiler *c)  }  static PyObject * -dict_keys_inorder(PyObject *dict, int offset) +dict_keys_inorder(PyObject *dict, Py_ssize_t offset)  {      PyObject *tuple, *k, *v;      Py_ssize_t i, pos = 0, size = PyDict_Size(dict); @@ -4059,10 +4178,10 @@ static int  compute_code_flags(struct compiler *c)  {      PySTEntryObject *ste = c->u->u_ste; -    int flags = 0, n; -    if (ste->ste_type != ModuleBlock) -        flags |= CO_NEWLOCALS; +    int flags = 0; +    Py_ssize_t n;      if (ste->ste_type == FunctionBlock) { +        flags |= CO_NEWLOCALS;          if (!ste->ste_unoptimized)              flags |= CO_OPTIMIZED;          if (ste->ste_nested) @@ -4084,9 +4203,9 @@ compute_code_flags(struct compiler *c)      if (n == 0) {          n = PyDict_Size(c->u->u_cellvars);          if (n < 0) -        return -1; +            return -1;          if (n == 0) { -        flags |= CO_NOFREE; +            flags |= CO_NOFREE;          }      } @@ -4105,7 +4224,10 @@ makecode(struct compiler *c, struct assembler *a)      PyObject *freevars = NULL;      PyObject *cellvars = NULL;      PyObject *bytecode = NULL; -    int nlocals, flags; +    Py_ssize_t nlocals; +    int nlocals_int; +    int flags; +    int argcount, kwonlyargcount;      tmp = dict_keys_inorder(c->u->u_consts, 0);      if (!tmp) @@ -4124,7 +4246,11 @@ makecode(struct compiler *c, struct assembler *a)      freevars = dict_keys_inorder(c->u->u_freevars, PyTuple_Size(cellvars));      if (!freevars)          goto error; +      nlocals = PyDict_Size(c->u->u_varnames); +    assert(nlocals < INT_MAX); +    nlocals_int = Py_SAFE_DOWNCAST(nlocals, Py_ssize_t, int); +      flags = compute_code_flags(c);      if (flags < 0)          goto error; @@ -4139,11 +4265,13 @@ makecode(struct compiler *c, struct assembler *a)      Py_DECREF(consts);      consts = tmp; -    co = PyCode_New(c->u->u_argcount, c->u->u_kwonlyargcount, -                    nlocals, stackdepth(c), flags, +    argcount = Py_SAFE_DOWNCAST(c->u->u_argcount, Py_ssize_t, int); +    kwonlyargcount = Py_SAFE_DOWNCAST(c->u->u_kwonlyargcount, Py_ssize_t, int); +    co = PyCode_New(argcount, kwonlyargcount, +                    nlocals_int, stackdepth(c), flags,                      bytecode, consts, names, varnames,                      freevars, cellvars, -                    c->c_filename_obj, c->u->u_name, +                    c->c_filename, c->u->u_name,                      c->u->u_firstlineno,                      a->a_lnotab);   error: @@ -4259,4 +4387,3 @@ PyAST_Compile(mod_ty mod, const char *filename, PyCompilerFlags *flags,      return PyAST_CompileEx(mod, filename, flags, -1, arena);  } - | 
