diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2010-08-01 20:08:46 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-08-01 20:08:46 (GMT) |
commit | 7ffa196dce8db3010bce3e550078ed455a30e851 (patch) | |
tree | ec5119d3f4e2b23c8c1b07af8c5e453f6f4a7949 /Modules | |
parent | 7fb6f5121a42136f35c561c408091cd043f6340d (diff) | |
download | cpython-7ffa196dce8db3010bce3e550078ed455a30e851.zip cpython-7ffa196dce8db3010bce3e550078ed455a30e851.tar.gz cpython-7ffa196dce8db3010bce3e550078ed455a30e851.tar.bz2 |
Issue #8397: Raise an error when attempting to mix iteration and regular
reads on a BZ2File object, rather than returning incorrect results.
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/bz2module.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/Modules/bz2module.c b/Modules/bz2module.c index 29f8592..c44d3b9 100644 --- a/Modules/bz2module.c +++ b/Modules/bz2module.c @@ -138,6 +138,22 @@ typedef struct { /* ===================================================================== */ /* Utility functions. */ +/* Refuse regular I/O if there's data in the iteration-buffer. + * Mixing them would cause data to arrive out of order, as the read* + * methods don't use the iteration buffer. */ +static int +check_iterbuffered(BZ2FileObject *f) +{ + if (f->f_buf != NULL && + (f->f_bufend - f->f_bufptr) > 0 && + f->f_buf[0] != '\0') { + PyErr_SetString(PyExc_ValueError, + "Mixing iteration and read methods would lose data"); + return -1; + } + return 0; +} + static int Util_CatchBZ2Error(int bzerror) { @@ -427,6 +443,10 @@ BZ2File_read(BZ2FileObject *self, PyObject *args) goto cleanup; } + /* refuse to mix with f.next() */ + if (check_iterbuffered(self)) + goto cleanup; + if (bytesrequested < 0) buffersize = Util_NewBufferSize((size_t)0); else @@ -516,6 +536,10 @@ BZ2File_readline(BZ2FileObject *self, PyObject *args) goto cleanup; } + /* refuse to mix with f.next() */ + if (check_iterbuffered(self)) + goto cleanup; + if (sizehint == 0) ret = PyBytes_FromStringAndSize("", 0); else @@ -573,6 +597,10 @@ BZ2File_readlines(BZ2FileObject *self, PyObject *args) goto cleanup; } + /* refuse to mix with f.next() */ + if (check_iterbuffered(self)) + goto cleanup; + if ((list = PyList_New(0)) == NULL) goto cleanup; |