summaryrefslogtreecommitdiff
path: root/zlib/infback.c
diff options
context:
space:
mode:
authorOleksandr Byelkin <sanja@mariadb.com>2023-05-02 13:54:54 +0200
committerOleksandr Byelkin <sanja@mariadb.com>2023-05-02 13:54:54 +0200
commitedf8ce5b9741520cd5b3e559af2dd7cace6b4af9 (patch)
tree20ce88b147bc64be1ab6206714d6fbcd3f40c530 /zlib/infback.c
parentd821fd7fab2723b84f774aaa4882acb86b35769d (diff)
parentedd0b03e60f4cc666fbdf16e7b01b97188f2f887 (diff)
downloadmariadb-git-edf8ce5b9741520cd5b3e559af2dd7cace6b4af9.tar.gz
Merge branch 'bb-10.4-release' into bb-10.5-release
Diffstat (limited to 'zlib/infback.c')
-rw-r--r--zlib/infback.c17
1 files changed, 10 insertions, 7 deletions
diff --git a/zlib/infback.c b/zlib/infback.c
index a390c58e816..babeaf1806f 100644
--- a/zlib/infback.c
+++ b/zlib/infback.c
@@ -66,6 +66,7 @@ int stream_size;
state->window = window;
state->wnext = 0;
state->whave = 0;
+ state->sane = 1;
return Z_OK;
}
@@ -605,25 +606,27 @@ void FAR *out_desc;
break;
case DONE:
- /* inflate stream terminated properly -- write leftover output */
+ /* inflate stream terminated properly */
ret = Z_STREAM_END;
- if (left < state->wsize) {
- if (out(out_desc, state->window, state->wsize - left))
- ret = Z_BUF_ERROR;
- }
goto inf_leave;
case BAD:
ret = Z_DATA_ERROR;
goto inf_leave;
- default: /* can't happen, but makes compilers happy */
+ default:
+ /* can't happen, but makes compilers happy */
ret = Z_STREAM_ERROR;
goto inf_leave;
}
- /* Return unused input */
+ /* Write leftover output and return unused input */
inf_leave:
+ if (left < state->wsize) {
+ if (out(out_desc, state->window, state->wsize - left) &&
+ ret == Z_STREAM_END)
+ ret = Z_BUF_ERROR;
+ }
strm->next_in = next;
strm->avail_in = have;
return ret;