From a85a1d337d26a65036e427341d15e3979f7e9ced Mon Sep 17 00:00:00 2001 From: Victor Stinner Date: Tue, 28 May 2019 16:01:17 +0200 Subject: bpo-36829: sys.excepthook and sys.unraisablehook flush (GH-13620) sys.excepthook() and sys.unraisablehook() now explicitly flush the file (usually sys.stderr). If file.flush() fails, sys.excepthook() silently ignores the error, whereas sys.unraisablehook() logs the new exception. --- Python/errors.c | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'Python/errors.c') diff --git a/Python/errors.c b/Python/errors.c index bd33d4d340..8a94afdd8c 100644 --- a/Python/errors.c +++ b/Python/errors.c @@ -26,6 +26,7 @@ extern "C" { _Py_IDENTIFIER(builtins); _Py_IDENTIFIER(stderr); +_Py_IDENTIFIER(flush); /* Forward declarations */ @@ -1254,6 +1255,14 @@ write_unraisable_exc_file(PyThreadState *tstate, PyObject *exc_type, if (PyFile_WriteString("\n", file) < 0) { return -1; } + + /* Explicitly call file.flush() */ + PyObject *res = _PyObject_CallMethodId(file, &PyId_flush, NULL); + if (!res) { + return -1; + } + Py_DECREF(res); + return 0; } -- cgit v1.2.1