diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2010-08-21 19:17:25 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-08-21 19:17:25 (GMT) |
commit | 3ebaed60b4779f89e5f5b82373c5a3bbc452813c (patch) | |
tree | dcd7d4e951de7873d5008d4956d22145c022c43f /Modules/_io | |
parent | b7575ee2d3bf00c9e5bd1391f95eef6cdd59c53a (diff) | |
download | cpython-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.c | 10 |
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); |