summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Misc/NEWS3
-rw-r--r--Modules/_io/iobase.c5
-rw-r--r--Modules/_io/textio.c7
3 files changed, 12 insertions, 3 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index 2d46d7d..b74b2f6 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -679,6 +679,9 @@ Library
Extension Modules
-----------------
+- Issue #12268: The io module file object writelines() methods no longer
+ abort early when one of its write system calls is interrupted (EINTR).
+
- Fix the leak of a dict in the time module when used in an embedded
interpreter that is repeatedly initialized and shutdown and reinitialized.
diff --git a/Modules/_io/iobase.c b/Modules/_io/iobase.c
index 04caea4..063ba2e 100644
--- a/Modules/_io/iobase.c
+++ b/Modules/_io/iobase.c
@@ -660,7 +660,10 @@ iobase_writelines(PyObject *self, PyObject *args)
break; /* Stop Iteration */
}
- res = PyObject_CallMethodObjArgs(self, _PyIO_str_write, line, NULL);
+ res = NULL;
+ do {
+ res = PyObject_CallMethodObjArgs(self, _PyIO_str_write, line, NULL);
+ } while (res == NULL && _PyIO_trap_eintr());
Py_DECREF(line);
if (res == NULL) {
Py_DECREF(iter);
diff --git a/Modules/_io/textio.c b/Modules/_io/textio.c
index d2e92fa..c9913d4 100644
--- a/Modules/_io/textio.c
+++ b/Modules/_io/textio.c
@@ -1213,8 +1213,11 @@ _textiowrapper_writeflush(textio *self)
Py_DECREF(pending);
if (b == NULL)
return -1;
- ret = PyObject_CallMethodObjArgs(self->buffer,
- _PyIO_str_write, b, NULL);
+ ret = NULL;
+ do {
+ ret = PyObject_CallMethodObjArgs(self->buffer,
+ _PyIO_str_write, b, NULL);
+ } while (ret == NULL && _PyIO_trap_eintr());
Py_DECREF(b);
if (ret == NULL)
return -1;