aboutsummaryrefslogtreecommitdiff
path: root/modules/stb_vorbis/audio_stream_ogg_vorbis.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'modules/stb_vorbis/audio_stream_ogg_vorbis.cpp')
-rw-r--r--modules/stb_vorbis/audio_stream_ogg_vorbis.cpp134
1 files changed, 58 insertions, 76 deletions
diff --git a/modules/stb_vorbis/audio_stream_ogg_vorbis.cpp b/modules/stb_vorbis/audio_stream_ogg_vorbis.cpp
index d3d7ab230..884eb905f 100644
--- a/modules/stb_vorbis/audio_stream_ogg_vorbis.cpp
+++ b/modules/stb_vorbis/audio_stream_ogg_vorbis.cpp
@@ -28,20 +28,19 @@
/*************************************************************************/
#include "audio_stream_ogg_vorbis.h"
-#include "thirdparty/stb_vorbis/stb_vorbis.c"
#include "os/file_access.h"
+#include "thirdparty/stb_vorbis/stb_vorbis.c"
-
-void AudioStreamPlaybackOGGVorbis::_mix_internal(AudioFrame* p_buffer,int p_frames) {
+void AudioStreamPlaybackOGGVorbis::_mix_internal(AudioFrame *p_buffer, int p_frames) {
ERR_FAIL_COND(!active);
- int todo=p_frames;
+ int todo = p_frames;
- while(todo) {
+ while (todo) {
- int mixed = stb_vorbis_get_samples_float_interleaved(ogg_stream,2,(float*)p_buffer,todo*2);
- todo-=mixed;
+ int mixed = stb_vorbis_get_samples_float_interleaved(ogg_stream, 2, (float *)p_buffer, todo * 2);
+ todo -= mixed;
if (todo) {
//end of file!
@@ -50,15 +49,13 @@ void AudioStreamPlaybackOGGVorbis::_mix_internal(AudioFrame* p_buffer,int p_fram
seek_pos(0);
loops++;
} else {
- for(int i=mixed;i<p_frames;i++) {
- p_buffer[i]=AudioFrame(0,0);
+ for (int i = mixed; i < p_frames; i++) {
+ p_buffer[i] = AudioFrame(0, 0);
}
- active=false;
+ active = false;
}
}
}
-
-
}
float AudioStreamPlaybackOGGVorbis::get_stream_sampling_rate() {
@@ -66,20 +63,17 @@ float AudioStreamPlaybackOGGVorbis::get_stream_sampling_rate() {
return vorbis_stream->sample_rate;
}
-
void AudioStreamPlaybackOGGVorbis::start(float p_from_pos) {
seek_pos(p_from_pos);
- active=true;
- loops=0;
+ active = true;
+ loops = 0;
_begin_resample();
-
-
}
void AudioStreamPlaybackOGGVorbis::stop() {
- active=false;
+ active = false;
}
bool AudioStreamPlaybackOGGVorbis::is_playing() const {
@@ -93,14 +87,14 @@ int AudioStreamPlaybackOGGVorbis::get_loop_count() const {
float AudioStreamPlaybackOGGVorbis::get_pos() const {
- return float(frames_mixed)/vorbis_stream->sample_rate;
+ return float(frames_mixed) / vorbis_stream->sample_rate;
}
void AudioStreamPlaybackOGGVorbis::seek_pos(float p_time) {
if (!active)
return;
- stb_vorbis_seek(ogg_stream, uint32_t(p_time*vorbis_stream->sample_rate));
+ stb_vorbis_seek(ogg_stream, uint32_t(p_time * vorbis_stream->sample_rate));
}
float AudioStreamPlaybackOGGVorbis::get_length() const {
@@ -117,27 +111,25 @@ AudioStreamPlaybackOGGVorbis::~AudioStreamPlaybackOGGVorbis() {
Ref<AudioStreamPlayback> AudioStreamOGGVorbis::instance_playback() {
-
-
Ref<AudioStreamPlaybackOGGVorbis> ovs;
- printf("instance at %p, data %p\n",this,data);
+ printf("instance at %p, data %p\n", this, data);
- ERR_FAIL_COND_V(data==NULL,ovs);
+ ERR_FAIL_COND_V(data == NULL, ovs);
ovs.instance();
- ovs->vorbis_stream=Ref<AudioStreamOGGVorbis>(this);
- ovs->ogg_alloc.alloc_buffer=(char*)AudioServer::get_singleton()->audio_data_alloc(decode_mem_size);
- ovs->ogg_alloc.alloc_buffer_length_in_bytes=decode_mem_size;
- ovs->frames_mixed=0;
- ovs->active=false;
- ovs->loops=0;
- int error ;
- ovs->ogg_stream = stb_vorbis_open_memory( (const unsigned char*)data, data_len, &error, &ovs->ogg_alloc );
+ ovs->vorbis_stream = Ref<AudioStreamOGGVorbis>(this);
+ ovs->ogg_alloc.alloc_buffer = (char *)AudioServer::get_singleton()->audio_data_alloc(decode_mem_size);
+ ovs->ogg_alloc.alloc_buffer_length_in_bytes = decode_mem_size;
+ ovs->frames_mixed = 0;
+ ovs->active = false;
+ ovs->loops = 0;
+ int error;
+ ovs->ogg_stream = stb_vorbis_open_memory((const unsigned char *)data, data_len, &error, &ovs->ogg_alloc);
if (!ovs->ogg_stream) {
AudioServer::get_singleton()->audio_data_free(ovs->ogg_alloc.alloc_buffer);
- ovs->ogg_alloc.alloc_buffer=NULL;
- ERR_FAIL_COND_V(!ovs->ogg_stream,Ref<AudioStreamPlaybackOGGVorbis>());
+ ovs->ogg_alloc.alloc_buffer = NULL;
+ ERR_FAIL_COND_V(!ovs->ogg_stream, Ref<AudioStreamPlaybackOGGVorbis>());
}
return ovs;
@@ -145,40 +137,40 @@ Ref<AudioStreamPlayback> AudioStreamOGGVorbis::instance_playback() {
String AudioStreamOGGVorbis::get_stream_name() const {
- return "";//return stream_name;
+ return ""; //return stream_name;
}
-void AudioStreamOGGVorbis::set_data(const PoolVector<uint8_t>& p_data) {
+void AudioStreamOGGVorbis::set_data(const PoolVector<uint8_t> &p_data) {
- int src_data_len=p_data.size();
-#define MAX_TEST_MEM (1<<20)
+ int src_data_len = p_data.size();
+#define MAX_TEST_MEM (1 << 20)
- uint32_t alloc_try=1024;
+ uint32_t alloc_try = 1024;
PoolVector<char> alloc_mem;
PoolVector<char>::Write w;
- stb_vorbis * ogg_stream=NULL;
+ stb_vorbis *ogg_stream = NULL;
stb_vorbis_alloc ogg_alloc;
- while(alloc_try<MAX_TEST_MEM) {
+ while (alloc_try < MAX_TEST_MEM) {
alloc_mem.resize(alloc_try);
w = alloc_mem.write();
- ogg_alloc.alloc_buffer=w.ptr();
- ogg_alloc.alloc_buffer_length_in_bytes=alloc_try;
+ ogg_alloc.alloc_buffer = w.ptr();
+ ogg_alloc.alloc_buffer_length_in_bytes = alloc_try;
PoolVector<uint8_t>::Read src_datar = p_data.read();
int error;
- ogg_stream = stb_vorbis_open_memory( (const unsigned char*)src_datar.ptr(), src_data_len, &error, &ogg_alloc );
+ ogg_stream = stb_vorbis_open_memory((const unsigned char *)src_datar.ptr(), src_data_len, &error, &ogg_alloc);
- if (!ogg_stream && error==VORBIS_outofmem) {
+ if (!ogg_stream && error == VORBIS_outofmem) {
w = PoolVector<char>::Write();
- alloc_try*=2;
+ alloc_try *= 2;
} else {
- ERR_FAIL_COND(alloc_try==MAX_TEST_MEM);
- ERR_FAIL_COND(ogg_stream==NULL);
+ ERR_FAIL_COND(alloc_try == MAX_TEST_MEM);
+ ERR_FAIL_COND(ogg_stream == NULL);
stb_vorbis_info info = stb_vorbis_get_info(ogg_stream);
@@ -190,19 +182,17 @@ void AudioStreamOGGVorbis::set_data(const PoolVector<uint8_t>& p_data) {
//print_line("succeded "+itos(ogg_alloc.alloc_buffer_length_in_bytes)+" setup "+itos(info.setup_memory_required)+" setup temp "+itos(info.setup_temp_memory_required)+" temp "+itos(info.temp_memory_required)+" maxframe"+itos(info.max_frame_size));
- length=stb_vorbis_stream_length_in_seconds(ogg_stream);
+ length = stb_vorbis_stream_length_in_seconds(ogg_stream);
stb_vorbis_close(ogg_stream);
- data = AudioServer::get_singleton()->audio_data_alloc(src_data_len,src_datar.ptr());
- data_len=src_data_len;
+ data = AudioServer::get_singleton()->audio_data_alloc(src_data_len, src_datar.ptr());
+ data_len = src_data_len;
break;
}
}
-
- printf("create at %p, data %p\n",this,data);
-
+ printf("create at %p, data %p\n", this, data);
}
PoolVector<uint8_t> AudioStreamOGGVorbis::get_data() const {
@@ -213,16 +203,15 @@ PoolVector<uint8_t> AudioStreamOGGVorbis::get_data() const {
vdata.resize(data_len);
{
PoolVector<uint8_t>::Write w = vdata.write();
- copymem(w.ptr(),data,data_len);
+ copymem(w.ptr(), data, data_len);
}
-
}
return vdata;
}
void AudioStreamOGGVorbis::set_loop(bool p_enable) {
- loop=p_enable;
+ loop = p_enable;
}
bool AudioStreamOGGVorbis::has_loop() const {
@@ -230,31 +219,24 @@ bool AudioStreamOGGVorbis::has_loop() const {
return loop;
}
-
void AudioStreamOGGVorbis::_bind_methods() {
- ClassDB::bind_method(D_METHOD("set_data","data"),&AudioStreamOGGVorbis::set_data);
- ClassDB::bind_method(D_METHOD("get_data"),&AudioStreamOGGVorbis::get_data);
-
- ClassDB::bind_method(D_METHOD("set_loop","enable"),&AudioStreamOGGVorbis::set_loop);
- ClassDB::bind_method(D_METHOD("has_loop"),&AudioStreamOGGVorbis::has_loop);
+ ClassDB::bind_method(D_METHOD("set_data", "data"), &AudioStreamOGGVorbis::set_data);
+ ClassDB::bind_method(D_METHOD("get_data"), &AudioStreamOGGVorbis::get_data);
- ADD_PROPERTY(PropertyInfo(Variant::POOL_BYTE_ARRAY,"data",PROPERTY_HINT_NONE,"",PROPERTY_USAGE_NOEDITOR),"set_data","get_data");
- ADD_PROPERTY(PropertyInfo(Variant::BOOL,"loop",PROPERTY_HINT_NONE,"",PROPERTY_USAGE_NOEDITOR),"set_loop","has_loop");
+ ClassDB::bind_method(D_METHOD("set_loop", "enable"), &AudioStreamOGGVorbis::set_loop);
+ ClassDB::bind_method(D_METHOD("has_loop"), &AudioStreamOGGVorbis::has_loop);
+ ADD_PROPERTY(PropertyInfo(Variant::POOL_BYTE_ARRAY, "data", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR), "set_data", "get_data");
+ ADD_PROPERTY(PropertyInfo(Variant::BOOL, "loop", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR), "set_loop", "has_loop");
}
AudioStreamOGGVorbis::AudioStreamOGGVorbis() {
-
- data=NULL;
- length=0;
- sample_rate=1;
- channels=1;
- decode_mem_size=0;
- loop=false;
+ data = NULL;
+ length = 0;
+ sample_rate = 1;
+ channels = 1;
+ decode_mem_size = 0;
+ loop = false;
}
-
-
-
-