ecore_audio: Build Eo-based Ecore_Audio and tests now

Signed-off-by: Daniel Willmann <d.willmann@samsung.com>
This commit is contained in:
Daniel Willmann 2013-04-11 18:21:37 +01:00
parent bfc4601673
commit 48b78234a8
6 changed files with 125 additions and 592 deletions

View File

@ -6,15 +6,17 @@ lib_LTLIBRARIES += lib/ecore_audio/libecore_audio.la
installed_ecoreaudiomainheadersdir = $(includedir)/ecore-audio-@VMAJ@
dist_installed_ecoreaudiomainheaders_DATA = \
lib/ecore_audio/Ecore_Audio.h
lib/ecore_audio/Ecore_Audio.h \
lib/ecore_audio/ecore_audio_obj.h \
lib/ecore_audio/ecore_audio_obj_in.h \
lib/ecore_audio/ecore_audio_obj_out.h
lib_ecore_audio_libecore_audio_la_SOURCES = \
lib/ecore_audio/ecore_audio.c \
lib/ecore_audio/ecore_audio_alsa.c \
lib/ecore_audio/ecore_audio_pulse.c \
lib/ecore_audio/ecore_audio_sndfile.c \
lib/ecore_audio/ecore_audio_tone.c \
lib/ecore_audio/ecore_audio_custom.c \
lib/ecore_audio/ecore_audio_obj.c \
lib/ecore_audio/ecore_audio_obj_in.c \
lib/ecore_audio/ecore_audio_obj_out.c \
lib/ecore_audio/ecore_audio_private.h
lib_ecore_audio_libecore_audio_la_CPPFLAGS = @ECORE_AUDIO_CFLAGS@

View File

@ -73,10 +73,6 @@ $(top_builddir)/src/lib/eina/libeina.la \
@ECORE_LDFLAGS@
if HAVE_ECORE_AUDIO
EXTRA_PROGRAMS += \
ecore_audio_custom \
ecore_audio_playback \
ecore_audio_to_ogg
ECORE_AUDIO_COMMON_LDADD = \
$(top_builddir)/src/lib/ecore_audio/libecore_audio.la \

View File

@ -2,6 +2,7 @@
#define ECORE_AUDIO_H
#include <Eina.h>
#include <Eo.h>
#ifdef EAPI
#undef EAPI
@ -17,6 +18,12 @@
#define EAPI
#endif
#include <ecore_audio_obj.h>
#include <ecore_audio_obj_in.h>
#include <ecore_audio_obj_out.h>
#include <ecore_audio_obj_in_sndfile.h>
/**
* @file Ecore_Audio.h
* @brief Audio utility functions

View File

@ -18,32 +18,6 @@ int _ecore_audio_log_dom = -1;
static int _ecore_audio_init_count = 0;
Eina_List *ecore_audio_modules;
EAPI int ECORE_AUDIO_INPUT_STARTED;
EAPI int ECORE_AUDIO_INPUT_STOPPED;
EAPI int ECORE_AUDIO_INPUT_LOOPED;
EAPI int ECORE_AUDIO_INPUT_ENDED;
EAPI int ECORE_AUDIO_INPUT_PAUSED;
EAPI int ECORE_AUDIO_OUTPUT_INPUT_ADDED;
EAPI int ECORE_AUDIO_OUTPUT_INPUT_REMOVED;
static void _dummy_free(void *foo EINA_UNUSED, void *bar EINA_UNUSED)
{
}
static int
module_cmp(const void *a, const void *b)
{
Ecore_Audio_Module *mod = (Ecore_Audio_Module *)a;
Ecore_Audio_Type type = *(Ecore_Audio_Type *)b;
return !(mod->type == type);
}
static Ecore_Audio_Module *
get_module_by_type(Ecore_Audio_Type type)
{
return eina_list_search_unsorted(ecore_audio_modules, module_cmp, &type);
}
/* externally accessible functions */
@ -58,6 +32,11 @@ ecore_audio_init(void)
if (!ecore_init())
return --_ecore_audio_init_count;
if (!eo_init()) {
ecore_shutdown();
return --_ecore_audio_init_count;
}
_ecore_audio_log_dom = eina_log_domain_register("ecore_audio", ECORE_AUDIO_DEFAULT_LOG_COLOR);
if (_ecore_audio_log_dom < 0)
{
@ -68,37 +47,6 @@ ecore_audio_init(void)
DBG("Ecore_Audio init");
ecore_audio_modules = NULL;
ECORE_AUDIO_INPUT_STARTED = ecore_event_type_new();
ECORE_AUDIO_INPUT_STOPPED = ecore_event_type_new();
ECORE_AUDIO_INPUT_LOOPED = ecore_event_type_new();
ECORE_AUDIO_INPUT_ENDED = ecore_event_type_new();
ECORE_AUDIO_INPUT_PAUSED = ecore_event_type_new();
ECORE_AUDIO_OUTPUT_INPUT_ADDED = ecore_event_type_new();
ECORE_AUDIO_OUTPUT_INPUT_REMOVED = ecore_event_type_new();
#ifdef HAVE_ALSA
mod = ecore_audio_alsa_init();
if (mod)
ecore_audio_modules = eina_list_append(ecore_audio_modules, mod);
#endif
#ifdef HAVE_PULSE
mod = ecore_audio_pulse_init();
if (mod)
ecore_audio_modules = eina_list_append(ecore_audio_modules, mod);
#endif
#ifdef HAVE_SNDFILE
mod = ecore_audio_sndfile_init();
if (mod)
ecore_audio_modules = eina_list_append(ecore_audio_modules, mod);
#endif
mod = ecore_audio_tone_init();
if (mod)
ecore_audio_modules = eina_list_append(ecore_audio_modules, mod);
mod = ecore_audio_custom_init();
if (mod)
ecore_audio_modules = eina_list_append(ecore_audio_modules, mod);
eina_log_timing(_ecore_audio_log_dom,
EINA_LOG_STATE_STOP,
@ -119,519 +67,18 @@ ecore_audio_shutdown(void)
EINA_LOG_STATE_START,
EINA_LOG_STATE_SHUTDOWN);
#ifdef HAVE_ALSA
ecore_audio_alsa_shutdown();
#endif
#ifdef HAVE_PULSE
ecore_audio_pulse_shutdown();
#endif
#ifdef HAVE_SNDFILE
ecore_audio_sndfile_shutdown();
#endif
ecore_audio_tone_shutdown();
ecore_audio_custom_shutdown();
eina_list_free(ecore_audio_modules);
eina_log_domain_unregister(_ecore_audio_log_dom);
_ecore_audio_log_dom = -1;
eo_shutdown();
ecore_shutdown();
return _ecore_audio_init_count;
}
/* Output operations */
EAPI Ecore_Audio_Object *
ecore_audio_output_add(Ecore_Audio_Type type)
{
Ecore_Audio_Output *out;
Ecore_Audio_Module *module;
module = get_module_by_type(type);
if (!module)
return NULL;
out = calloc(1, sizeof(Ecore_Audio_Output));
if (!out)
{
ERR("Could not allocate memory for output.");
return NULL;
}
ECORE_MAGIC_SET(out, ECORE_MAGIC_AUDIO_OUTPUT);
out->module = module;
out->inputs = NULL;
return module->out_ops->output_new((Ecore_Audio_Object *)out);
}
EAPI void
ecore_audio_output_del(Ecore_Audio_Object *output)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
Eina_Bool del;
Ecore_Audio_Object *in;
EINA_SAFETY_ON_NULL_RETURN(out);
/* Cleanup */
EINA_LIST_FREE (out->inputs, in)
{
del = ecore_audio_output_input_del(output, in);
if (!del)
WRN("Disconnecting in %p and out %p failed.", in, output);
}
out->module->out_ops->output_del(output);
eina_stringshare_del(output->name);
free(output);
}
EAPI void ecore_audio_output_data_set(Ecore_Audio_Object *output, void *data)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
out->user_data = data;
}
EAPI void *ecore_audio_output_data_get(Ecore_Audio_Object *output)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
return out->user_data;
}
EAPI const char *ecore_audio_output_name_get(Ecore_Audio_Object *output)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
EINA_SAFETY_ON_NULL_RETURN_VAL(out, NULL);
return out->name;
}
EAPI void ecore_audio_output_name_set(Ecore_Audio_Object *output, const char *name)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
EINA_SAFETY_ON_NULL_RETURN(out);
if (out->name)
eina_stringshare_del(out->name);
out->name = eina_stringshare_add(name);
}
EAPI void
ecore_audio_output_volume_set(Ecore_Audio_Object *output, double volume)
{
EINA_SAFETY_ON_NULL_RETURN(output);
Ecore_Audio_Module *outmod = output->module;
outmod->out_ops->output_volume_set(output, volume);
}
EAPI double
ecore_audio_output_volume_get(Ecore_Audio_Object *output)
{
EINA_SAFETY_ON_NULL_RETURN_VAL(output, 0);
Ecore_Audio_Module *outmod = output->module;
return outmod->out_ops->output_volume_get(output);
}
EAPI void
ecore_audio_output_paused_set(Ecore_Audio_Object *output, Eina_Bool paused)
{
EINA_SAFETY_ON_NULL_RETURN(output);
Ecore_Audio_Module *outmod = output->module;
outmod->out_ops->output_paused_set(output, paused);
}
EAPI Eina_Bool
ecore_audio_output_paused_get(Ecore_Audio_Object *output)
{
EINA_SAFETY_ON_NULL_RETURN_VAL(output, EINA_TRUE);
return output->paused;
}
EAPI Eina_Bool
ecore_audio_output_input_add(Ecore_Audio_Object *output, Ecore_Audio_Object *input)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(output, EINA_FALSE);
EINA_SAFETY_ON_NULL_RETURN_VAL(input, EINA_FALSE);
Ecore_Audio_Module *outmod = output->module;
Eina_Bool ret;
if (in->output != NULL)
ecore_audio_output_input_del((Ecore_Audio_Object *)in->output, input);
ret = outmod->out_ops->output_add_input(output, input);
if (ret)
{
in->output = out;
out->inputs = eina_list_append(out->inputs, in);
ecore_event_add(ECORE_AUDIO_OUTPUT_INPUT_ADDED, in, _dummy_free, NULL);
}
return ret;
}
EAPI Eina_Bool
ecore_audio_output_input_del(Ecore_Audio_Object *output, Ecore_Audio_Object *input)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(output, EINA_FALSE);
EINA_SAFETY_ON_NULL_RETURN_VAL(input, EINA_FALSE);
Ecore_Audio_Module *outmod = output->module;
Eina_Bool ret;
ret = outmod->out_ops->output_del_input(output, input);
if (ret)
{
in->output = NULL;
out->inputs = eina_list_remove(out->inputs, in);
ecore_event_add(ECORE_AUDIO_OUTPUT_INPUT_REMOVED, in, _dummy_free, NULL);
}
return ret;
}
EAPI Eina_List *ecore_audio_output_inputs_get(Ecore_Audio_Object *output)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
EINA_SAFETY_ON_NULL_RETURN_VAL(out, EINA_FALSE);
return out->inputs;
}
EAPI Eina_Bool ecore_audio_output_input_chain_after(Ecore_Audio_Object *output, Ecore_Audio_Object *after, Ecore_Audio_Object *input)
{
Ecore_Audio_Output *out = (Ecore_Audio_Output *)output;
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(out, EINA_FALSE);
EINA_SAFETY_ON_NULL_RETURN_VAL(in, EINA_FALSE);
EINA_SAFETY_ON_NULL_RETURN_VAL(after, EINA_FALSE);
if (!eina_list_data_find(out->inputs, after))
return EINA_FALSE;
/* XXX: implement */
return EINA_FALSE;
}
/* Input operations */
EAPI Ecore_Audio_Object *
ecore_audio_input_add(Ecore_Audio_Type type)
{
Ecore_Audio_Input *in;
Ecore_Audio_Module *module;
module = get_module_by_type(type);
if (!module)
return NULL;
in = calloc(1, sizeof(Ecore_Audio_Input));
if (!in)
{
ERR("Could not allocate memory for input.");
return NULL;
}
ECORE_MAGIC_SET(in, ECORE_MAGIC_AUDIO_INPUT);
in->module = module;
in->output = NULL;
in->paused = EINA_FALSE;
in->speed = 1.0;
return module->in_ops->input_new((Ecore_Audio_Object *)in);
}
EAPI void
ecore_audio_input_del(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
Eina_Bool del;
Ecore_Audio_Module *module = input->module;
if (in->output) {
del = ecore_audio_output_input_del((Ecore_Audio_Object *)in->output, input);
if (!del)
WRN("Disconnecting in %p and out %p failed.", input, in->output);
in->output = NULL;
}
module->in_ops->input_del(input);
eina_stringshare_del(in->name);
free(in);
}
EAPI void ecore_audio_input_data_set(Ecore_Audio_Object *input, void *data)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
in->user_data = data;
}
EAPI void *ecore_audio_input_data_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
return in->user_data;
}
EAPI const char *ecore_audio_input_name_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(in, NULL);
return in->name;
}
EAPI void ecore_audio_input_name_set(Ecore_Audio_Object *input, const char *name)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN(in);
if (in->name)
eina_stringshare_del(in->name);
in->name = eina_stringshare_add(name);
}
EAPI int ecore_audio_input_samplerate_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(in, -1);
return in->samplerate;
}
EAPI void ecore_audio_input_samplerate_set(Ecore_Audio_Object *input, int samplerate)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN(input);
Ecore_Audio_Module *outmod;
if (in->samplerate == samplerate)
return;
in->samplerate = samplerate;
if (in->output)
{
outmod = in->output->module;
outmod->out_ops->output_update_input_format((Ecore_Audio_Object *)in->output, input);
}
}
EAPI double ecore_audio_input_speed_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input* in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(in, 0);
return in->speed;
}
EAPI void ecore_audio_input_speed_set(Ecore_Audio_Object *input, double speed)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN(input);
Ecore_Audio_Module *outmod;
if ((in->speed == speed) || (speed < 0.2) || (speed > 5.0))
return;
in->speed = speed;
if (in->output)
{
outmod = in->output->module;
outmod->out_ops->output_update_input_format((Ecore_Audio_Object *)in->output, input);
}
}
EAPI int ecore_audio_input_channels_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(in, -1);
return in->channels;
}
EAPI void ecore_audio_input_channels_set(Ecore_Audio_Object *input, int channels)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN(in);
if (in->channels == channels)
return;
in->channels = channels;
/* XXX: Change channel number for connected streams?
if (in->output)
{
outmod = in->output->module;
outmod->out_ops->output_update_input_format(in->output, in);
} */
}
EAPI int ecore_audio_input_read(Ecore_Audio_Object *input, void *data, int len)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
int ret;
EINA_SAFETY_ON_NULL_RETURN_VAL(in, 0);
Ecore_Audio_Module *inmod = input->module;
if (in->paused)
{
memset(data, 0, len);
return len;
}
ret = inmod->in_ops->input_read(input, data, len);
if (ret == 0)
{
if (!in->looped)
{
ecore_event_add(ECORE_AUDIO_INPUT_ENDED, in, _dummy_free, NULL);
}
else
{
inmod->in_ops->input_seek(input, 0, SEEK_SET);
ret = inmod->in_ops->input_read(input, data, len);
ecore_event_add(ECORE_AUDIO_INPUT_LOOPED, input, _dummy_free, NULL);
}
}
return ret;
}
EAPI double
ecore_audio_input_seek(Ecore_Audio_Object *input, double offs, int mode)
{
EINA_SAFETY_ON_NULL_RETURN_VAL(input, -1);
Ecore_Audio_Module *inmod = input->module;
return inmod->in_ops->input_seek(input, offs, mode);
}
EAPI Eina_Bool
ecore_audio_input_paused_get(Ecore_Audio_Object *input)
{
EINA_SAFETY_ON_NULL_RETURN_VAL(input, EINA_FALSE);
return input->paused;
}
EAPI void
ecore_audio_input_paused_set(Ecore_Audio_Object *input, Eina_Bool paused)
{
EINA_SAFETY_ON_NULL_RETURN(input);
if (paused == input->paused)
return;
input->paused = paused;
ecore_event_add(ECORE_AUDIO_INPUT_PAUSED, input, _dummy_free, NULL);
}
EAPI void
ecore_audio_input_volume_set(Ecore_Audio_Object *input, double volume)
{
EINA_SAFETY_ON_NULL_RETURN(input);
Ecore_Audio_Module *inmod = input->module;
inmod->in_ops->input_volume_set(input, volume);
}
EAPI double
ecore_audio_input_volume_get(Ecore_Audio_Object *input)
{
EINA_SAFETY_ON_NULL_RETURN_VAL(input, -1);
Ecore_Audio_Module *inmod = input->module;
return inmod->in_ops->input_volume_get(input);
}
EAPI void
ecore_audio_input_looped_set(Ecore_Audio_Object *input, Eina_Bool looped)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN(input);
in->looped = looped;
}
EAPI Eina_Bool
ecore_audio_input_looped_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(input, EINA_FALSE);
return in->looped;
}
EAPI double
ecore_audio_input_length_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(input, -1);
return in->length;
}
EAPI void
ecore_audio_input_preloaded_set(Ecore_Audio_Object *input, Eina_Bool preloaded)
{
EINA_SAFETY_ON_NULL_RETURN(input);
Ecore_Audio_Module *inmod = input->module;
inmod->in_ops->input_preloaded_set(input, preloaded);
}
EAPI Eina_Bool
ecore_audio_input_preloaded_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(input, EINA_FALSE);
return in->preloaded;
}
EAPI Ecore_Audio_Object *
ecore_audio_input_output_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(input, NULL);
return (Ecore_Audio_Object *)in->output;
}
EAPI double
ecore_audio_input_remaining_get(Ecore_Audio_Object *input)
{
Ecore_Audio_Input *in = (Ecore_Audio_Input *)input;
EINA_SAFETY_ON_NULL_RETURN_VAL(input, -1);
Ecore_Audio_Module *inmod = input->module;
return in->length - inmod->in_ops->input_seek(input, 0, SEEK_CUR);
}
/* XXX: Error checking!!! */
EAPI void
ecore_audio_input_callback_setup(Ecore_Audio_Object *input, Ecore_Audio_Read_Callback read_cb, void *data)
{
EINA_SAFETY_ON_NULL_RETURN(input);
struct _Ecore_Audio_Callback *cb = input->module_data;
cb->read_cb = read_cb;
cb->data = data;
}
/**
* @}

View File

@ -235,9 +235,12 @@ struct _Ecore_Audio_Object
{
ECORE_MAGIC;
const char *name;
const char *source;
Ecore_Audio_Module *module;
Eina_Bool paused;
double volume;
void *module_data;
void *obj_data;
@ -278,7 +281,7 @@ struct _Ecore_Audio_Input
void *obj_data;
void *user_data;
Ecore_Audio_Output *output; /**< The output this input is connected to */
Eo *output; /**< The output this input is connected to */
int samplerate;
int channels;
@ -345,16 +348,6 @@ struct _Ecore_Audio_Sndfile_Private
SF_VIRTUAL_IO vio_wrapper;
};
struct _Ecore_Audio_Sndfile
{
const char *filename;
SNDFILE *handle;
SF_INFO sfinfo;
Ecore_Audio_Vio *vio;
double volume;
Ecore_Timer *timer;
};
Ecore_Audio_Module *ecore_audio_sndfile_init(void);
void ecore_audio_sndfile_shutdown(void);
#endif /* HAVE_SNDFILE */

View File

@ -17,15 +17,6 @@
#define SOUNDS_DIR TESTS_SRC_DIR
#if 0
/* TODO: must fix these tests to produce no warnings and to be
* passing on all platforms that support them.
*
* It would be nice if timers are not used so it doesn't take an
* eternity to run ecore_suite. :-)
*/
static Ecore_Audio_Object *out;
static Ecore_Audio_Object *in;
Eina_Bool
seek(void *data)
{
@ -339,6 +330,101 @@ START_TEST(ecore_test_ecore_audio_custom)
END_TEST
#endif
START_TEST(ecore_test_ecore_audio_obj_in_out)
{
Eo *out2;
Eina_List *in3;
Eo *in = eo_add(ECORE_AUDIO_OBJ_IN_CLASS, NULL);
Eo *in2 = eo_add(ECORE_AUDIO_OBJ_IN_CLASS, NULL);
Eo *out = eo_add(ECORE_AUDIO_OBJ_OUT_CLASS, NULL);
fail_if(!in);
fail_if(!in2);
fail_if(!out);
fail_if(!eo_do(in, ecore_audio_obj_in_output_get(&out2)));
fail_if(out2);
fail_if(!eo_do(out, ecore_audio_obj_out_inputs_get(&in3)));
fail_if(eina_list_count(in3) != 0);
fail_if(!eo_do(out, ecore_audio_obj_out_input_attach(in)));
fail_if(!eo_do(in, ecore_audio_obj_in_output_get(&out2)));
fail_if(out2 != out);
fail_if(!eo_do(out, ecore_audio_obj_out_inputs_get(&in3)));
fail_if(eina_list_count(in3) != 1);
fail_if(eina_list_data_get(in3) != in);
fail_if(!eo_do(out, ecore_audio_obj_out_input_attach(in2)));
fail_if(!eo_do(out, ecore_audio_obj_out_inputs_get(&in3)));
fail_if(eina_list_count(in3) != 2);
fail_if(eina_list_data_get(in3) != in);
eo_del(in2);
fail_if(!eo_do(out, ecore_audio_obj_out_inputs_get(&in3)));
fail_if(eina_list_count(in3) != 1);
fail_if(eina_list_data_get(in3) != in);
eo_del(out);
fail_if(!eo_do(in, ecore_audio_obj_in_output_get(&out2)));
fail_if(out2);
eo_del(in);
}
END_TEST
START_TEST(ecore_test_ecore_audio_obj)
{
const char *name;
Eina_Bool paused;
double volume;
Eo *in = eo_add(ECORE_AUDIO_OBJ_IN_CLASS, NULL);
fail_if(!in);
fail_if(!eo_do(in, ecore_audio_obj_name_get(&name)));
fail_if(name);
fail_if(!eo_do(in, ecore_audio_obj_name_set("In1")));
fail_if(!eo_do(in, ecore_audio_obj_name_get(&name)));
ck_assert_str_eq(name, "In1");
fail_if(!eo_do(in, ecore_audio_obj_name_get(NULL)));
fail_if(!eo_do(in, ecore_audio_obj_paused_get(&paused)));
fail_if(paused);
fail_if(!eo_do(in, ecore_audio_obj_paused_set(EINA_TRUE)));
fail_if(!eo_do(in, ecore_audio_obj_paused_get(&paused)));
fail_if(!paused);
fail_if(!eo_do(in, ecore_audio_obj_volume_get(&volume)));
fail_if(volume != 1.0);
fail_if(!eo_do(in, ecore_audio_obj_volume_set(0.5)));
fail_if(!eo_do(in, ecore_audio_obj_volume_get(&volume)));
fail_if(volume != 0.5);
eo_del(in);
}
END_TEST
START_TEST(ecore_test_ecore_audio_init)
{
int ret;
@ -380,13 +466,15 @@ ecore_test_ecore_audio(TCase *tc)
tcase_add_test(tc, ecore_test_ecore_audio_init);
#if 0
tcase_add_test(tc, ecore_test_ecore_audio_obj);
tcase_add_test(tc, ecore_test_ecore_audio_obj_in_out);
/*
tcase_add_test(tc, ecore_test_ecore_audio_default);
tcase_add_test(tc, ecore_test_ecore_audio_sndfile);
tcase_add_test(tc, ecore_test_ecore_audio_sndfile_vio);
tcase_add_test(tc, ecore_test_ecore_audio_custom);
tcase_add_test(tc, ecore_test_ecore_audio_cleanup);
#endif
*/
}