Fix crash and memory leak when importing OGG Vorbis
This commit is contained in:
parent
45428e91ba
commit
b5badd12c6
1 changed files with 16 additions and 6 deletions
|
@ -136,11 +136,11 @@ Error ResourceImporterOGGVorbis::import(const String &p_source_file, const Strin
|
||||||
|
|
||||||
// Have a page now.
|
// Have a page now.
|
||||||
if (!initialized_stream) {
|
if (!initialized_stream) {
|
||||||
ogg_stream_init(&stream_state, ogg_page_serialno(&page));
|
if (ogg_stream_init(&stream_state, ogg_page_serialno(&page))) {
|
||||||
ERR_FAIL_COND_V_MSG((err = ogg_stream_check(&stream_state)), Error::ERR_INVALID_DATA, "Ogg stream error " + itos(err));
|
ERR_FAIL_V_MSG(Error::ERR_OUT_OF_MEMORY, "Failed allocating memory for OGG Vorbis stream.");
|
||||||
|
}
|
||||||
initialized_stream = true;
|
initialized_stream = true;
|
||||||
}
|
}
|
||||||
ERR_FAIL_COND_V_MSG((err = ogg_stream_check(&stream_state)), Error::ERR_INVALID_DATA, "Ogg stream error " + itos(err));
|
|
||||||
ogg_stream_pagein(&stream_state, &page);
|
ogg_stream_pagein(&stream_state, &page);
|
||||||
ERR_FAIL_COND_V_MSG((err = ogg_stream_check(&stream_state)), Error::ERR_INVALID_DATA, "Ogg stream error " + itos(err));
|
ERR_FAIL_COND_V_MSG((err = ogg_stream_check(&stream_state)), Error::ERR_INVALID_DATA, "Ogg stream error " + itos(err));
|
||||||
int desync_iters = 0;
|
int desync_iters = 0;
|
||||||
|
@ -160,10 +160,12 @@ Error ResourceImporterOGGVorbis::import(const String &p_source_file, const Strin
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (packet_count == 0 && vorbis_synthesis_idheader(&packet) == 0) {
|
if (packet_count == 0 && vorbis_synthesis_idheader(&packet) == 0) {
|
||||||
WARN_PRINT("Found a non-vorbis-header packet in a header position");
|
print_verbose("Found a non-vorbis-header packet in a header position");
|
||||||
// Clearly this logical stream is not a vorbis stream, so destroy it and try again with the next page.
|
// Clearly this logical stream is not a vorbis stream, so destroy it and try again with the next page.
|
||||||
ogg_stream_destroy(&stream_state);
|
if (initialized_stream) {
|
||||||
initialized_stream = false;
|
ogg_stream_clear(&stream_state);
|
||||||
|
initialized_stream = false;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
granule_pos = packet.granulepos;
|
granule_pos = packet.granulepos;
|
||||||
|
@ -178,6 +180,14 @@ Error ResourceImporterOGGVorbis::import(const String &p_source_file, const Strin
|
||||||
ogg_packet_sequence->push_page(granule_pos, packet_data);
|
ogg_packet_sequence->push_page(granule_pos, packet_data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (initialized_stream) {
|
||||||
|
ogg_stream_clear(&stream_state);
|
||||||
|
}
|
||||||
|
ogg_sync_clear(&sync_state);
|
||||||
|
|
||||||
|
if (ogg_packet_sequence->get_packet_granule_positions().is_empty()) {
|
||||||
|
ERR_FAIL_V_MSG(Error::ERR_FILE_CORRUPT, "OGG Vorbis decoding failed. Check that your data is a valid OGG Vorbis audio stream.");
|
||||||
|
}
|
||||||
|
|
||||||
ogg_vorbis_stream->set_packet_sequence(ogg_packet_sequence);
|
ogg_vorbis_stream->set_packet_sequence(ogg_packet_sequence);
|
||||||
ogg_vorbis_stream->set_loop(loop);
|
ogg_vorbis_stream->set_loop(loop);
|
||||||
|
|
Loading…
Reference in a new issue