Kaydet (Commit) 4ef4edaa authored tarafından Serhiy Storchaka's avatar Serhiy Storchaka

Issue #26822: Decreased an overhead of using _PyArg_NoKeywords() in calls of

itemgetter, attrgetter and methodcaller objects.
üst fd583495
...@@ -511,7 +511,7 @@ itemgetter_call(itemgetterobject *ig, PyObject *args, PyObject *kw) ...@@ -511,7 +511,7 @@ itemgetter_call(itemgetterobject *ig, PyObject *args, PyObject *kw)
PyObject *obj, *result; PyObject *obj, *result;
Py_ssize_t i, nitems=ig->nitems; Py_ssize_t i, nitems=ig->nitems;
if (!_PyArg_NoKeywords("itemgetter", kw)) if (kw != NULL && !_PyArg_NoKeywords("itemgetter", kw))
return NULL; return NULL;
if (!PyArg_UnpackTuple(args, "itemgetter", 1, 1, &obj)) if (!PyArg_UnpackTuple(args, "itemgetter", 1, 1, &obj))
return NULL; return NULL;
...@@ -693,7 +693,7 @@ attrgetter_call(attrgetterobject *ag, PyObject *args, PyObject *kw) ...@@ -693,7 +693,7 @@ attrgetter_call(attrgetterobject *ag, PyObject *args, PyObject *kw)
PyObject *obj, *result; PyObject *obj, *result;
Py_ssize_t i, nattrs=ag->nattrs; Py_ssize_t i, nattrs=ag->nattrs;
if (!_PyArg_NoKeywords("attrgetter", kw)) if (kw != NULL && !_PyArg_NoKeywords("attrgetter", kw))
return NULL; return NULL;
if (!PyArg_UnpackTuple(args, "attrgetter", 1, 1, &obj)) if (!PyArg_UnpackTuple(args, "attrgetter", 1, 1, &obj))
return NULL; return NULL;
...@@ -842,7 +842,7 @@ methodcaller_call(methodcallerobject *mc, PyObject *args, PyObject *kw) ...@@ -842,7 +842,7 @@ methodcaller_call(methodcallerobject *mc, PyObject *args, PyObject *kw)
{ {
PyObject *method, *obj, *result; PyObject *method, *obj, *result;
if (!_PyArg_NoKeywords("methodcaller", kw)) if (kw != NULL && !_PyArg_NoKeywords("methodcaller", kw))
return NULL; return NULL;
if (!PyArg_UnpackTuple(args, "methodcaller", 1, 1, &obj)) if (!PyArg_UnpackTuple(args, "methodcaller", 1, 1, &obj))
return NULL; return NULL;
......
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