mp3: added mp3DecodeData.decoder
We need the decoder object at several places in the mp3 plugin. Add it to mp3DecodeData, so we don't have to pass it around in every function.
This commit is contained in:
parent
7653ab434e
commit
468f61d587
@ -165,12 +165,14 @@ typedef struct _mp3DecodeData {
|
|||||||
int foundFirstFrame;
|
int foundFirstFrame;
|
||||||
int decodedFirstFrame;
|
int decodedFirstFrame;
|
||||||
unsigned long bitRate;
|
unsigned long bitRate;
|
||||||
|
struct decoder *decoder;
|
||||||
InputStream *inStream;
|
InputStream *inStream;
|
||||||
struct audio_dither dither;
|
struct audio_dither dither;
|
||||||
enum mad_layer layer;
|
enum mad_layer layer;
|
||||||
} mp3DecodeData;
|
} mp3DecodeData;
|
||||||
|
|
||||||
static void initMp3DecodeData(mp3DecodeData * data, InputStream * inStream)
|
static void initMp3DecodeData(mp3DecodeData * data, struct decoder *decoder,
|
||||||
|
InputStream * inStream)
|
||||||
{
|
{
|
||||||
data->muteFrame = 0;
|
data->muteFrame = 0;
|
||||||
data->highestFrame = 0;
|
data->highestFrame = 0;
|
||||||
@ -185,6 +187,7 @@ static void initMp3DecodeData(mp3DecodeData * data, InputStream * inStream)
|
|||||||
data->foundXing = 0;
|
data->foundXing = 0;
|
||||||
data->foundFirstFrame = 0;
|
data->foundFirstFrame = 0;
|
||||||
data->decodedFirstFrame = 0;
|
data->decodedFirstFrame = 0;
|
||||||
|
data->decoder = decoder;
|
||||||
data->inStream = inStream;
|
data->inStream = inStream;
|
||||||
data->layer = 0;
|
data->layer = 0;
|
||||||
memset(&(data->dither), 0, sizeof(struct audio_dither));
|
memset(&(data->dither), 0, sizeof(struct audio_dither));
|
||||||
@ -682,9 +685,10 @@ static int parse_lame(struct lame *lame, struct mad_bitptr *ptr, int *bitlen)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int decodeFirstFrame(mp3DecodeData * data, struct decoder * decoder,
|
static int decodeFirstFrame(mp3DecodeData * data,
|
||||||
MpdTag ** tag, ReplayGainInfo ** replayGainInfo)
|
MpdTag ** tag, ReplayGainInfo ** replayGainInfo)
|
||||||
{
|
{
|
||||||
|
struct decoder *decoder = data->decoder;
|
||||||
struct xing xing;
|
struct xing xing;
|
||||||
struct lame lame;
|
struct lame lame;
|
||||||
struct mad_bitptr ptr;
|
struct mad_bitptr ptr;
|
||||||
@ -798,8 +802,8 @@ static int getMp3TotalTime(char *file)
|
|||||||
|
|
||||||
if (openInputStream(&inStream, file) < 0)
|
if (openInputStream(&inStream, file) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
initMp3DecodeData(&data, &inStream);
|
initMp3DecodeData(&data, NULL, &inStream);
|
||||||
if (decodeFirstFrame(&data, NULL, NULL, NULL) < 0)
|
if (decodeFirstFrame(&data, NULL, NULL) < 0)
|
||||||
ret = -1;
|
ret = -1;
|
||||||
else
|
else
|
||||||
ret = data.totalTime + 0.5;
|
ret = data.totalTime + 0.5;
|
||||||
@ -813,9 +817,9 @@ static int openMp3FromInputStream(InputStream * inStream, mp3DecodeData * data,
|
|||||||
struct decoder * decoder, MpdTag ** tag,
|
struct decoder * decoder, MpdTag ** tag,
|
||||||
ReplayGainInfo ** replayGainInfo)
|
ReplayGainInfo ** replayGainInfo)
|
||||||
{
|
{
|
||||||
initMp3DecodeData(data, inStream);
|
initMp3DecodeData(data, decoder, inStream);
|
||||||
*tag = NULL;
|
*tag = NULL;
|
||||||
if (decodeFirstFrame(data, decoder, tag, replayGainInfo) < 0) {
|
if (decodeFirstFrame(data, tag, replayGainInfo) < 0) {
|
||||||
mp3DecodeDataFinalize(data);
|
mp3DecodeDataFinalize(data);
|
||||||
if (tag && *tag)
|
if (tag && *tag)
|
||||||
freeMpdTag(*tag);
|
freeMpdTag(*tag);
|
||||||
@ -825,9 +829,9 @@ static int openMp3FromInputStream(InputStream * inStream, mp3DecodeData * data,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int mp3Read(mp3DecodeData * data, struct decoder *decoder,
|
static int mp3Read(mp3DecodeData * data, ReplayGainInfo ** replayGainInfo)
|
||||||
ReplayGainInfo ** replayGainInfo)
|
|
||||||
{
|
{
|
||||||
|
struct decoder *decoder = data->decoder;
|
||||||
unsigned int pcm_length, max_samples;
|
unsigned int pcm_length, max_samples;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
int ret;
|
int ret;
|
||||||
@ -1062,7 +1066,7 @@ static int mp3_decode(struct decoder * decoder, InputStream * inStream)
|
|||||||
|
|
||||||
decoder_initialized(decoder, &audio_format, data.totalTime);
|
decoder_initialized(decoder, &audio_format, data.totalTime);
|
||||||
|
|
||||||
while (mp3Read(&data, decoder, &replayGainInfo) != DECODE_BREAK) ;
|
while (mp3Read(&data, &replayGainInfo) != DECODE_BREAK) ;
|
||||||
|
|
||||||
if (replayGainInfo)
|
if (replayGainInfo)
|
||||||
freeReplayGainInfo(replayGainInfo);
|
freeReplayGainInfo(replayGainInfo);
|
||||||
|
Loading…
Reference in New Issue
Block a user