diff options
Diffstat (limited to 'Python/bltinmodule.c')
| -rw-r--r-- | Python/bltinmodule.c | 113 | 
1 files changed, 56 insertions, 57 deletions
| diff --git a/Python/bltinmodule.c b/Python/bltinmodule.c index 9f5db2a..be14560 100644 --- a/Python/bltinmodule.c +++ b/Python/bltinmodule.c @@ -145,7 +145,7 @@ builtin___build_class__(PyObject *self, PyObject *args, PyObject *kwds)      if (prep == NULL) {          if (PyErr_ExceptionMatches(PyExc_AttributeError)) {              PyErr_Clear(); -            ns = PyDict_New(); +            ns = PyODict_New();          }          else {              Py_DECREF(meta); @@ -155,16 +155,8 @@ builtin___build_class__(PyObject *self, PyObject *args, PyObject *kwds)          }      }      else { -        PyObject *pargs = PyTuple_Pack(2, name, bases); -        if (pargs == NULL) { -            Py_DECREF(prep); -            Py_DECREF(meta); -            Py_XDECREF(mkw); -            Py_DECREF(bases); -            return NULL; -        } -        ns = PyEval_CallObjectWithKeywords(prep, pargs, mkw); -        Py_DECREF(pargs); +        PyObject *pargs[2] = {name, bases}; +        ns = _PyObject_FastCallDict(prep, pargs, 2, mkw);          Py_DECREF(prep);      }      if (ns == NULL) { @@ -177,12 +169,8 @@ builtin___build_class__(PyObject *self, PyObject *args, PyObject *kwds)                               NULL, 0, NULL, 0, NULL, 0, NULL,                               PyFunction_GET_CLOSURE(func));      if (cell != NULL) { -        PyObject *margs; -        margs = PyTuple_Pack(3, name, bases, ns); -        if (margs != NULL) { -            cls = PyEval_CallObjectWithKeywords(meta, margs, mkw); -            Py_DECREF(margs); -        } +        PyObject *margs[3] = {name, bases, ns}; +        cls = _PyObject_FastCallDict(meta, margs, 3, mkw);          if (cls != NULL && PyCell_Check(cell))              PyCell_Set(cell, cls);          Py_DECREF(cell); @@ -331,7 +319,7 @@ builtin_any(PyObject *module, PyObject *iterable)              Py_DECREF(it);              return NULL;          } -        if (cmp == 1) { +        if (cmp > 0) {              Py_DECREF(it);              Py_RETURN_TRUE;          } @@ -469,6 +457,7 @@ filter_next(filterobject *lz)      PyObject *it = lz->it;      long ok;      PyObject *(*iternext)(PyObject *); +    int checktrue = lz->func == Py_None || lz->func == (PyObject *)&PyBool_Type;      iternext = *Py_TYPE(it)->tp_iternext;      for (;;) { @@ -476,12 +465,11 @@ filter_next(filterobject *lz)          if (item == NULL)              return NULL; -        if (lz->func == Py_None || lz->func == (PyObject *)&PyBool_Type) { +        if (checktrue) {              ok = PyObject_IsTrue(item);          } else {              PyObject *good; -            good = PyObject_CallFunctionObjArgs(lz->func, -                                                item, NULL); +            good = PyObject_CallFunctionObjArgs(lz->func, item, NULL);              if (good == NULL) {                  Py_DECREF(item);                  return NULL; @@ -1168,26 +1156,43 @@ map_traverse(mapobject *lz, visitproc visit, void *arg)  static PyObject *  map_next(mapobject *lz)  { -    PyObject *val; -    PyObject *argtuple; -    PyObject *result; -    Py_ssize_t numargs, i; +    PyObject *small_stack[5]; +    PyObject **stack; +    Py_ssize_t niters, nargs, i; +    PyObject *result = NULL; -    numargs = PyTuple_Size(lz->iters); -    argtuple = PyTuple_New(numargs); -    if (argtuple == NULL) -        return NULL; +    niters = PyTuple_GET_SIZE(lz->iters); +    if (niters <= (Py_ssize_t)Py_ARRAY_LENGTH(small_stack)) { +        stack = small_stack; +    } +    else { +        stack = PyMem_Malloc(niters * sizeof(stack[0])); +        if (stack == NULL) { +            PyErr_NoMemory(); +            return NULL; +        } +    } -    for (i=0 ; i<numargs ; i++) { -        val = PyIter_Next(PyTuple_GET_ITEM(lz->iters, i)); +    nargs = 0; +    for (i=0; i < niters; i++) { +        PyObject *it = PyTuple_GET_ITEM(lz->iters, i); +        PyObject *val = Py_TYPE(it)->tp_iternext(it);          if (val == NULL) { -            Py_DECREF(argtuple); -            return NULL; +            goto exit;          } -        PyTuple_SET_ITEM(argtuple, i, val); +        stack[i] = val; +        nargs++; +    } + +    result = _PyObject_FastCall(lz->func, stack, nargs); + +exit: +    for (i=0; i < nargs; i++) { +        Py_DECREF(stack[i]); +    } +    if (stack != small_stack) { +        PyMem_Free(stack);      } -    result = PyObject_Call(lz->func, argtuple, NULL); -    Py_DECREF(argtuple);      return result;  } @@ -1779,7 +1784,7 @@ builtin_print(PyObject *self, PyObject *args, PyObject *kwds)          if (do_flush == -1)              return NULL;          else if (do_flush) { -            tmp = _PyObject_CallMethodId(file, &PyId_flush, ""); +            tmp = _PyObject_CallMethodId(file, &PyId_flush, NULL);              if (tmp == NULL)                  return NULL;              else @@ -1845,7 +1850,7 @@ builtin_input_impl(PyObject *module, PyObject *prompt)      }      /* First of all, flush stderr */ -    tmp = _PyObject_CallMethodId(ferr, &PyId_flush, ""); +    tmp = _PyObject_CallMethodId(ferr, &PyId_flush, NULL);      if (tmp == NULL)          PyErr_Clear();      else @@ -1854,7 +1859,7 @@ builtin_input_impl(PyObject *module, PyObject *prompt)      /* We should only use (GNU) readline if Python's sys.stdin and         sys.stdout are the same as C's stdin and stdout, because we         need to pass it those. */ -    tmp = _PyObject_CallMethodId(fin, &PyId_fileno, ""); +    tmp = _PyObject_CallMethodId(fin, &PyId_fileno, NULL);      if (tmp == NULL) {          PyErr_Clear();          tty = 0; @@ -1867,7 +1872,7 @@ builtin_input_impl(PyObject *module, PyObject *prompt)          tty = fd == fileno(stdin) && isatty(fd);      }      if (tty) { -        tmp = _PyObject_CallMethodId(fout, &PyId_fileno, ""); +        tmp = _PyObject_CallMethodId(fout, &PyId_fileno, NULL);          if (tmp == NULL) {              PyErr_Clear();              tty = 0; @@ -1902,7 +1907,7 @@ builtin_input_impl(PyObject *module, PyObject *prompt)          stdin_errors_str = _PyUnicode_AsString(stdin_errors);          if (!stdin_encoding_str || !stdin_errors_str)              goto _readline_errors; -        tmp = _PyObject_CallMethodId(fout, &PyId_flush, ""); +        tmp = _PyObject_CallMethodId(fout, &PyId_flush, NULL);          if (tmp == NULL)              PyErr_Clear();          else @@ -1929,9 +1934,8 @@ builtin_input_impl(PyObject *module, PyObject *prompt)              Py_CLEAR(stringpo);              if (po == NULL)                  goto _readline_errors; -            promptstr = PyBytes_AsString(po); -            if (promptstr == NULL) -                goto _readline_errors; +            assert(PyBytes_Check(po)); +            promptstr = PyBytes_AS_STRING(po);          }          else {              po = NULL; @@ -1983,7 +1987,7 @@ builtin_input_impl(PyObject *module, PyObject *prompt)          if (PyFile_WriteObject(prompt, fout, Py_PRINT_RAW) != 0)              return NULL;      } -    tmp = _PyObject_CallMethodId(fout, &PyId_flush, ""); +    tmp = _PyObject_CallMethodId(fout, &PyId_flush, NULL);      if (tmp == NULL)          PyErr_Clear();      else @@ -2087,10 +2091,11 @@ PyDoc_STRVAR(builtin_sorted__doc__,  static PyObject *  builtin_sorted(PyObject *self, PyObject *args, PyObject *kwds)  { -    PyObject *newlist, *v, *seq, *keyfunc=NULL, *newargs; +    PyObject *newlist, *v, *seq, *keyfunc=NULL, **newargs;      PyObject *callable;      static char *kwlist[] = {"iterable", "key", "reverse", 0};      int reverse; +    Py_ssize_t nargs;      /* args 1-3 should match listsort in Objects/listobject.c */      if (!PyArg_ParseTupleAndKeywords(args, kwds, "O|Oi:sorted", @@ -2107,15 +2112,9 @@ builtin_sorted(PyObject *self, PyObject *args, PyObject *kwds)          return NULL;      } -    newargs = PyTuple_GetSlice(args, 1, 4); -    if (newargs == NULL) { -        Py_DECREF(newlist); -        Py_DECREF(callable); -        return NULL; -    } - -    v = PyObject_Call(callable, newargs, kwds); -    Py_DECREF(newargs); +    newargs = &PyTuple_GET_ITEM(args, 1); +    nargs = PyTuple_GET_SIZE(args) - 1; +    v = _PyObject_FastCallDict(callable, newargs, nargs, kwds);      Py_DECREF(callable);      if (v == NULL) {          Py_DECREF(newlist); @@ -2710,10 +2709,10 @@ _PyBuiltin_Init(void)      SETBUILTIN("zip",                   &PyZip_Type);      debug = PyBool_FromLong(Py_OptimizeFlag == 0);      if (PyDict_SetItemString(dict, "__debug__", debug) < 0) { -        Py_XDECREF(debug); +        Py_DECREF(debug);          return NULL;      } -    Py_XDECREF(debug); +    Py_DECREF(debug);      return mod;  #undef ADD_TO_ALL | 
