Commit 558689ca authored by Stefan Behnel's avatar Stefan Behnel

pypy: avoid borrowed references and improve error handling where it differs from CPython

parent d9a9663b
...@@ -7676,7 +7676,7 @@ class ClassCellInjectorNode(ExprNode): ...@@ -7676,7 +7676,7 @@ class ClassCellInjectorNode(ExprNode):
def generate_injection_code(self, code, classobj_cname): def generate_injection_code(self, code, classobj_cname):
if self.is_active: if self.is_active:
code.putln('__Pyx_CyFunction_InitClassCell(%s, %s);' % ( code.put_error_if_neg(self.pos, '__Pyx_CyFunction_InitClassCell(%s, %s)' % (
self.result(), classobj_cname)) self.result(), classobj_cname))
......
...@@ -245,17 +245,27 @@ __Pyx_CyFunction_get_code(__pyx_CyFunctionObject *op) ...@@ -245,17 +245,27 @@ __Pyx_CyFunction_get_code(__pyx_CyFunctionObject *op)
static int static int
__Pyx_CyFunction_init_defaults(__pyx_CyFunctionObject *op) { __Pyx_CyFunction_init_defaults(__pyx_CyFunctionObject *op) {
int result = 0;
PyObject *res = op->defaults_getter((PyObject *) op); PyObject *res = op->defaults_getter((PyObject *) op);
if (unlikely(!res)) if (unlikely(!res))
return -1; return -1;
// Cache result // Cache result
#if CYTHON_COMPILING_IN_CPYTHON
op->defaults_tuple = PyTuple_GET_ITEM(res, 0); op->defaults_tuple = PyTuple_GET_ITEM(res, 0);
Py_INCREF(op->defaults_tuple); Py_INCREF(op->defaults_tuple);
op->defaults_kwdict = PyTuple_GET_ITEM(res, 1); op->defaults_kwdict = PyTuple_GET_ITEM(res, 1);
Py_INCREF(op->defaults_kwdict); Py_INCREF(op->defaults_kwdict);
#else
op->defaults_tuple = PySequence_ITEM(res, 0);
if (unlikely(!op->defaults_tuple)) result = -1;
else {
op->defaults_kwdict = PySequence_ITEM(res, 1);
if (unlikely(!op->defaults_kwdict)) result = -1;
}
#endif
Py_DECREF(res); Py_DECREF(res);
return 0; return result;
} }
static int static int
...@@ -572,15 +582,15 @@ static PyObject * __Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject ...@@ -572,15 +582,15 @@ static PyObject * __Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject
switch (PyCFunction_GET_FLAGS(func) & ~(METH_CLASS | METH_STATIC | METH_COEXIST)) { switch (PyCFunction_GET_FLAGS(func) & ~(METH_CLASS | METH_STATIC | METH_COEXIST)) {
case METH_VARARGS: case METH_VARARGS:
if (likely(kw == NULL) || PyDict_Size(kw) == 0) if (likely(kw == NULL || PyDict_Size(kw) == 0))
return (*meth)(self, arg); return (*meth)(self, arg);
break; break;
case METH_VARARGS | METH_KEYWORDS: case METH_VARARGS | METH_KEYWORDS:
return (*(PyCFunctionWithKeywords)meth)(self, arg, kw); return (*(PyCFunctionWithKeywords)meth)(self, arg, kw);
case METH_NOARGS: case METH_NOARGS:
if (likely(kw == NULL) || PyDict_Size(kw) == 0) { if (likely(kw == NULL || PyDict_Size(kw) == 0)) {
size = PyTuple_GET_SIZE(arg); size = PyTuple_GET_SIZE(arg);
if (size == 0) if (likely(size == 0))
return (*meth)(self, NULL); return (*meth)(self, NULL);
PyErr_Format(PyExc_TypeError, PyErr_Format(PyExc_TypeError,
"%.200s() takes no arguments (%" CYTHON_FORMAT_SSIZE_T "d given)", "%.200s() takes no arguments (%" CYTHON_FORMAT_SSIZE_T "d given)",
...@@ -589,10 +599,15 @@ static PyObject * __Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject ...@@ -589,10 +599,15 @@ static PyObject * __Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject
} }
break; break;
case METH_O: case METH_O:
if (likely(kw == NULL) || PyDict_Size(kw) == 0) { if (likely(kw == NULL || PyDict_Size(kw) == 0)) {
size = PyTuple_GET_SIZE(arg); size = PyTuple_GET_SIZE(arg);
if (size == 1) if (likely(size == 1)) {
return (*meth)(self, PyTuple_GET_ITEM(arg, 0)); PyObject *result, *arg0 = PySequence_ITEM(arg, 0);
if (unlikely(!arg0)) return NULL;
result = (*meth)(self, arg0);
Py_DECREF(arg0);
return result;
}
PyErr_Format(PyExc_TypeError, PyErr_Format(PyExc_TypeError,
"%.200s() takes exactly one argument (%" CYTHON_FORMAT_SSIZE_T "d given)", "%.200s() takes exactly one argument (%" CYTHON_FORMAT_SSIZE_T "d given)",
f->m_ml->ml_name, size); f->m_ml->ml_name, size);
...@@ -720,21 +735,30 @@ static CYTHON_INLINE void __Pyx_CyFunction_SetAnnotationsDict(PyObject *func, Py ...@@ -720,21 +735,30 @@ static CYTHON_INLINE void __Pyx_CyFunction_SetAnnotationsDict(PyObject *func, Py
} }
//////////////////// CyFunctionClassCell.proto //////////////////// //////////////////// CyFunctionClassCell.proto ////////////////////
static CYTHON_INLINE void __Pyx_CyFunction_InitClassCell(PyObject *cyfunctions, static CYTHON_INLINE int __Pyx_CyFunction_InitClassCell(PyObject *cyfunctions, PyObject *classobj);
PyObject *classobj);
//////////////////// CyFunctionClassCell //////////////////// //////////////////// CyFunctionClassCell ////////////////////
//@requires: CythonFunction //@requires: CythonFunction
static CYTHON_INLINE void __Pyx_CyFunction_InitClassCell(PyObject *cyfunctions, PyObject *classobj) { static CYTHON_INLINE int __Pyx_CyFunction_InitClassCell(PyObject *cyfunctions, PyObject *classobj) {
int i; Py_ssize_t i, count = PyList_GET_SIZE(cyfunctions);
for (i = 0; i < PyList_GET_SIZE(cyfunctions); i++) { for (i = 0; i < count; i++) {
__pyx_CyFunctionObject *m = __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *)
(__pyx_CyFunctionObject *) PyList_GET_ITEM(cyfunctions, i); #if CYTHON_COMPILING_IN_CPYTHON
m->func_classobj = classobj; PyList_GET_ITEM(cyfunctions, i);
#else
PySequence_ITEM(cyfunctions, i);
if (unlikely(!m))
return -1;
#endif
Py_INCREF(classobj); Py_INCREF(classobj);
m->func_classobj = classobj;
#if !CYTHON_COMPILING_IN_CPYTHON
Py_DECREF((PyObject*)m);
#endif
} }
return 0;
} }
//////////////////// FusedFunction.proto //////////////////// //////////////////// FusedFunction.proto ////////////////////
...@@ -886,9 +910,15 @@ __pyx_FusedFunction_getitem(__pyx_FusedFunctionObject *self, PyObject *idx) ...@@ -886,9 +910,15 @@ __pyx_FusedFunction_getitem(__pyx_FusedFunctionObject *self, PyObject *idx)
return NULL; return NULL;
for (i = 0; i < n; i++) { for (i = 0; i < n; i++) {
#if CYTHON_COMPILING_IN_CPYTHON
PyObject *item = PyTuple_GET_ITEM(idx, i); PyObject *item = PyTuple_GET_ITEM(idx, i);
#else
PyObject *item = PySequence_ITEM(idx, i);
#endif
string = _obj_to_str(item); string = _obj_to_str(item);
#if !CYTHON_COMPILING_IN_CPYTHON
Py_DECREF(item);
#endif
if (!string || PyList_Append(list, string) < 0) if (!string || PyList_Append(list, string) < 0)
goto __pyx_err; goto __pyx_err;
...@@ -998,12 +1028,19 @@ __pyx_FusedFunction_call(PyObject *func, PyObject *args, PyObject *kw) ...@@ -998,12 +1028,19 @@ __pyx_FusedFunction_call(PyObject *func, PyObject *args, PyObject *kw)
return NULL; return NULL;
self = binding_func->self; self = binding_func->self;
#if !CYTHON_COMPILING_IN_CPYTHON
Py_INCREF(self);
#endif
Py_INCREF(self); Py_INCREF(self);
PyTuple_SET_ITEM(new_args, 0, self); PyTuple_SET_ITEM(new_args, 0, self);
for (i = 0; i < argc; i++) { for (i = 0; i < argc; i++) {
#if CYTHON_COMPILING_IN_CPYTHON
PyObject *item = PyTuple_GET_ITEM(args, i); PyObject *item = PyTuple_GET_ITEM(args, i);
Py_INCREF(item); Py_INCREF(item);
#else
PyObject *item = PySequence_ITEM(args, i); if (unlikely(!item)) goto bad;
#endif
PyTuple_SET_ITEM(new_args, i + 1, item); PyTuple_SET_ITEM(new_args, i + 1, item);
} }
...@@ -1014,7 +1051,11 @@ __pyx_FusedFunction_call(PyObject *func, PyObject *args, PyObject *kw) ...@@ -1014,7 +1051,11 @@ __pyx_FusedFunction_call(PyObject *func, PyObject *args, PyObject *kw)
PyErr_SetString(PyExc_TypeError, "Need at least one argument, 0 given."); PyErr_SetString(PyExc_TypeError, "Need at least one argument, 0 given.");
return NULL; return NULL;
} }
#if CYTHON_COMPILING_IN_CPYTHON
self = PyTuple_GET_ITEM(args, 0); self = PyTuple_GET_ITEM(args, 0);
#else
self = PySequence_ITEM(args, 0); if (unlikely(!self)) return NULL;
#endif
} }
if (self && !is_classmethod && !is_staticmethod && if (self && !is_classmethod && !is_staticmethod &&
...@@ -1023,21 +1064,25 @@ __pyx_FusedFunction_call(PyObject *func, PyObject *args, PyObject *kw) ...@@ -1023,21 +1064,25 @@ __pyx_FusedFunction_call(PyObject *func, PyObject *args, PyObject *kw)
"First argument should be of type %.200s, got %.200s.", "First argument should be of type %.200s, got %.200s.",
((PyTypeObject *) binding_func->type)->tp_name, ((PyTypeObject *) binding_func->type)->tp_name,
self->ob_type->tp_name); self->ob_type->tp_name);
goto __pyx_err; goto bad;
} }
#if !CYTHON_COMPILING_IN_CPYTHON
Py_XDECREF(self);
self = NULL;
#endif
if (binding_func->__signatures__) { if (binding_func->__signatures__) {
PyObject *tup = PyTuple_Pack(4, binding_func->__signatures__, args, PyObject *tup = PyTuple_Pack(4, binding_func->__signatures__, args,
kw == NULL ? Py_None : kw, kw == NULL ? Py_None : kw,
binding_func->func.defaults_tuple); binding_func->func.defaults_tuple);
if (!tup) if (!tup)
goto __pyx_err; goto bad;
new_func = (__pyx_FusedFunctionObject *) __pyx_FusedFunction_callfunction(func, tup, NULL); new_func = (__pyx_FusedFunctionObject *) __pyx_FusedFunction_callfunction(func, tup, NULL);
Py_DECREF(tup); Py_DECREF(tup);
if (!new_func) if (!new_func)
goto __pyx_err; goto bad;
Py_XINCREF(binding_func->func.func_classobj); Py_XINCREF(binding_func->func.func_classobj);
Py_CLEAR(new_func->func.func_classobj); Py_CLEAR(new_func->func.func_classobj);
...@@ -1047,7 +1092,10 @@ __pyx_FusedFunction_call(PyObject *func, PyObject *args, PyObject *kw) ...@@ -1047,7 +1092,10 @@ __pyx_FusedFunction_call(PyObject *func, PyObject *args, PyObject *kw)
} }
result = __pyx_FusedFunction_callfunction(func, args, kw); result = __pyx_FusedFunction_callfunction(func, args, kw);
__pyx_err: bad:
#if !CYTHON_COMPILING_IN_CPYTHON
Py_XDECREF(self);
#endif
Py_XDECREF(new_args); Py_XDECREF(new_args);
Py_XDECREF((PyObject *) new_func); Py_XDECREF((PyObject *) new_func);
return result; return result;
......
...@@ -724,7 +724,11 @@ static PyObject *__Pyx_FindInheritedMetaclass(PyObject *bases) { ...@@ -724,7 +724,11 @@ static PyObject *__Pyx_FindInheritedMetaclass(PyObject *bases) {
PyObject *metaclass; PyObject *metaclass;
if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) { if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) {
PyTypeObject *metatype; PyTypeObject *metatype;
#if CYTHON_COMPILING_IN_CPYTHON
PyObject *base = PyTuple_GET_ITEM(bases, 0); PyObject *base = PyTuple_GET_ITEM(bases, 0);
#else
PyObject *base = PySequence_ITEM(bases, 0);
#endif
#if PY_MAJOR_VERSION < 3 #if PY_MAJOR_VERSION < 3
PyObject* basetype = __Pyx_PyObject_GetAttrStr(base, PYIDENT("__class__")); PyObject* basetype = __Pyx_PyObject_GetAttrStr(base, PYIDENT("__class__"));
if (basetype) { if (basetype) {
...@@ -739,6 +743,9 @@ static PyObject *__Pyx_FindInheritedMetaclass(PyObject *bases) { ...@@ -739,6 +743,9 @@ static PyObject *__Pyx_FindInheritedMetaclass(PyObject *bases) {
metatype = Py_TYPE(base); metatype = Py_TYPE(base);
#endif #endif
metaclass = __Pyx_CalculateMetaclass(metatype, bases); metaclass = __Pyx_CalculateMetaclass(metatype, bases);
#if !CYTHON_COMPILING_IN_CPYTHON
Py_DECREF(base);
#endif
#if PY_MAJOR_VERSION < 3 #if PY_MAJOR_VERSION < 3
Py_DECREF(basetype); Py_DECREF(basetype);
#endif #endif
......
...@@ -382,12 +382,24 @@ static {{struct_type_decl}} {{funcname}}(PyObject * o) { ...@@ -382,12 +382,24 @@ static {{struct_type_decl}} {{funcname}}(PyObject * o) {
goto bad; goto bad;
} }
#if CYTHON_COMPILING_IN_CPYTHON
{{for ix, component in enumerate(components):}} {{for ix, component in enumerate(components):}}
{{py:attr = "result.f%s" % ix}} {{py:attr = "result.f%s" % ix}}
{{attr}} = {{component.from_py_function}}(PyTuple_GET_ITEM(o, {{ix}})); {{attr}} = {{component.from_py_function}}(PyTuple_GET_ITEM(o, {{ix}}));
if ({{component.error_condition(attr)}}) if ({{component.error_condition(attr)}}) goto bad;
goto bad;
{{endfor}} {{endfor}}
#else
{
PyObject *item;
{{for ix, component in enumerate(components):}}
{{py:attr = "result.f%s" % ix}}
item = PySequence_ITEM(o, {{ix}}); if (unlikely(!item)) goto bad;
{{attr}} = {{component.from_py_function}}(item);
Py_DECREF(item);
if ({{component.error_condition(attr)}}) goto bad;
{{endfor}}
}
#endif
return result; return result;
bad: bad:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment