summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlex Beregszaszi <alex@rtfs.hu>2006-01-15 01:19:02 +0000
committerAlex Beregszaszi <alex@rtfs.hu>2006-01-15 01:19:02 +0000
commit0c2ed2df5aa574d3ad5754cc76b2b2ceb4a19095 (patch)
treeee456234ae94da4b51266517e3ae205b676befd1
parent29a10be0d4c748446de746eecf1cfeaedcbe0aff (diff)
downloadffmpeg-0c2ed2df5aa574d3ad5754cc76b2b2ceb4a19095.tar.gz
10l: now it works really, with 1k outbut buffers it failed more times, with 65k it looks safe with all samples i had
Originally committed as revision 4861 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r--cws2fws.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/cws2fws.c b/cws2fws.c
index 67ef96cd52..eb02f58171 100644
--- a/cws2fws.c
+++ b/cws2fws.c
@@ -19,7 +19,7 @@
main(int argc, char *argv[])
{
int fd_in, fd_out, comp_len, uncomp_len, tag, i, last_out;
- char buf_in[1024], buf_out[1024];
+ char buf_in[1024], buf_out[65536];
z_stream zstream;
struct stat statbuf;
@@ -73,7 +73,7 @@ main(int argc, char *argv[])
zstream.opaque = NULL;
inflateInit(&zstream);
- for (i = 0; i < comp_len-4;)
+ for (i = 0; i < comp_len-8;)
{
int ret, len = read(fd_in, &buf_in, 1024);
@@ -84,12 +84,10 @@ main(int argc, char *argv[])
zstream.next_in = &buf_in[0];
zstream.avail_in = len;
zstream.next_out = &buf_out[0];
- zstream.avail_out = 1024;
+ zstream.avail_out = 65536;
ret = inflate(&zstream, Z_SYNC_FLUSH);
- if (ret == Z_STREAM_END || ret == Z_BUF_ERROR)
- break;
- if (ret != Z_OK)
+ if (ret != Z_STREAM_END && ret != Z_OK)
{
printf("Error while decompressing: %d\n", ret);
inflateEnd(&zstream);
@@ -103,6 +101,9 @@ main(int argc, char *argv[])
write(fd_out, &buf_out, zstream.total_out-last_out);
i += len;
+
+ if (ret == Z_STREAM_END || ret == Z_BUF_ERROR)
+ break;
}
if (zstream.total_out != uncomp_len-8)