X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=src%2Fwav_reader.c;h=2690d24187c6af4212f30a201e887dc5d5fb7cb4;hb=a7e00a42195bd01fad75e5800fcbadeb1a5d3efd;hp=e69cba7050b24ed29f6fb1f113e1cfaab1cf42a7;hpb=1af8624b009faf5bc6b9b8dfa76676483da5f6cf;p=fdkaac.git diff --git a/src/wav_reader.c b/src/wav_reader.c index e69cba7..2690d24 100644 --- a/src/wav_reader.c +++ b/src/wav_reader.c @@ -14,7 +14,7 @@ #include #include #include -#include "wav_reader.h" +#include "pcm_reader.h" #define RIFF_FOURCC(a,b,c,d) ((a)|((b)<<8)|((c)<<16)|((d)<<24)) @@ -93,7 +93,6 @@ int riff_ds64(wav_reader_t *reader, int64_t *length) TRY_IO(pcm_scanl(&reader->io, "QQQL", &riff_size, length, &sample_count, &table_size) != 4); TRY_IO(pcm_skip(&reader->io, (chunk_size - 27) & ~1)); - reader->data_offset += (chunk_size + 9) & ~1; FAIL: return -1; } @@ -163,7 +162,6 @@ int wav_parse(wav_reader_t *reader, int64_t *data_length) container == RIFF_FOURCC('R','F','6','4')); TRY_IO(pcm_read32le(&reader->io, &fcc)); ENSURE(fcc == RIFF_FOURCC('W','A','V','E')); - reader->data_offset = 12; if (container == RIFF_FOURCC('R','F','6','4')) riff_ds64(reader, data_length); @@ -174,12 +172,11 @@ int wav_parse(wav_reader_t *reader, int64_t *data_length) } else if (fcc == RIFF_FOURCC('d','a','t','a')) { if (container == RIFF_FOURCC('R','I','F','F')) *data_length = chunk_size; - reader->data_offset += 8; + reader->data_offset = pcm_tell(&reader->io); break; } else { TRY_IO(pcm_skip(&reader->io, (chunk_size + 1) & ~1)); } - reader->data_offset += (chunk_size + 9) & ~1; } if (fcc == RIFF_FOURCC('d','a','t','a')) return 0;