summaryrefslogtreecommitdiffstats
path: root/Modules/_io
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2010-08-21 19:17:25 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2010-08-21 19:17:25 (GMT)
commit3ebaed60b4779f89e5f5b82373c5a3bbc452813c (patch)
treedcd7d4e951de7873d5008d4956d22145c022c43f /Modules/_io
parentb7575ee2d3bf00c9e5bd1391f95eef6cdd59c53a (diff)
downloadcpython-3ebaed60b4779f89e5f5b82373c5a3bbc452813c.zip
cpython-3ebaed60b4779f89e5f5b82373c5a3bbc452813c.tar.gz
cpython-3ebaed60b4779f89e5f5b82373c5a3bbc452813c.tar.bz2
Merged revisions 84239 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r84239 | antoine.pitrou | 2010-08-21 21:09:32 +0200 (sam., 21 août 2010) | 4 lines Issue #9617: Signals received during a low-level write operation aren't ignored by the buffered IO layer anymore. ........
Diffstat (limited to 'Modules/_io')
-rw-r--r--Modules/_io/bufferedio.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/Modules/_io/bufferedio.c b/Modules/_io/bufferedio.c
index a68f8fe..d96b7ee 100644
--- a/Modules/_io/bufferedio.c
+++ b/Modules/_io/bufferedio.c
@@ -1670,6 +1670,11 @@ _bufferedwriter_flush_unlocked(buffered *self, int restore_pos)
self->write_pos += n;
self->raw_pos = self->write_pos;
written += Py_SAFE_DOWNCAST(n, Py_off_t, Py_ssize_t);
+ /* Partial writes can return successfully when interrupted by a
+ signal (see write(2)). We must run signal handlers before
+ blocking another time, possibly indefinitely. */
+ if (PyErr_CheckSignals() < 0)
+ goto error;
}
if (restore_pos) {
@@ -1807,6 +1812,11 @@ bufferedwriter_write(buffered *self, PyObject *args)
}
written += n;
remaining -= n;
+ /* Partial writes can return successfully when interrupted by a
+ signal (see write(2)). We must run signal handlers before
+ blocking another time, possibly indefinitely. */
+ if (PyErr_CheckSignals() < 0)
+ goto error;
}
if (self->readable)
_bufferedreader_reset_buf(self);