diff options
| author | dgp@users.sourceforge.net <dgp> | 2014-10-10 18:24:32 (GMT) |
|---|---|---|
| committer | dgp@users.sourceforge.net <dgp> | 2014-10-10 18:24:32 (GMT) |
| commit | e7c37b3a8d29556d1936bed027c3d36ae7df2a20 (patch) | |
| tree | 4edc380d2309a8614af4d5922f663170cd99ae16 | |
| parent | 82519777d4041077b7bcf00b69b37e67a7eb05ef (diff) | |
| download | tcl-e7c37b3a8d29556d1936bed027c3d36ae7df2a20.zip tcl-e7c37b3a8d29556d1936bed027c3d36ae7df2a20.tar.gz tcl-e7c37b3a8d29556d1936bed027c3d36ae7df2a20.tar.bz2 | |
[ed29c4da21] Don't let BLOCKED state get converted into a channel error.
| -rw-r--r-- | generic/tclIO.c | 28 |
1 files changed, 23 insertions, 5 deletions
diff --git a/generic/tclIO.c b/generic/tclIO.c index 3119db5..2fd3792 100644 --- a/generic/tclIO.c +++ b/generic/tclIO.c @@ -8853,21 +8853,39 @@ DoRead( } /* - * If there is not enough data in the buffers to possibly - * complete the read, then go get more. + * Don't read more data if we have what we need. */ - if (bufPtr == NULL || BytesLeft(bufPtr) < bytesToRead) { + while (!bufPtr || /* We got no buffer! OR */ + (!IsBufferFull(bufPtr) && /* Our buffer has room AND */ + (BytesLeft(bufPtr) < bytesToRead) ) ) { + /* Not enough bytes in it + * yet to fill the dst */ + int code; + moreData: - if (GetInput(chanPtr)) { + code = GetInput(chanPtr); + bufPtr = statePtr->inQueueHead; + + assert (bufPtr != NULL); + + if (GotFlag(statePtr, CHANNEL_EOF|CHANNEL_BLOCKED)) { + /* Further reads cannot do any more */ + break; + } + + if (code) { /* Read error */ UpdateInterest(chanPtr); TclChannelRelease((Tcl_Channel)chanPtr); return -1; } - bufPtr = statePtr->inQueueHead; + + assert (IsBufferFull(bufPtr)); } + assert (bufPtr != NULL); + bytesRead = BytesLeft(bufPtr); bytesWritten = bytesToRead; |
