summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2016-09-12 10:55:28 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2016-09-12 10:55:28 (GMT)
commitb1e169bf4b8c8c494181724c583f991d3dd66995 (patch)
tree7a0f414e170b894934e7c6b92c9b07d9b13032fd
parent410b9887e14f6b15c00c10e57537297c3abe45dd (diff)
downloadcpython-b1e169bf4b8c8c494181724c583f991d3dd66995.zip
cpython-b1e169bf4b8c8c494181724c583f991d3dd66995.tar.gz
cpython-b1e169bf4b8c8c494181724c583f991d3dd66995.tar.bz2
ssue #27213: Reintroduce checks in _PyStack_AsDict()
-rw-r--r--Include/abstract.h4
-rw-r--r--Objects/abstract.c26
-rw-r--r--Objects/methodobject.c2
3 files changed, 23 insertions, 9 deletions
diff --git a/Include/abstract.h b/Include/abstract.h
index a94ce66..8748367 100644
--- a/Include/abstract.h
+++ b/Include/abstract.h
@@ -275,7 +275,9 @@ xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx*/
PyAPI_FUNC(PyObject *) _PyStack_AsDict(
PyObject **values,
- PyObject *kwnames);
+ Py_ssize_t nkwargs,
+ PyObject *kwnames,
+ PyObject *func);
/* Convert (args, nargs, kwargs) into a (stack, nargs, kwnames).
diff --git a/Objects/abstract.c b/Objects/abstract.c
index a929be9..f9e5009 100644
--- a/Objects/abstract.c
+++ b/Objects/abstract.c
@@ -2367,9 +2367,9 @@ _PyObject_Call_Prepend(PyObject *func,
}
PyObject *
-_PyStack_AsDict(PyObject **values, PyObject *kwnames)
+_PyStack_AsDict(PyObject **values, Py_ssize_t nkwargs, PyObject *kwnames,
+ PyObject *func)
{
- Py_ssize_t nkwargs = PyTuple_GET_SIZE(kwnames);
PyObject *kwdict;
Py_ssize_t i;
@@ -2378,12 +2378,24 @@ _PyStack_AsDict(PyObject **values, PyObject *kwnames)
return NULL;
}
- for (i = 0; i < nkwargs; i++) {
+ for (i=0; i < nkwargs; i++) {
+ int err;
PyObject *key = PyTuple_GET_ITEM(kwnames, i);
PyObject *value = *values++;
- assert(PyUnicode_CheckExact(key));
- assert(PyDict_GetItem(kwdict, key) == NULL);
- if (PyDict_SetItem(kwdict, key, value)) {
+
+ 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) {
Py_DECREF(kwdict);
return NULL;
}
@@ -2467,7 +2479,7 @@ _PyObject_FastCallKeywords(PyObject *func, PyObject **stack, Py_ssize_t nargs,
}
if (nkwargs > 0) {
- kwdict = _PyStack_AsDict(stack + nargs, kwnames);
+ kwdict = _PyStack_AsDict(stack + nargs, nkwargs, kwnames, func);
if (kwdict == NULL) {
return NULL;
}
diff --git a/Objects/methodobject.c b/Objects/methodobject.c
index 90c473e..487ccd7 100644
--- a/Objects/methodobject.c
+++ b/Objects/methodobject.c
@@ -279,7 +279,7 @@ _PyCFunction_FastCallKeywords(PyObject *func, PyObject **stack,
nkwargs = (kwnames == NULL) ? 0 : PyTuple_GET_SIZE(kwnames);
if (nkwargs > 0) {
- kwdict = _PyStack_AsDict(stack + nargs, kwnames);
+ kwdict = _PyStack_AsDict(stack + nargs, nkwargs, kwnames, func);
if (kwdict == NULL) {
return NULL;
}