decoder/wavpack: move variable declarations

This commit is contained in:
Max Kellermann 2013-10-23 23:20:55 +02:00
parent 93deb84499
commit 0a5c991ab5

View File

@ -140,19 +140,13 @@ wavpack_bits_to_sample_format(bool is_float, int bytes_per_sample)
static void static void
wavpack_decode(Decoder &decoder, WavpackContext *wpc, bool can_seek) wavpack_decode(Decoder &decoder, WavpackContext *wpc, bool can_seek)
{ {
bool is_float; bool is_float = (WavpackGetMode(wpc) & MODE_FLOAT) != 0;
SampleFormat sample_format; SampleFormat sample_format =
AudioFormat audio_format;
format_samples_t format_samples;
float total_time;
int bytes_per_sample, output_sample_size;
is_float = (WavpackGetMode(wpc) & MODE_FLOAT) != 0;
sample_format =
wavpack_bits_to_sample_format(is_float, wavpack_bits_to_sample_format(is_float,
WavpackGetBytesPerSample(wpc)); WavpackGetBytesPerSample(wpc));
Error error; Error error;
AudioFormat audio_format;
if (!audio_format_init_checked(audio_format, if (!audio_format_init_checked(audio_format,
WavpackGetSampleRate(wpc), WavpackGetSampleRate(wpc),
sample_format, sample_format,
@ -161,16 +155,15 @@ wavpack_decode(Decoder &decoder, WavpackContext *wpc, bool can_seek)
return; return;
} }
if (is_float) { const format_samples_t format_samples = is_float
format_samples = format_samples_float; ? format_samples_float
} else { : format_samples_int;
format_samples = format_samples_int;
}
total_time = WavpackGetNumSamples(wpc); const float total_time = float(WavpackGetNumSamples(wpc))
total_time /= audio_format.sample_rate; / audio_format.sample_rate;
bytes_per_sample = WavpackGetBytesPerSample(wpc);
output_sample_size = audio_format.GetFrameSize(); const int bytes_per_sample = WavpackGetBytesPerSample(wpc);
const int output_sample_size = audio_format.GetFrameSize();
/* wavpack gives us all kind of samples in a 32-bit space */ /* wavpack gives us all kind of samples in a 32-bit space */
int32_t chunk[1024]; int32_t chunk[1024];
@ -220,10 +213,7 @@ static bool
wavpack_tag_float(WavpackContext *wpc, const char *key, float *value_r) wavpack_tag_float(WavpackContext *wpc, const char *key, float *value_r)
{ {
char buffer[64]; char buffer[64];
int ret; if (WavpackGetTagItem(wpc, key, buffer, sizeof(buffer)) <= 0)
ret = WavpackGetTagItem(wpc, key, buffer, sizeof(buffer));
if (ret <= 0)
return false; return false;
*value_r = atof(buffer); *value_r = atof(buffer);
@ -291,10 +281,8 @@ static bool
wavpack_scan_file(const char *fname, wavpack_scan_file(const char *fname,
const struct tag_handler *handler, void *handler_ctx) const struct tag_handler *handler, void *handler_ctx)
{ {
WavpackContext *wpc;
char error[ERRORLEN]; char error[ERRORLEN];
WavpackContext *wpc = WavpackOpenFileInput(fname, error, OPEN_TAGS, 0);
wpc = WavpackOpenFileInput(fname, error, OPEN_TAGS, 0);
if (wpc == nullptr) { if (wpc == nullptr) {
FormatError(wavpack_domain, FormatError(wavpack_domain,
"failed to open WavPack file \"%s\": %s", "failed to open WavPack file \"%s\": %s",
@ -462,11 +450,6 @@ wavpack_open_wvc(Decoder &decoder, const char *uri,
Mutex &mutex, Cond &cond, Mutex &mutex, Cond &cond,
struct wavpack_input *wpi) struct wavpack_input *wpi)
{ {
InputStream *is_wvc;
char *wvc_url = nullptr;
char first_byte;
size_t nbytes;
/* /*
* As we use dc->utf8url, this function will be bad for * As we use dc->utf8url, this function will be bad for
* single files. utf8url is not absolute file path :/ * single files. utf8url is not absolute file path :/
@ -474,9 +457,10 @@ wavpack_open_wvc(Decoder &decoder, const char *uri,
if (uri == nullptr) if (uri == nullptr)
return nullptr; return nullptr;
wvc_url = g_strconcat(uri, "c", nullptr); char *wvc_url = g_strconcat(uri, "c", nullptr);
is_wvc = InputStream::Open(wvc_url, mutex, cond, IgnoreError()); InputStream *is_wvc = InputStream::Open(wvc_url, mutex, cond,
IgnoreError());
g_free(wvc_url); g_free(wvc_url);
if (is_wvc == nullptr) if (is_wvc == nullptr)
@ -486,9 +470,9 @@ wavpack_open_wvc(Decoder &decoder, const char *uri,
* And we try to buffer in order to get know * And we try to buffer in order to get know
* about a possible 404 error. * about a possible 404 error.
*/ */
nbytes = decoder_read( char first_byte;
decoder, *is_wvc, &first_byte, sizeof(first_byte) size_t nbytes = decoder_read(decoder, *is_wvc,
); &first_byte, sizeof(first_byte));
if (nbytes == 0) { if (nbytes == 0) {
is_wvc->Close(); is_wvc->Close();
return nullptr; return nullptr;
@ -506,14 +490,11 @@ wavpack_open_wvc(Decoder &decoder, const char *uri,
static void static void
wavpack_streamdecode(Decoder &decoder, InputStream &is) wavpack_streamdecode(Decoder &decoder, InputStream &is)
{ {
char error[ERRORLEN];
WavpackContext *wpc;
InputStream *is_wvc;
int open_flags = OPEN_NORMALIZE; int open_flags = OPEN_NORMALIZE;
struct wavpack_input isp, isp_wvc;
bool can_seek = is.seekable; bool can_seek = is.seekable;
is_wvc = wavpack_open_wvc(decoder, is.uri.c_str(), wavpack_input isp_wvc;
InputStream *is_wvc = wavpack_open_wvc(decoder, is.uri.c_str(),
is.mutex, is.cond, is.mutex, is.cond,
&isp_wvc); &isp_wvc);
if (is_wvc != nullptr) { if (is_wvc != nullptr) {
@ -525,12 +506,15 @@ wavpack_streamdecode(Decoder &decoder, InputStream &is)
open_flags |= OPEN_STREAMING; open_flags |= OPEN_STREAMING;
} }
wavpack_input isp;
wavpack_input_init(&isp, decoder, is); wavpack_input_init(&isp, decoder, is);
wpc = WavpackOpenFileInputEx(
&mpd_is_reader, &isp, char error[ERRORLEN];
open_flags & OPEN_WVC ? &isp_wvc : nullptr, WavpackContext *wpc =
error, open_flags, 23 WavpackOpenFileInputEx(&mpd_is_reader, &isp,
); open_flags & OPEN_WVC
? &isp_wvc : nullptr,
error, open_flags, 23);
if (wpc == nullptr) { if (wpc == nullptr) {
FormatError(wavpack_domain, FormatError(wavpack_domain,
@ -553,12 +537,9 @@ static void
wavpack_filedecode(Decoder &decoder, const char *fname) wavpack_filedecode(Decoder &decoder, const char *fname)
{ {
char error[ERRORLEN]; char error[ERRORLEN];
WavpackContext *wpc; WavpackContext *wpc = WavpackOpenFileInput(fname, error,
OPEN_TAGS | OPEN_WVC | OPEN_NORMALIZE,
wpc = WavpackOpenFileInput( 23);
fname, error,
OPEN_TAGS | OPEN_WVC | OPEN_NORMALIZE, 23
);
if (wpc == nullptr) { if (wpc == nullptr) {
FormatWarning(wavpack_domain, FormatWarning(wavpack_domain,
"failed to open WavPack file \"%s\": %s", "failed to open WavPack file \"%s\": %s",