X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=tools%2Fcws2fws.c;h=74588c10a695da76fa872346bda65d37c87743a3;hb=a9a1bc56abf1fa79104996bf7b98b12ca42cd32c;hp=f81e2e26eae1296bcb15b10d3339ba9df1e075f7;hpb=21f41fa667d19f4fb46fceb815c23bd6d0e95b1a;p=ffmpeg diff --git a/tools/cws2fws.c b/tools/cws2fws.c index f81e2e26eae..74588c10a69 100644 --- a/tools/cws2fws.c +++ b/tools/cws2fws.c @@ -6,17 +6,23 @@ * This utility converts compressed Macromedia Flash files to uncompressed ones. */ +#include "config.h" #include #include #include #include +#if HAVE_UNISTD_H #include +#endif +#if HAVE_IO_H +#include +#endif #include #ifdef DEBUG #define dbgprintf printf #else -#define dbgprintf +#define dbgprintf(...) #endif int main(int argc, char *argv[]) @@ -26,82 +32,83 @@ int main(int argc, char *argv[]) z_stream zstream; struct stat statbuf; - if (argc < 3) - { + if (argc < 3) { printf("Usage: %s \n", argv[0]); - exit(1); + return 1; } fd_in = open(argv[1], O_RDONLY); - if (fd_in < 0) - { - perror("Error while opening: "); - exit(1); + if (fd_in < 0) { + perror("Error opening input file"); + return 1; } - fd_out = open(argv[2], O_WRONLY|O_CREAT, 00644); - if (fd_out < 0) - { - perror("Error while opening: "); + fd_out = open(argv[2], O_WRONLY | O_CREAT, 00644); + if (fd_out < 0) { + perror("Error opening output file"); close(fd_in); - exit(1); + return 1; } - if (read(fd_in, &buf_in, 8) != 8) - { + if (read(fd_in, &buf_in, 8) != 8) { printf("Header error\n"); close(fd_in); close(fd_out); - exit(1); + return 1; } - if (buf_in[0] != 'C' || buf_in[1] != 'W' || buf_in[2] != 'S') - { + if (buf_in[0] != 'C' || buf_in[1] != 'W' || buf_in[2] != 'S') { printf("Not a compressed flash file\n"); - exit(1); + return 1; } fstat(fd_in, &statbuf); - comp_len = statbuf.st_size; + comp_len = statbuf.st_size; uncomp_len = buf_in[4] | (buf_in[5] << 8) | (buf_in[6] << 16) | (buf_in[7] << 24); - printf("Compressed size: %d Uncompressed size: %d\n", comp_len-4, uncomp_len-4); + printf("Compressed size: %d Uncompressed size: %d\n", + comp_len - 4, uncomp_len - 4); // write out modified header buf_in[0] = 'F'; - write(fd_out, &buf_in, 8); + if (write(fd_out, &buf_in, 8) < 8) { + perror("Error writing output file"); + return 1; + } zstream.zalloc = NULL; - zstream.zfree = NULL; + zstream.zfree = NULL; zstream.opaque = NULL; inflateInit(&zstream); - for (i = 0; i < comp_len-8;) - { + for (i = 0; i < comp_len - 8;) { int ret, len = read(fd_in, &buf_in, 1024); dbgprintf("read %d bytes\n", len); last_out = zstream.total_out; - zstream.next_in = &buf_in[0]; - zstream.avail_in = len; - zstream.next_out = &buf_out[0]; + zstream.next_in = &buf_in[0]; + zstream.avail_in = len; + zstream.next_out = &buf_out[0]; zstream.avail_out = 65536; ret = inflate(&zstream, Z_SYNC_FLUSH); - if (ret != Z_STREAM_END && ret != Z_OK) - { + if (ret != Z_STREAM_END && ret != Z_OK) { printf("Error while decompressing: %d\n", ret); inflateEnd(&zstream); - exit(1); + return 1; } - dbgprintf("a_in: %d t_in: %d a_out: %d t_out: %d -- %d out\n", - zstream.avail_in, zstream.total_in, zstream.avail_out, zstream.total_out, - zstream.total_out-last_out); + dbgprintf("a_in: %d t_in: %lu a_out: %d t_out: %lu -- %lu out\n", + zstream.avail_in, zstream.total_in, zstream.avail_out, + zstream.total_out, zstream.total_out - last_out); - write(fd_out, &buf_out, zstream.total_out-last_out); + if (write(fd_out, &buf_out, zstream.total_out - last_out) < + zstream.total_out - last_out) { + perror("Error writing output file"); + return 1; + } i += len; @@ -109,18 +116,20 @@ int main(int argc, char *argv[]) break; } - if (zstream.total_out != uncomp_len-8) - { - printf("Size mismatch (%d != %d), updating header...\n", - zstream.total_out, uncomp_len-8); + if (zstream.total_out != uncomp_len - 8) { + printf("Size mismatch (%lu != %d), updating header...\n", + zstream.total_out, uncomp_len - 8); - buf_in[0] = (zstream.total_out+8) & 0xff; - buf_in[1] = (zstream.total_out+8 >> 8) & 0xff; - buf_in[2] = (zstream.total_out+8 >> 16) & 0xff; - buf_in[3] = (zstream.total_out+8 >> 24) & 0xff; + buf_in[0] = (zstream.total_out + 8) & 0xff; + buf_in[1] = ((zstream.total_out + 8) >> 8) & 0xff; + buf_in[2] = ((zstream.total_out + 8) >> 16) & 0xff; + buf_in[3] = ((zstream.total_out + 8) >> 24) & 0xff; lseek(fd_out, 4, SEEK_SET); - write(fd_out, &buf_in, 4); + if (write(fd_out, &buf_in, 4) < 4) { + perror("Error writing output file"); + return 1; + } } inflateEnd(&zstream);