diff options
author | Pierre Joye <pierre.php@gmail.com> | 2021-09-08 10:08:12 +0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-09-08 10:08:12 +0700 |
commit | 6f5136821be86e7068fcdf651ae9420b5d42e9a9 (patch) | |
tree | 736d3371ab030a593f809b08a2d3c90b810d7474 | |
parent | 16ebd800f7034a1e8c37c07b6d0e08f7812eb30c (diff) | |
parent | 75fecefe770a1672ff57064ca827d71e44244d66 (diff) | |
download | libgd-6f5136821be86e7068fcdf651ae9420b5d42e9a9.tar.gz |
Merge pull request #755 from libgd/bug/750
Partial fix for #750, BMP and WebP. Gif's usage of PutBuf needs too much refactoring for the actual gain here."
-rw-r--r-- | src/gd_bmp.c | 14 | ||||
-rw-r--r-- | src/gd_webp.c | 7 |
2 files changed, 17 insertions, 4 deletions
diff --git a/src/gd_bmp.c b/src/gd_bmp.c index e186ac9..c67e45f 100644 --- a/src/gd_bmp.c +++ b/src/gd_bmp.c @@ -30,6 +30,7 @@ #include <stdlib.h> #include "gd.h" #include "gdhelpers.h" +#include "gd_errors.h" #include "bmp.h" static int compress_row(unsigned char *uncompressed_row, int length); @@ -266,7 +267,11 @@ static int _gdImageBmpCtx(gdImagePtr im, gdIOCtxPtr out, int compression) bitmap_size += compressed_size; - gdPutBuf(uncompressed_row, compressed_size, out); + if (gdPutBuf(uncompressed_row, compressed_size, out) != compressed_size){ + gd_error("gd-bmp write error\n"); + error = 1; + break; + } gdPutC(BMP_RLE_COMMAND, out); gdPutC(BMP_RLE_ENDOFLINE, out); bitmap_size += 2; @@ -325,7 +330,10 @@ static int _gdImageBmpCtx(gdImagePtr im, gdIOCtxPtr out, int compression) if (buffer_size == 0) { break; } - gdPutBuf(copy_buffer , buffer_size, out_original); + if (gdPutBuf(copy_buffer , buffer_size, out_original) != buffer_size) { + gd_error("gd-bmp write error\n"); + error = 1; + } } gdFree(copy_buffer); @@ -335,7 +343,7 @@ static int _gdImageBmpCtx(gdImagePtr im, gdIOCtxPtr out, int compression) out_original = NULL; } - ret = 0; + ret = error; cleanup: if (tmpfile_for_compression) { #ifdef _WIN32 diff --git a/src/gd_webp.c b/src/gd_webp.c index bf89087..e9ad802 100644 --- a/src/gd_webp.c +++ b/src/gd_webp.c @@ -227,8 +227,13 @@ static int _gdImageWebpCtx (gdImagePtr im, gdIOCtx * outfile, int quality) ret = 1; goto freeargb; } - gdPutBuf(out, out_size, outfile); + + int res = gdPutBuf(out, out_size, outfile); free(out); + if (res != out_size) { + gd_error("gd-webp write error\n"); + ret = 1; + } freeargb: gdFree(argb); |