summaryrefslogtreecommitdiff
path: root/Python/_warnings.c
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2013-11-01 00:55:30 +0100
committerVictor Stinner <victor.stinner@gmail.com>2013-11-01 00:55:30 +0100
commitc52af1265e0b79bc1787abccf29ea0ff471440ba (patch)
tree6820ae7ed6c94a5d8ee23db7b31a9d3d369e4a9c /Python/_warnings.c
parentde7f03c9b563d9a12a2a281a7272c80b199ee2e9 (diff)
downloadcpython-c52af1265e0b79bc1787abccf29ea0ff471440ba.tar.gz
Close #19442: warn_explicit() does nothing when called late during Python shutdown
After more tests, I now think that it is the safest option.
Diffstat (limited to 'Python/_warnings.c')
-rw-r--r--Python/_warnings.c18
1 files changed, 9 insertions, 9 deletions
diff --git a/Python/_warnings.c b/Python/_warnings.c
index d9f3297dd3..e88f646089 100644
--- a/Python/_warnings.c
+++ b/Python/_warnings.c
@@ -333,6 +333,13 @@ warn_explicit(PyObject *category, PyObject *message,
PyObject *action;
int rc;
+ /* module can be None if a warning is emitted late during Python shutdown.
+ In this case, the Python warnings module was probably unloaded, filters
+ are no more available to choose as action. It is safer to ignore the
+ warning and do nothing. */
+ if (module == Py_None)
+ Py_RETURN_NONE;
+
if (registry && !PyDict_Check(registry) && (registry != Py_None)) {
PyErr_SetString(PyExc_TypeError, "'registry' must be a dict");
return NULL;
@@ -635,15 +642,8 @@ do_warn(PyObject *message, PyObject *category, Py_ssize_t stack_level)
if (!setup_context(stack_level, &filename, &lineno, &module, &registry))
return NULL;
- if (module != Py_None) {
- res = warn_explicit(category, message, filename, lineno, module, registry,
- NULL);
- }
- else {
- /* FIXME: emitting warnings at exit does crash Python */
- res = Py_None;
- Py_INCREF(res);
- }
+ res = warn_explicit(category, message, filename, lineno, module, registry,
+ NULL);
Py_DECREF(filename);
Py_DECREF(registry);
Py_DECREF(module);