• Joe Tsai's avatar
    compress/bzip2: fix checksum mismatch on empty reads · 57f7bc3a
    Joe Tsai authored
    Previously, the read method checked whether the current block
    was fully consumed or not based on whether the buffer could be filled
    with a non-zero number of bytes. This check is problematic because
    zero bytes could be read if the provided buffer is empty.
    
    We fix this case by simply checking for whether the input buffer
    provided by the user was empty or not. If empty, we assume that
    we could not read any bytes because the buffer was too small,
    rather than indicating that the current block was fully exhausted.
    
    This check causes bzip2.Reader to be unable to make progress
    on the next block unless a non-empty buffer is provided.
    However, that is an entirely reasonable expectation since a
    non-empty buffer needs to be provided eventually anyways to
    read the actual contents of subsequent blocks.
    
    Fixes #22028
    
    Change-Id: I2bb1b2d54e78567baf2bf7b490a272c0853d7bfe
    Reviewed-on: https://go-review.googlesource.com/66110Reviewed-by: 's avatarIan Lance Taylor <iant@golang.org>
    57f7bc3a
Name
Last commit
Last update
..
archive Loading commit data...
bufio Loading commit data...
builtin Loading commit data...
bytes Loading commit data...
cmd Loading commit data...
compress Loading commit data...
container Loading commit data...
context Loading commit data...
crypto Loading commit data...
database/sql Loading commit data...
debug Loading commit data...
encoding Loading commit data...
errors Loading commit data...
expvar Loading commit data...
flag Loading commit data...
fmt Loading commit data...
go Loading commit data...
hash Loading commit data...
html Loading commit data...
image Loading commit data...
index/suffixarray Loading commit data...
internal Loading commit data...
io Loading commit data...
log Loading commit data...
math Loading commit data...
mime Loading commit data...
net Loading commit data...
os Loading commit data...
path Loading commit data...
plugin Loading commit data...
reflect Loading commit data...
regexp Loading commit data...
runtime Loading commit data...
sort Loading commit data...
strconv Loading commit data...
strings Loading commit data...
sync Loading commit data...
syscall Loading commit data...
testing Loading commit data...
text Loading commit data...
time Loading commit data...
unicode Loading commit data...
unsafe Loading commit data...
vendor/golang_org/x Loading commit data...
Make.dist Loading commit data...
all.bash Loading commit data...
all.bat Loading commit data...
all.rc Loading commit data...
androidtest.bash Loading commit data...
bootstrap.bash Loading commit data...
buildall.bash Loading commit data...
clean.bash Loading commit data...
clean.bat Loading commit data...
clean.rc Loading commit data...
cmp.bash Loading commit data...
iostest.bash Loading commit data...
make.bash Loading commit data...
make.bat Loading commit data...
make.rc Loading commit data...
naclmake.bash Loading commit data...
nacltest.bash Loading commit data...
race.bash Loading commit data...
race.bat Loading commit data...
run.bash Loading commit data...
run.bat Loading commit data...
run.rc Loading commit data...