diff options
author | Victor Stinner <vstinner@python.org> | 2023-08-24 13:59:12 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-08-24 13:59:12 (GMT) |
commit | 67266266469fe0e817736227f39537182534c1a5 (patch) | |
tree | 1ae99ebf16335cbd67678f3911702e9819cbe039 /Python/pylifecycle.c | |
parent | c163d7f0b67a568e9b64eeb9c1cbbaa127818596 (diff) | |
download | cpython-67266266469fe0e817736227f39537182534c1a5.zip cpython-67266266469fe0e817736227f39537182534c1a5.tar.gz cpython-67266266469fe0e817736227f39537182534c1a5.tar.bz2 |
gh-108314: Add PyDict_ContainsString() function (#108323)
Diffstat (limited to 'Python/pylifecycle.c')
-rw-r--r-- | Python/pylifecycle.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/Python/pylifecycle.c b/Python/pylifecycle.c index 1861426..7d362af 100644 --- a/Python/pylifecycle.c +++ b/Python/pylifecycle.c @@ -2220,10 +2220,11 @@ add_main_module(PyInterpreterState *interp) } Py_DECREF(ann_dict); - if (_PyDict_GetItemStringWithError(d, "__builtins__") == NULL) { - if (PyErr_Occurred()) { - return _PyStatus_ERR("Failed to test __main__.__builtins__"); - } + int has_builtins = PyDict_ContainsString(d, "__builtins__"); + if (has_builtins < 0) { + return _PyStatus_ERR("Failed to test __main__.__builtins__"); + } + if (!has_builtins) { PyObject *bimod = PyImport_ImportModule("builtins"); if (bimod == NULL) { return _PyStatus_ERR("Failed to retrieve builtins module"); |