Skip to content

Commit a450398

Browse files
authored
bpo-44687: Ensure BufferedReader objects with unread buffers can peek even when the underlying file is closed (pythonGH-28457)
1 parent cd760ce commit a450398

File tree

2 files changed

+6
-3
lines changed

2 files changed

+6
-3
lines changed
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
:meth:`BufferedReader.peek` no longer raises :exc:`ValueError` when the entire file has already been buffered.

Modules/_io/bufferedio.c

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -341,11 +341,10 @@ _enter_buffered_busy(buffered *self)
341341
: buffered_closed(self)))
342342

343343
#define CHECK_CLOSED(self, error_msg) \
344-
if (IS_CLOSED(self)) { \
344+
if (IS_CLOSED(self) & (Py_SAFE_DOWNCAST(READAHEAD(self), Py_off_t, Py_ssize_t) == 0)) { \
345345
PyErr_SetString(PyExc_ValueError, error_msg); \
346346
return NULL; \
347-
}
348-
347+
} \
349348

350349
#define VALID_READ_BUFFER(self) \
351350
(self->readable && self->read_end != -1)
@@ -530,6 +529,9 @@ buffered_close(buffered *self, PyObject *args)
530529
Py_CLEAR(res);
531530
}
532531

532+
self->read_end = 0;
533+
self->pos = 0;
534+
533535
end:
534536
LEAVE_BUFFERED(self)
535537
return res;

0 commit comments

Comments
 (0)