mirror of
https://github.com/python/cpython.git
synced 2026-04-17 17:31:04 +00:00
gh-145876: Do not mask KeyErrors raised during dictionary unpacking in call (GH-146472)
KeyErrors raised in keys() or __getitem__() during dictionary unpacking in call (func(**mymapping)) are no longer masked by TypeError.
This commit is contained in:
parent
1af025dd22
commit
6932c3ee6a
11 changed files with 71 additions and 73 deletions
|
|
@ -3456,9 +3456,18 @@ _Py_Check_ArgsIterable(PyThreadState *tstate, PyObject *func, PyObject *args)
|
|||
}
|
||||
|
||||
void
|
||||
_PyEval_FormatKwargsError(PyThreadState *tstate, PyObject *func, PyObject *kwargs)
|
||||
_PyEval_FormatKwargsError(PyThreadState *tstate, PyObject *func, PyObject *kwargs, PyObject *dupkey)
|
||||
{
|
||||
/* _PyDict_MergeEx raises attribute
|
||||
if (dupkey != NULL) {
|
||||
PyObject *funcstr = _PyObject_FunctionStr(func);
|
||||
_PyErr_Format(
|
||||
tstate, PyExc_TypeError,
|
||||
"%V got multiple values for keyword argument '%S'",
|
||||
funcstr, "finction", dupkey);
|
||||
Py_XDECREF(funcstr);
|
||||
return;
|
||||
}
|
||||
/* _PyDict_MergeUniq raises attribute
|
||||
* error (percolated from an attempt
|
||||
* to get 'keys' attribute) instead of
|
||||
* a type error if its second argument
|
||||
|
|
@ -3478,27 +3487,6 @@ _PyEval_FormatKwargsError(PyThreadState *tstate, PyObject *func, PyObject *kwarg
|
|||
_PyErr_ChainExceptions1Tstate(tstate, exc);
|
||||
}
|
||||
}
|
||||
else if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
|
||||
PyObject *exc = _PyErr_GetRaisedException(tstate);
|
||||
PyObject *args = PyException_GetArgs(exc);
|
||||
if (PyTuple_Check(args) && PyTuple_GET_SIZE(args) == 1) {
|
||||
_PyErr_Clear(tstate);
|
||||
PyObject *funcstr = _PyObject_FunctionStr(func);
|
||||
if (funcstr != NULL) {
|
||||
PyObject *key = PyTuple_GET_ITEM(args, 0);
|
||||
_PyErr_Format(
|
||||
tstate, PyExc_TypeError,
|
||||
"%U got multiple values for keyword argument '%S'",
|
||||
funcstr, key);
|
||||
Py_DECREF(funcstr);
|
||||
}
|
||||
Py_XDECREF(exc);
|
||||
}
|
||||
else {
|
||||
_PyErr_SetRaisedException(tstate, exc);
|
||||
}
|
||||
Py_DECREF(args);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue