mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-11-21 10:55:51 +02:00
Refactor the tag checking into a switch statement
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
parent
93df511ec7
commit
a06d238e8c
@ -254,7 +254,8 @@ static int wav_read_header(AVFormatContext *s,
|
||||
size = next_tag(pb, &tag);
|
||||
next_tag_ofs = avio_tell(pb) + size;
|
||||
|
||||
if (tag == MKTAG('f', 'm', 't', ' ')) {
|
||||
switch (tag) {
|
||||
case MKTAG('f', 'm', 't', ' '):
|
||||
/* only parse the first 'fmt ' tag found */
|
||||
if (!got_fmt && (ret = wav_parse_fmt_tag(s, size, &st) < 0)) {
|
||||
return ret;
|
||||
@ -262,18 +263,22 @@ static int wav_read_header(AVFormatContext *s,
|
||||
av_log(s, AV_LOG_WARNING, "found more than one 'fmt ' tag\n");
|
||||
|
||||
got_fmt = 1;
|
||||
} else if (tag == MKTAG('d', 'a', 't', 'a')) {
|
||||
break;
|
||||
case MKTAG('d', 'a', 't', 'a'):
|
||||
if (!got_fmt) {
|
||||
av_log(s, AV_LOG_ERROR, "found no 'fmt ' tag before the 'data' tag\n");
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
|
||||
break;
|
||||
}else if (tag == MKTAG('f','a','c','t') && !sample_count){
|
||||
goto break_loop;
|
||||
case MKTAG('f','a','c','t'):
|
||||
if(!sample_count)
|
||||
sample_count = avio_rl32(pb);
|
||||
break;
|
||||
}
|
||||
avio_seek(pb, next_tag_ofs, SEEK_SET);
|
||||
}
|
||||
break_loop:
|
||||
if (rf64)
|
||||
size = data_size;
|
||||
if (size < 0)
|
||||
|
Loading…
Reference in New Issue
Block a user