mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
bpo-42006: Stop using PyDict_GetItem, PyDict_GetItemString and _PyDict_GetItemId. (GH-22648)
These functions are considered not safe because they suppress all internal errors and can return wrong result. PyDict_GetItemString and _PyDict_GetItemId can also silence current exception in rare cases. Remove no longer used _PyDict_GetItemId. Add _PyDict_ContainsId and rename _PyDict_Contains into _PyDict_Contains_KnownHash.
This commit is contained in:
parent
96a9eed245
commit
fb5db7ec58
17 changed files with 259 additions and 142 deletions
|
@ -489,8 +489,8 @@ dictbytype(PyObject *src, int scope_type, int flag, Py_ssize_t offset)
|
|||
/* XXX this should probably be a macro in symtable.h */
|
||||
long vi;
|
||||
k = PyList_GET_ITEM(sorted_keys, key_i);
|
||||
v = PyDict_GetItem(src, k);
|
||||
assert(PyLong_Check(v));
|
||||
v = PyDict_GetItemWithError(src, k);
|
||||
assert(v && PyLong_Check(v));
|
||||
vi = PyLong_AS_LONG(v);
|
||||
scope = (vi >> SCOPE_OFFSET) & SCOPE_MASK;
|
||||
|
||||
|
@ -1889,7 +1889,7 @@ static int
|
|||
compiler_lookup_arg(PyObject *dict, PyObject *name)
|
||||
{
|
||||
PyObject *v;
|
||||
v = PyDict_GetItem(dict, name);
|
||||
v = PyDict_GetItemWithError(dict, name);
|
||||
if (v == NULL)
|
||||
return -1;
|
||||
return PyLong_AS_LONG(v);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue