since GetStreamInfo is called multiple times, moved initialization into AllocateCookie
git-svn-id: file:///srv/svn/repos/haiku/trunk/current@6800 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
d796ec827a
commit
d480685184
@ -5,7 +5,6 @@
|
|||||||
|
|
||||||
|
|
||||||
#include "MusePackReader.h"
|
#include "MusePackReader.h"
|
||||||
#include "mpc/mpc_dec.h"
|
|
||||||
|
|
||||||
#include <InterfaceDefs.h>
|
#include <InterfaceDefs.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -55,6 +54,16 @@ MusePackReader::Sniff(int32 *_streamCount)
|
|||||||
void
|
void
|
||||||
MusePackReader::GetFileFormatInfo(media_file_format *mff)
|
MusePackReader::GetFileFormatInfo(media_file_format *mff)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
mff->capabilities = media_file_format::B_READABLE
|
||||||
|
| media_file_format::B_KNOWS_ENCODED_AUDIO
|
||||||
|
| media_file_format::B_IMPERFECTLY_SEEKABLE;
|
||||||
|
mff->family = B_MISC_FORMAT_FAMILY;
|
||||||
|
mff->version = 100;
|
||||||
|
strcpy(mff->mime_type, "audio/x-mpc");
|
||||||
|
strcpy(mff->file_extension, "mpc");
|
||||||
|
strcpy(mff->short_name, "MusePack");
|
||||||
|
strcpy(mff->pretty_name, "MusePack");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -63,6 +72,36 @@ MusePackReader::AllocateCookie(int32 streamNumber, void **_cookie)
|
|||||||
{
|
{
|
||||||
// we don't need a cookie - we only know one single stream
|
// we don't need a cookie - we only know one single stream
|
||||||
*_cookie = NULL;
|
*_cookie = NULL;
|
||||||
|
|
||||||
|
media_format_description description;
|
||||||
|
description.family = B_MISC_FORMAT_FAMILY;
|
||||||
|
description.u.misc.file_format = 'mpc ';
|
||||||
|
description.u.misc.codec = 'MPC7';
|
||||||
|
// 7 is the most recent stream version
|
||||||
|
|
||||||
|
status_t status = BMediaFormats().GetFormatFor(description, &fFormat);
|
||||||
|
if (status < B_OK)
|
||||||
|
return status;
|
||||||
|
|
||||||
|
// allocate and initialize internal decoder
|
||||||
|
fDecoder = new MPC_decoder(static_cast<BPositionIO *>(Source()));
|
||||||
|
fDecoder->RESET_Globals();
|
||||||
|
fDecoder->RESET_Synthesis();
|
||||||
|
fDecoder->SetStreamInfo(&fInfo);
|
||||||
|
if (!fDecoder->FileInit()) {
|
||||||
|
delete fDecoder;
|
||||||
|
fDecoder = 0;
|
||||||
|
return B_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0 // not required to report
|
||||||
|
fFormat.u.encoded_audio.output.frame_rate = fInfo.simple.SampleFreq;
|
||||||
|
fFormat.u.encoded_audio.output.channel_count = fInfo.simple.Channels;
|
||||||
|
fFormat.u.encoded_audio.output.format = media_raw_audio_format::B_AUDIO_FLOAT;
|
||||||
|
fFormat.u.encoded_audio.output.byte_order = B_MEDIA_HOST_ENDIAN;
|
||||||
|
fFormat.u.encoded_audio.output.buffer_size = sizeof(MPC_SAMPLE_FORMAT) * FRAMELEN * 2;
|
||||||
|
#endif
|
||||||
|
|
||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,28 +125,10 @@ MusePackReader::GetStreamInfo(void *cookie, int64 *_frameCount, bigtime_t *_dura
|
|||||||
*_duration = bigtime_t(1000.0 * (fInfo.simple.Frames - 0.5) * FRAMELEN
|
*_duration = bigtime_t(1000.0 * (fInfo.simple.Frames - 0.5) * FRAMELEN
|
||||||
/ (fInfo.simple.SampleFreq / 1000) + 0.5);
|
/ (fInfo.simple.SampleFreq / 1000) + 0.5);
|
||||||
|
|
||||||
media_format_description description;
|
*format = fFormat;
|
||||||
description.family = B_MISC_FORMAT_FAMILY;
|
|
||||||
description.u.misc.file_format = 'mpc ';
|
|
||||||
description.u.misc.codec = 'MPC7';
|
|
||||||
// 7 is the most recent stream version
|
|
||||||
|
|
||||||
status_t status = BMediaFormats().GetFormatFor(description, format);
|
|
||||||
if (status < B_OK)
|
|
||||||
return status;
|
|
||||||
|
|
||||||
// allocate and initialize internal decoder
|
|
||||||
MPC_decoder *decoder = new MPC_decoder(static_cast<BPositionIO *>(Source()));
|
|
||||||
decoder->RESET_Globals();
|
|
||||||
decoder->RESET_Synthesis();
|
|
||||||
decoder->SetStreamInfo(&fInfo);
|
|
||||||
if (!decoder->FileInit()) {
|
|
||||||
delete decoder;
|
|
||||||
return B_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
// we provide the stream info in this place
|
// we provide the stream info in this place
|
||||||
*_infoBuffer = (void *)decoder;
|
*_infoBuffer = (void *)fDecoder;
|
||||||
*_infoSize = sizeof(MPC_decoder);
|
*_infoSize = sizeof(MPC_decoder);
|
||||||
|
|
||||||
return B_OK;
|
return B_OK;
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include <MediaFormats.h>
|
#include <MediaFormats.h>
|
||||||
|
|
||||||
#include "mpc/in_mpc.h"
|
#include "mpc/in_mpc.h"
|
||||||
|
#include "mpc/mpc_dec.h"
|
||||||
|
|
||||||
|
|
||||||
class MusePackReader : public Reader {
|
class MusePackReader : public Reader {
|
||||||
@ -37,6 +38,8 @@ class MusePackReader : public Reader {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
StreamInfo fInfo;
|
StreamInfo fInfo;
|
||||||
|
media_format fFormat;
|
||||||
|
MPC_decoder *fDecoder;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* MUSEPACK_READER_H */
|
#endif /* MUSEPACK_READER_H */
|
||||||
|
Loading…
Reference in New Issue
Block a user