Thanks for making my code totally unreadable indent!
git-svn-id: https://svn.musicpd.org/mpd/trunk@4455 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
e880a878bc
commit
0979b0f75e
@ -450,7 +450,7 @@ enum {
|
|||||||
XING_FRAMES = 0x00000001L,
|
XING_FRAMES = 0x00000001L,
|
||||||
XING_BYTES = 0x00000002L,
|
XING_BYTES = 0x00000002L,
|
||||||
XING_TOC = 0x00000004L,
|
XING_TOC = 0x00000004L,
|
||||||
XING_SCALE = 0x00000008L
|
XING_SCALE = 0x00000008L,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int parse_xing(struct xing *xing, struct mad_bitptr *ptr, int bitlen)
|
static int parse_xing(struct xing *xing, struct mad_bitptr *ptr, int bitlen)
|
||||||
@ -462,62 +462,49 @@ static int parse_xing(struct xing *xing, struct mad_bitptr *ptr, int bitlen)
|
|||||||
|
|
||||||
oldbitlen = bitlen;
|
oldbitlen = bitlen;
|
||||||
|
|
||||||
if (bitlen < 16)
|
if (bitlen < 16) goto fail;
|
||||||
goto fail;
|
|
||||||
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)
|
if (bitlen < 16) goto fail;
|
||||||
goto fail;
|
if (mad_bit_read(ptr, 16) != NG_MAGIC) goto fail;
|
||||||
if (mad_bit_read(ptr, 16) != NG_MAGIC)
|
|
||||||
goto fail;
|
|
||||||
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)
|
if (bitlen < 16) goto fail;
|
||||||
goto fail;
|
if (mad_bit_read(ptr, 16) != FO_MAGIC) goto fail;
|
||||||
if (mad_bit_read(ptr, 16) != FO_MAGIC)
|
|
||||||
goto fail;
|
|
||||||
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)
|
else if (bits == FO_MAGIC) xing->magic = XING_MAGIC_INFO;
|
||||||
xing->magic = XING_MAGIC_INFO;
|
else goto fail;
|
||||||
else
|
|
||||||
goto fail;
|
|
||||||
|
|
||||||
if (bitlen < 32)
|
if (bitlen < 32) goto fail;
|
||||||
goto fail;
|
|
||||||
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)
|
if (bitlen < 32) goto fail;
|
||||||
goto fail;
|
|
||||||
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)
|
if (bitlen < 32) goto fail;
|
||||||
goto fail;
|
|
||||||
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)
|
if (bitlen < 800) goto fail;
|
||||||
goto fail;
|
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)
|
if (bitlen < 32) goto fail;
|
||||||
goto fail;
|
|
||||||
xing->scale = mad_bit_read(ptr, 32);
|
xing->scale = mad_bit_read(ptr, 32);
|
||||||
bitlen -= 32;
|
bitlen -= 32;
|
||||||
}
|
}
|
||||||
@ -525,8 +512,7 @@ static int parse_xing(struct xing *xing, struct mad_bitptr *ptr, int bitlen)
|
|||||||
/* 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)
|
if (bitsleft < 0) goto fail;
|
||||||
goto fail;
|
|
||||||
else if (bitsleft > 0) {
|
else if (bitsleft > 0) {
|
||||||
mad_bit_read(ptr, bitsleft);
|
mad_bit_read(ptr, bitsleft);
|
||||||
bitlen -= bitsleft;
|
bitlen -= bitsleft;
|
||||||
@ -538,12 +524,11 @@ static int parse_xing(struct xing *xing, struct mad_bitptr *ptr, int bitlen)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int parse_extension_headers(struct xing *xing, struct mad_bitptr ptr,
|
static int parse_extensions(struct xing *xing, struct mad_bitptr ptr,
|
||||||
int bitlen)
|
int bitlen)
|
||||||
{
|
{
|
||||||
bitlen = parse_xing(xing, &ptr, bitlen);
|
bitlen = parse_xing(xing, &ptr, bitlen);
|
||||||
if (bitlen < 0)
|
if (bitlen < 0) return 0;
|
||||||
return 0;
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -560,50 +545,41 @@ static int decodeFirstFrame(mp3DecodeData * data, DecoderControl * dc,
|
|||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
skip = 0;
|
skip = 0;
|
||||||
while ((ret =
|
while ((ret = decodeNextFrameHeader(data, tag, replayGainInfo)) == DECODE_CONT &&
|
||||||
decodeNextFrameHeader(data, tag,
|
(!dc || !dc->stop));
|
||||||
replayGainInfo)) == DECODE_CONT
|
|
||||||
&& (!dc || !dc->stop)) ;
|
if (ret == DECODE_SKIP) skip = 1;
|
||||||
if (ret == DECODE_SKIP)
|
else if (ret == DECODE_BREAK || (dc && dc->stop)) return -1;
|
||||||
skip = 1;
|
|
||||||
else if (ret == DECODE_BREAK || (dc && dc->stop))
|
|
||||||
return -1;
|
|
||||||
while ((ret = decodeNextFrame(data)) == DECODE_CONT &&
|
while ((ret = decodeNextFrame(data)) == DECODE_CONT &&
|
||||||
(!dc || !dc->stop)) ;
|
(!dc || !dc->stop));
|
||||||
if (ret == DECODE_BREAK || (dc && dc->stop))
|
|
||||||
return -1;
|
if (ret == DECODE_BREAK || (dc && dc->stop)) return -1;
|
||||||
if (!skip && ret == DECODE_OK)
|
if (!skip && ret == DECODE_OK) break;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parse_extension_headers(&xing, data->stream.anc_ptr,
|
if (parse_extensions(&xing, data->stream.anc_ptr,
|
||||||
(int)data->stream.anc_bitlen)) {
|
(int)data->stream.anc_bitlen)) {
|
||||||
if (xing.flags & XING_FRAMES) {
|
if (xing.flags & XING_FRAMES) {
|
||||||
mad_timer_t duration = data->frame.header.duration;
|
mad_timer_t duration = data->frame.header.duration;
|
||||||
mad_timer_multiply(&duration, xing.frames);
|
mad_timer_multiply(&duration, xing.frames);
|
||||||
data->muteFrame = MUTEFRAME_SKIP;
|
data->muteFrame = MUTEFRAME_SKIP;
|
||||||
data->totalTime = ((float)mad_timer_count(duration,
|
data->totalTime = ((float)mad_timer_count(duration, MAD_UNITS_MILLISECONDS)) / 1000;
|
||||||
MAD_UNITS_MILLISECONDS))
|
|
||||||
/ 1000;
|
|
||||||
data->maxFrames = xing.frames;
|
data->maxFrames = xing.frames;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
size_t offset = data->inStream->offset;
|
size_t offset = data->inStream->offset;
|
||||||
mad_timer_t duration = data->frame.header.duration;
|
mad_timer_t duration = data->frame.header.duration;
|
||||||
float frameTime = ((float)mad_timer_count(duration,
|
float frameTime = ((float)mad_timer_count(duration, MAD_UNITS_MILLISECONDS)) / 1000;
|
||||||
MAD_UNITS_MILLISECONDS))
|
|
||||||
/ 1000;
|
if (data->stream.this_frame != NULL)
|
||||||
if (data->stream.this_frame != NULL) {
|
|
||||||
offset -= data->stream.bufend - data->stream.this_frame;
|
offset -= data->stream.bufend - data->stream.this_frame;
|
||||||
} else {
|
else
|
||||||
offset -= data->stream.bufend - data->stream.buffer;
|
offset -= data->stream.bufend - data->stream.buffer;
|
||||||
}
|
|
||||||
if (data->inStream->size >= offset) {
|
if (data->inStream->size >= offset) {
|
||||||
data->totalTime =
|
data->totalTime = ((data->inStream->size - offset) * 8.0) / (data->frame).header.bitrate;
|
||||||
((data->inStream->size -
|
data->maxFrames = data->totalTime / frameTime + FRAMES_CUSHION;
|
||||||
offset) * 8.0) / (data->frame).header.bitrate;
|
|
||||||
data->maxFrames =
|
|
||||||
data->totalTime / frameTime + FRAMES_CUSHION;
|
|
||||||
} else {
|
} else {
|
||||||
data->maxFrames = FRAMES_CUSHION;
|
data->maxFrames = FRAMES_CUSHION;
|
||||||
data->totalTime = 0;
|
data->totalTime = 0;
|
||||||
@ -622,10 +598,8 @@ static void mp3DecodeDataFinalize(mp3DecodeData * data)
|
|||||||
mad_frame_finish(&data->frame);
|
mad_frame_finish(&data->frame);
|
||||||
mad_stream_finish(&data->stream);
|
mad_stream_finish(&data->stream);
|
||||||
|
|
||||||
if (data->frameOffset)
|
if (data->frameOffset) free(data->frameOffset);
|
||||||
free(data->frameOffset);
|
if (data->times) free(data->times);
|
||||||
if (data->times)
|
|
||||||
free(data->times);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* this is primarily used for getting total time for tags */
|
/* this is primarily used for getting total time for tags */
|
||||||
|
Loading…
Reference in New Issue
Block a user