Closes #15488: Closed files keep their buffer alive

This commit is contained in:
Jesus Cea 2012-10-04 12:37:56 +02:00
parent 279ed3cc55
commit dc469454ec
3 changed files with 16 additions and 0 deletions

View file

@ -815,6 +815,14 @@ def test_sizeof(self):
bufio = self.tp(rawio, buffer_size=bufsize2) bufio = self.tp(rawio, buffer_size=bufsize2)
self.assertEqual(sys.getsizeof(bufio), size + bufsize2) self.assertEqual(sys.getsizeof(bufio), size + bufsize2)
@support.cpython_only
def test_buffer_freeing(self) :
bufsize = 4096
rawio = self.MockRawIO()
bufio = self.tp(rawio, buffer_size=bufsize)
size = sys.getsizeof(bufio) - bufsize
bufio.close()
self.assertEqual(sys.getsizeof(bufio), size)
class BufferedReaderTest(unittest.TestCase, CommonBufferedTests): class BufferedReaderTest(unittest.TestCase, CommonBufferedTests):
read_mode = "rb" read_mode = "rb"

View file

@ -24,6 +24,9 @@ Core and Builtins
- Issue #15839: Convert SystemErrors in `super()` to RuntimeErrors. - Issue #15839: Convert SystemErrors in `super()` to RuntimeErrors.
- Issue #15448: Buffered IO now frees the buffer when closed, instead
of when deallocating.
- Issue #15846: Fix SystemError which happened when using `ast.parse()` in an - Issue #15846: Fix SystemError which happened when using `ast.parse()` in an
exception handler on code with syntax errors. exception handler on code with syntax errors.

View file

@ -519,6 +519,11 @@ buffered_close(buffered *self, PyObject *args)
res = PyObject_CallMethodObjArgs(self->raw, _PyIO_str_close, NULL); res = PyObject_CallMethodObjArgs(self->raw, _PyIO_str_close, NULL);
if (self->buffer) {
PyMem_Free(self->buffer);
self->buffer = NULL;
}
end: end:
LEAVE_BUFFERED(self) LEAVE_BUFFERED(self)
return res; return res;