Set duration for wav files from sample size and data size or the wf64 sample value.

This should improve duration accuracy slightly and avoids a warning about its
inaccuracy when accurate values are available. Idea by Frank Barchard

Originally committed as revision 26366 to svn://svn.ffmpeg.org/ffmpeg/trunk
oldabi
Michael Niedermayer 14 years ago
parent 13184036a6
commit 462b26202b
  1. 7
      libavformat/wav.c

@ -183,6 +183,7 @@ static int wav_read_header(AVFormatContext *s,
AVFormatParameters *ap) AVFormatParameters *ap)
{ {
int64_t size, av_uninit(data_size); int64_t size, av_uninit(data_size);
int64_t sample_count=0;
int rf64; int rf64;
unsigned int tag; unsigned int tag;
ByteIOContext *pb = s->pb; ByteIOContext *pb = s->pb;
@ -208,6 +209,7 @@ static int wav_read_header(AVFormatContext *s,
return -1; return -1;
get_le64(pb); /* RIFF size */ get_le64(pb); /* RIFF size */
data_size = get_le64(pb); data_size = get_le64(pb);
sample_count = get_le64(pb);
url_fskip(pb, size - 16); /* skip rest of ds64 chunk */ url_fskip(pb, size - 16); /* skip rest of ds64 chunk */
} }
@ -233,6 +235,11 @@ static int wav_read_header(AVFormatContext *s,
wav->data_end = INT64_MAX; wav->data_end = INT64_MAX;
} else } else
wav->data_end= url_ftell(pb) + size; wav->data_end= url_ftell(pb) + size;
if (!sample_count && st->codec->channels && av_get_bits_per_sample(st->codec->codec_id))
sample_count = (size<<3) / (st->codec->channels * (uint64_t)av_get_bits_per_sample(st->codec->codec_id));
if (sample_count)
st->duration = sample_count;
return 0; return 0;
} }

Loading…
Cancel
Save