changeset: 103705:e372c0ad32ce user: Victor Stinner date: Mon Sep 12 13:30:02 2016 +0200 files: Include/abstract.h Objects/abstract.c Objects/methodobject.c description: Revert change f860b7a775c5 Revert change "Issue #27213: Reintroduce checks in _PyStack_AsDict()", pushed by mistake. diff -r e163ba9b8d3e -r e372c0ad32ce Include/abstract.h --- a/Include/abstract.h Mon Sep 12 13:04:17 2016 +0200 +++ b/Include/abstract.h Mon Sep 12 13:30:02 2016 +0200 @@ -275,9 +275,7 @@ PyAPI_FUNC(PyObject *) _PyStack_AsDict( PyObject **values, - Py_ssize_t nkwargs, - PyObject *kwnames, - PyObject *func); + PyObject *kwnames); /* Convert (args, nargs, kwargs) into a (stack, nargs, kwnames). diff -r e163ba9b8d3e -r e372c0ad32ce Objects/abstract.c --- a/Objects/abstract.c Mon Sep 12 13:04:17 2016 +0200 +++ b/Objects/abstract.c Mon Sep 12 13:30:02 2016 +0200 @@ -2367,9 +2367,9 @@ } PyObject * -_PyStack_AsDict(PyObject **values, Py_ssize_t nkwargs, PyObject *kwnames, - PyObject *func) +_PyStack_AsDict(PyObject **values, PyObject *kwnames) { + Py_ssize_t nkwargs = PyTuple_GET_SIZE(kwnames); PyObject *kwdict; Py_ssize_t i; @@ -2378,24 +2378,12 @@ return NULL; } - for (i=0; i < nkwargs; i++) { - int err; + for (i = 0; i < nkwargs; i++) { PyObject *key = PyTuple_GET_ITEM(kwnames, i); PyObject *value = *values++; - - if (PyDict_GetItem(kwdict, key) != NULL) { - PyErr_Format(PyExc_TypeError, - "%.200s%s got multiple values " - "for keyword argument '%U'", - PyEval_GetFuncName(func), - PyEval_GetFuncDesc(func), - key); - Py_DECREF(kwdict); - return NULL; - } - - err = PyDict_SetItem(kwdict, key, value); - if (err) { + assert(PyUnicode_CheckExact(key)); + assert(PyDict_GetItem(kwdict, key) == NULL); + if (PyDict_SetItem(kwdict, key, value)) { Py_DECREF(kwdict); return NULL; } @@ -2479,7 +2467,7 @@ } if (nkwargs > 0) { - kwdict = _PyStack_AsDict(stack + nargs, nkwargs, kwnames, func); + kwdict = _PyStack_AsDict(stack + nargs, kwnames); if (kwdict == NULL) { return NULL; } diff -r e163ba9b8d3e -r e372c0ad32ce Objects/methodobject.c --- a/Objects/methodobject.c Mon Sep 12 13:04:17 2016 +0200 +++ b/Objects/methodobject.c Mon Sep 12 13:30:02 2016 +0200 @@ -279,7 +279,7 @@ nkwargs = (kwnames == NULL) ? 0 : PyTuple_GET_SIZE(kwnames); if (nkwargs > 0) { - kwdict = _PyStack_AsDict(stack + nargs, nkwargs, kwnames, func); + kwdict = _PyStack_AsDict(stack + nargs, kwnames); if (kwdict == NULL) { return NULL; }