X-Git-Url: http://git.asbjorn.biz/?p=swftools.git;a=blobdiff_plain;f=lib%2Fwav.c;h=ff577c702825fed4a75e90ef8065d43021f79b52;hp=86a8bb3a6e70567202f534b10b79f45044e45fed;hb=e0a27e1bd83ff2d60745dd6030e0f5ef7ef97b82;hpb=6c3ab5574d31504d24710c2756899d49275c1a37 diff --git a/lib/wav.c b/lib/wav.c index 86a8bb3..ff577c7 100644 --- a/lib/wav.c +++ b/lib/wav.c @@ -46,7 +46,7 @@ int getWAVBlock(FILE*fi, struct WAVBlock*block) return 1; } -int wav_read(struct WAV*wav, char* filename) +int wav_read(struct WAV*wav, const char* filename) { FILE*fi = fopen(filename, "rb"); unsigned char b[16]; @@ -131,13 +131,17 @@ int wav_read(struct WAV*wav, char* filename) return 0; } l = fread(wav->data, 1, block.size, fi); - if(l < block.size) - { - fprintf(stderr, "Error while reading data block of size %d (%d bytes missing)", block.size, block.size-l); + if(l<=0) { + fprintf(stderr, "Error: Couldn't read WAV data block\n"); fclose(fi); return 0; + } else if(l < block.size) + { + fprintf(stderr, "Warning: data block of size %d is only %d bytes (%d bytes missing)\n", block.size, l, block.size-l); + wav->size = l; + } else { + wav->size = block.size; } - wav->size = block.size; } pos+=block.size; fseek(fi, pos, SEEK_SET); @@ -147,7 +151,7 @@ int wav_read(struct WAV*wav, char* filename) return 1; } -int wav_write(struct WAV*wav, char*filename) +int wav_write(struct WAV*wav, const char*filename) { FILE*fi = fopen(filename, "wb"); char*b="RIFFWAVEfmt \x10\0\0\0data";