Commit 3ff46855 authored by Stefan Behnel's avatar Stefan Behnel

Reduce some overhead in the fused function selection code.

parent 8c7c5a47
...@@ -1135,7 +1135,13 @@ __pyx_FusedFunction_descr_get(PyObject *self, PyObject *obj, PyObject *type) ...@@ -1135,7 +1135,13 @@ __pyx_FusedFunction_descr_get(PyObject *self, PyObject *obj, PyObject *type)
static PyObject * static PyObject *
_obj_to_str(PyObject *obj) _obj_to_str(PyObject *obj)
{ {
if (PyType_Check(obj)) if (PyUnicode_CheckExact(obj))
return __Pyx_NewRef(obj);
#if PY_MAJOR_VERSION == 2
else if (PyString_CheckExact(obj))
return __Pyx_NewRef(obj);
#endif
else if (PyType_Check(obj))
return PyObject_GetAttr(obj, PYIDENT("__name__")); return PyObject_GetAttr(obj, PYIDENT("__name__"));
else else
return PyObject_Str(obj); return PyObject_Str(obj);
...@@ -1154,16 +1160,14 @@ __pyx_FusedFunction_getitem(__pyx_FusedFunctionObject *self, PyObject *idx) ...@@ -1154,16 +1160,14 @@ __pyx_FusedFunction_getitem(__pyx_FusedFunctionObject *self, PyObject *idx)
} }
if (PyTuple_Check(idx)) { if (PyTuple_Check(idx)) {
PyObject *list = PyList_New(0);
Py_ssize_t n = PyTuple_GET_SIZE(idx); Py_ssize_t n = PyTuple_GET_SIZE(idx);
PyObject *sep = NULL; PyObject *list = PyList_New(n);
int i; int i;
if (unlikely(!list)) if (unlikely(!list))
return NULL; return NULL;
for (i = 0; i < n; i++) { for (i = 0; i < n; i++) {
int ret;
PyObject *string; PyObject *string;
#if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS #if CYTHON_ASSUME_SAFE_MACROS && !CYTHON_AVOID_BORROWED_REFS
PyObject *item = PyTuple_GET_ITEM(idx, i); PyObject *item = PyTuple_GET_ITEM(idx, i);
...@@ -1175,18 +1179,13 @@ __pyx_FusedFunction_getitem(__pyx_FusedFunctionObject *self, PyObject *idx) ...@@ -1175,18 +1179,13 @@ __pyx_FusedFunction_getitem(__pyx_FusedFunctionObject *self, PyObject *idx)
Py_DECREF(item); Py_DECREF(item);
#endif #endif
if (unlikely(!string)) goto __pyx_err; if (unlikely(!string)) goto __pyx_err;
ret = PyList_Append(list, string); PyList_SET_ITEM(list, i, string);
Py_DECREF(string);
if (unlikely(ret < 0)) goto __pyx_err;
} }
sep = PyUnicode_FromString("|"); signature = PyUnicode_Join(PYUNICODE("|"), list);
if (likely(sep)) signature = PyUnicode_Join(PYUNICODE("|"), list);
signature = PyUnicode_Join(sep, list); __pyx_err:;
__pyx_err:
;
Py_DECREF(list); Py_DECREF(list);
Py_XDECREF(sep);
} else { } else {
signature = _obj_to_str(idx); signature = _obj_to_str(idx);
} }
......
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