mp3: no "goto"

http://xkcd.com/292/
This commit is contained in:
Max Kellermann 2008-10-28 20:43:17 +01:00
parent 28b47725ff
commit 898978a67d

View File

@ -282,15 +282,18 @@ static void mp3_parse_id3(struct mp3_data *data, size_t tagsize,
if (count != tagsize) { if (count != tagsize) {
DEBUG("mp3_decode: error parsing ID3 tag\n"); DEBUG("mp3_decode: error parsing ID3 tag\n");
goto fail; g_free(allocated);
return;
} }
id3_data = allocated; id3_data = allocated;
} }
id3_tag = id3_tag_parse(id3_data, tagsize); id3_tag = id3_tag_parse(id3_data, tagsize);
if (id3_tag == NULL) if (id3_tag == NULL) {
goto fail; g_free(allocated);
return;
}
if (mpd_tag) { if (mpd_tag) {
struct tag *tmp_tag = tag_id3_import(id3_tag); struct tag *tmp_tag = tag_id3_import(id3_tag);
@ -311,7 +314,7 @@ static void mp3_parse_id3(struct mp3_data *data, size_t tagsize,
} }
id3_tag_delete(id3_tag); id3_tag_delete(id3_tag);
fail:
g_free(allocated); g_free(allocated);
} }
#endif #endif
@ -472,49 +475,65 @@ parse_xing(struct xing *xing, struct mad_bitptr *ptr, int *oldbitlen)
bitlen = *oldbitlen; bitlen = *oldbitlen;
if (bitlen < 16) goto fail; if (bitlen < 16)
return false;
bits = mad_bit_read(ptr, 16); bits = mad_bit_read(ptr, 16);
bitlen -= 16; bitlen -= 16;
if (bits == XI_MAGIC) { if (bits == XI_MAGIC) {
if (bitlen < 16) goto fail; if (bitlen < 16)
if (mad_bit_read(ptr, 16) != NG_MAGIC) goto fail; return false;
if (mad_bit_read(ptr, 16) != NG_MAGIC)
return false;
bitlen -= 16; bitlen -= 16;
xing->magic = XING_MAGIC_XING; xing->magic = XING_MAGIC_XING;
} else if (bits == IN_MAGIC) { } else if (bits == IN_MAGIC) {
if (bitlen < 16) goto fail; if (bitlen < 16)
if (mad_bit_read(ptr, 16) != FO_MAGIC) goto fail; return false;
if (mad_bit_read(ptr, 16) != FO_MAGIC)
return false;
bitlen -= 16; bitlen -= 16;
xing->magic = XING_MAGIC_INFO; xing->magic = XING_MAGIC_INFO;
} }
else if (bits == NG_MAGIC) xing->magic = XING_MAGIC_XING; else if (bits == NG_MAGIC) xing->magic = XING_MAGIC_XING;
else if (bits == FO_MAGIC) xing->magic = XING_MAGIC_INFO; else if (bits == FO_MAGIC) xing->magic = XING_MAGIC_INFO;
else goto fail; else
return false;
if (bitlen < 32) goto fail; if (bitlen < 32)
return false;
xing->flags = mad_bit_read(ptr, 32); xing->flags = mad_bit_read(ptr, 32);
bitlen -= 32; bitlen -= 32;
if (xing->flags & XING_FRAMES) { if (xing->flags & XING_FRAMES) {
if (bitlen < 32) goto fail; if (bitlen < 32)
return false;
xing->frames = mad_bit_read(ptr, 32); xing->frames = mad_bit_read(ptr, 32);
bitlen -= 32; bitlen -= 32;
} }
if (xing->flags & XING_BYTES) { if (xing->flags & XING_BYTES) {
if (bitlen < 32) goto fail; if (bitlen < 32)
return false;
xing->bytes = mad_bit_read(ptr, 32); xing->bytes = mad_bit_read(ptr, 32);
bitlen -= 32; bitlen -= 32;
} }
if (xing->flags & XING_TOC) { if (xing->flags & XING_TOC) {
if (bitlen < 800) goto fail; if (bitlen < 800)
return false;
for (i = 0; i < 100; ++i) xing->toc[i] = mad_bit_read(ptr, 8); for (i = 0; i < 100; ++i) xing->toc[i] = mad_bit_read(ptr, 8);
bitlen -= 800; bitlen -= 800;
} }
if (xing->flags & XING_SCALE) { if (xing->flags & XING_SCALE) {
if (bitlen < 32) goto fail; if (bitlen < 32)
return false;
xing->scale = mad_bit_read(ptr, 32); xing->scale = mad_bit_read(ptr, 32);
bitlen -= 32; bitlen -= 32;
} }
@ -522,7 +541,8 @@ parse_xing(struct xing *xing, struct mad_bitptr *ptr, int *oldbitlen)
/* Make sure we consume no less than 120 bytes (960 bits) in hopes that /* Make sure we consume no less than 120 bytes (960 bits) in hopes that
* the LAME tag is found there, and not right after the Xing header */ * the LAME tag is found there, and not right after the Xing header */
bitsleft = 960 - ((*oldbitlen) - bitlen); bitsleft = 960 - ((*oldbitlen) - bitlen);
if (bitsleft < 0) goto fail; if (bitsleft < 0)
return false;
else if (bitsleft > 0) { else if (bitsleft > 0) {
mad_bit_read(ptr, bitsleft); mad_bit_read(ptr, bitsleft);
bitlen -= bitsleft; bitlen -= bitsleft;
@ -531,9 +551,6 @@ parse_xing(struct xing *xing, struct mad_bitptr *ptr, int *oldbitlen)
*oldbitlen = bitlen; *oldbitlen = bitlen;
return true; return true;
fail:
xing->flags = 0;
return false;
} }
static bool static bool