mp3: eliminated outputPtr

The output buffer is always flushed after being appended to, which
allows us to assume it is always empty.  Always start writing at
outputBuffer, don't remember outputPtr.
This commit is contained in:
Max Kellermann 2008-08-26 08:27:13 +02:00
parent f0bcb4a44a
commit 3f55b5a1e4

View File

@ -151,8 +151,6 @@ typedef struct _mp3DecodeData {
mad_timer_t timer; mad_timer_t timer;
unsigned char readBuffer[READ_BUFFER_SIZE]; unsigned char readBuffer[READ_BUFFER_SIZE];
char outputBuffer[MP3_DATA_OUTPUT_BUFFER_SIZE]; char outputBuffer[MP3_DATA_OUTPUT_BUFFER_SIZE];
char *outputPtr;
char *outputBufferEnd;
float totalTime; float totalTime;
float elapsedTime; float elapsedTime;
int muteFrame; int muteFrame;
@ -176,9 +174,6 @@ typedef struct _mp3DecodeData {
static void initMp3DecodeData(mp3DecodeData * data, InputStream * inStream) static void initMp3DecodeData(mp3DecodeData * data, InputStream * inStream)
{ {
data->outputPtr = data->outputBuffer;
data->outputBufferEnd =
data->outputBuffer + MP3_DATA_OUTPUT_BUFFER_SIZE;
data->muteFrame = 0; data->muteFrame = 0;
data->highestFrame = 0; data->highestFrame = 0;
data->maxFrames = 0; data->maxFrames = 0;
@ -871,7 +866,6 @@ static int mp3Read(mp3DecodeData * data, struct decoder *decoder,
break; break;
case MUTEFRAME_SEEK: case MUTEFRAME_SEEK:
if (decoder_seek_where(decoder) <= data->elapsedTime) { if (decoder_seek_where(decoder) <= data->elapsedTime) {
data->outputPtr = data->outputBuffer;
decoder_clear(decoder); decoder_clear(decoder);
data->muteFrame = 0; data->muteFrame = 0;
decoder_command_finished(decoder); decoder_command_finished(decoder);
@ -930,31 +924,27 @@ static int mp3Read(mp3DecodeData * data, struct decoder *decoder,
while (i < pcm_length) { while (i < pcm_length) {
enum decoder_command cmd; enum decoder_command cmd;
unsigned int num_samples = unsigned int num_samples = sizeof(data->outputBuffer) /
(data->outputBufferEnd - data->outputPtr) /
(2 * MAD_NCHANNELS(&(data->frame).header)); (2 * MAD_NCHANNELS(&(data->frame).header));
if (num_samples > pcm_length - i) if (num_samples > pcm_length - i)
num_samples = pcm_length - i; num_samples = pcm_length - i;
i += num_samples; i += num_samples;
num_samples = dither_buffer((mpd_sint16 *) data->outputPtr, num_samples = dither_buffer((mpd_sint16 *) data->outputBuffer,
&data->synth, &data->dither, &data->synth, &data->dither,
i - num_samples, i, i - num_samples, i,
MAD_NCHANNELS(&(data->frame).header)); MAD_NCHANNELS(&(data->frame).header));
data->outputPtr += 2 * num_samples;
cmd = decoder_data(decoder, data->inStream, cmd = decoder_data(decoder, data->inStream,
data->inStream->seekable, data->inStream->seekable,
data->outputBuffer, data->outputBuffer,
data->outputPtr - data->outputBuffer, 2 * num_samples,
data->elapsedTime, data->elapsedTime,
data->bitRate / 1000, data->bitRate / 1000,
(replayGainInfo != NULL) ? *replayGainInfo : NULL); (replayGainInfo != NULL) ? *replayGainInfo : NULL);
if (cmd == DECODE_COMMAND_STOP) if (cmd == DECODE_COMMAND_STOP)
return DECODE_BREAK; return DECODE_BREAK;
data->outputPtr = data->outputBuffer;
} }
if (data->dropSamplesAtEnd && if (data->dropSamplesAtEnd &&
@ -978,7 +968,6 @@ static int mp3Read(mp3DecodeData * data, struct decoder *decoder,
if (seekMp3InputBuffer(data, if (seekMp3InputBuffer(data,
data->frameOffset[j]) == data->frameOffset[j]) ==
0) { 0) {
data->outputPtr = data->outputBuffer;
decoder_clear(decoder); decoder_clear(decoder);
data->currentFrame = j; data->currentFrame = j;
decoder_command_finished(decoder); decoder_command_finished(decoder);