summaryrefslogtreecommitdiffstats
path: root/Python/pylifecycle.c
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2023-08-24 13:59:12 (GMT)
committerGitHub <noreply@github.com>2023-08-24 13:59:12 (GMT)
commit67266266469fe0e817736227f39537182534c1a5 (patch)
tree1ae99ebf16335cbd67678f3911702e9819cbe039 /Python/pylifecycle.c
parentc163d7f0b67a568e9b64eeb9c1cbbaa127818596 (diff)
downloadcpython-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.c9
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");