cleanups...

i did this module long ago, without a proper indentation settings in my emacs...



SVN revision: 47124
This commit is contained in:
Gustavo Sverzut Barbieri 2010-03-10 21:54:23 +00:00
parent 6177180010
commit 2a1229013a
5 changed files with 450 additions and 525 deletions

View File

@ -60,43 +60,43 @@ struct channel_info
}; };
static void static void
_cb_changed_left(void *data, Evas_Object *obj) _cb_changed_left(void *data, Evas_Object *obj __UNUSED__)
{ {
E_Mixer_App_Dialog_Data *app = data; E_Mixer_App_Dialog_Data *app = data;
E_Mixer_Channel_State *state; E_Mixer_Channel_State *state;
state = &app->state; state = &app->state;
if (app->lock_sliders && (state->left != state->right)) if (app->lock_sliders && (state->left != state->right))
{ {
state->right = state->left; state->right = state->left;
e_widget_slider_value_int_set(app->ui.channel_editor.right, e_widget_slider_value_int_set(app->ui.channel_editor.right,
state->right); state->right);
} }
e_mixer_system_set_volume(app->sys, app->channel_info->id, e_mixer_system_set_volume(app->sys, app->channel_info->id,
state->left, state->right); state->left, state->right);
} }
static void static void
_cb_changed_right(void *data, Evas_Object *obj) _cb_changed_right(void *data, Evas_Object *obj __UNUSED__)
{ {
E_Mixer_App_Dialog_Data *app = data; E_Mixer_App_Dialog_Data *app = data;
E_Mixer_Channel_State *state; E_Mixer_Channel_State *state;
state = &app->state; state = &app->state;
if (app->lock_sliders && (state->right != state->left)) if (app->lock_sliders && (state->right != state->left))
{ {
state->left = state->right; state->left = state->right;
e_widget_slider_value_int_set(app->ui.channel_editor.left, e_widget_slider_value_int_set(app->ui.channel_editor.left,
state->left); state->left);
} }
e_mixer_system_set_volume(app->sys, app->channel_info->id, e_mixer_system_set_volume(app->sys, app->channel_info->id,
state->left, state->right); state->left, state->right);
} }
static void static void
_cb_changed_mute(void *data, Evas_Object *obj) _cb_changed_mute(void *data, Evas_Object *obj __UNUSED__)
{ {
E_Mixer_App_Dialog_Data *app = data; E_Mixer_App_Dialog_Data *app = data;
@ -104,17 +104,17 @@ _cb_changed_mute(void *data, Evas_Object *obj)
} }
static void static void
_cb_changed_lock_sliders(void *data, Evas_Object *obj) _cb_changed_lock_sliders(void *data, Evas_Object *obj __UNUSED__)
{ {
E_Mixer_App_Dialog_Data *app = data; E_Mixer_App_Dialog_Data *app = data;
E_Mixer_Channel_State *state; E_Mixer_Channel_State *state;
if (!app->lock_sliders) if (!app->lock_sliders)
return; return;
state = &app->state; state = &app->state;
if (state->left == state->right) if (state->left == state->right)
return; return;
state->left = state->right = (state->left + state->right) / 2; state->left = state->right = (state->left + state->right) / 2;
@ -127,34 +127,30 @@ _cb_changed_lock_sliders(void *data, Evas_Object *obj)
static void static void
_update_channel_editor_state(E_Mixer_App_Dialog_Data *app, const E_Mixer_Channel_State state) _update_channel_editor_state(E_Mixer_App_Dialog_Data *app, const E_Mixer_Channel_State state)
{ {
struct e_mixer_app_ui_channel_editor *ui; struct e_mixer_app_ui_channel_editor *ui = &app->ui.channel_editor;
ui = &app->ui.channel_editor;
e_widget_slider_value_int_set(ui->left, state.left); e_widget_slider_value_int_set(ui->left, state.left);
e_widget_slider_value_int_set(ui->right, state.right); e_widget_slider_value_int_set(ui->right, state.right);
if (e_mixer_system_can_mute(app->sys, app->channel_info->id)) if (e_mixer_system_can_mute(app->sys, app->channel_info->id))
{ {
e_widget_disabled_set(ui->mute, 0); e_widget_disabled_set(ui->mute, 0);
e_widget_check_checked_set(ui->mute, state.mute); e_widget_check_checked_set(ui->mute, state.mute);
} }
else else
{ {
e_widget_disabled_set(ui->mute, 1); e_widget_disabled_set(ui->mute, 1);
e_widget_check_checked_set(ui->mute, 0); e_widget_check_checked_set(ui->mute, 0);
} }
} }
static void static void
_populate_channel_editor(E_Mixer_App_Dialog_Data *app) _populate_channel_editor(E_Mixer_App_Dialog_Data *app)
{ {
struct e_mixer_app_ui_channel_editor *ui; struct e_mixer_app_ui_channel_editor *ui = &app->ui.channel_editor;
E_Mixer_Channel_State state; E_Mixer_Channel_State state;
const char *card_name; const char *card_name;
ui = &app->ui.channel_editor;
card_name = e_mixer_system_get_card_name(app->card); card_name = e_mixer_system_get_card_name(app->card);
e_widget_entry_text_set(ui->card, card_name); e_widget_entry_text_set(ui->card, card_name);
eina_stringshare_del(card_name); eina_stringshare_del(card_name);
@ -162,9 +158,9 @@ _populate_channel_editor(E_Mixer_App_Dialog_Data *app)
e_widget_entry_text_set(ui->channel, app->channel_name); e_widget_entry_text_set(ui->channel, app->channel_name);
if (e_mixer_system_has_capture(app->sys, app->channel_info->id)) if (e_mixer_system_has_capture(app->sys, app->channel_info->id))
e_widget_entry_text_set(ui->type, _("Capture")); e_widget_entry_text_set(ui->type, _("Capture"));
else else
e_widget_entry_text_set(ui->type, _("Playback")); e_widget_entry_text_set(ui->type, _("Playback"));
e_mixer_system_get_state(app->sys, app->channel_info->id, &state); e_mixer_system_get_state(app->sys, app->channel_info->id, &state);
_update_channel_editor_state(app, state); _update_channel_editor_state(app, state);
@ -190,9 +186,9 @@ _channel_info_cmp(const void *data_a, const void *data_b)
const struct channel_info *a = data_a, *b = data_b; const struct channel_info *a = data_a, *b = data_b;
if (a->has_capture < b->has_capture) if (a->has_capture < b->has_capture)
return -1; return -1;
else if (a->has_capture > b->has_capture) else if (a->has_capture > b->has_capture)
return 1; return 1;
return strcmp(a->name, b->name); return strcmp(a->name, b->name);
} }
@ -205,16 +201,16 @@ _channels_info_new(E_Mixer_System *sys)
channels = e_mixer_system_get_channels(sys); channels = e_mixer_system_get_channels(sys);
channels_infos = NULL; channels_infos = NULL;
for (l = channels; l != NULL; l = l->next) for (l = channels; l != NULL; l = l->next)
{ {
struct channel_info *info; struct channel_info *info;
info = malloc(sizeof(*info)); info = malloc(sizeof(*info));
info->id = l->data; info->id = l->data;
info->name = e_mixer_system_get_channel_name(sys, info->id); info->name = e_mixer_system_get_channel_name(sys, info->id);
info->has_capture = e_mixer_system_has_capture(sys, info->id); info->has_capture = e_mixer_system_has_capture(sys, info->id);
channels_infos = eina_list_append(channels_infos, info); channels_infos = eina_list_append(channels_infos, info);
} }
e_mixer_system_free_channels(channels); e_mixer_system_free_channels(channels);
return eina_list_sort(channels_infos, -1, _channel_info_cmp); return eina_list_sort(channels_infos, -1, _channel_info_cmp);
@ -226,22 +222,20 @@ _channels_info_free(Eina_List *list)
struct channel_info *info; struct channel_info *info;
EINA_LIST_FREE(list, info) EINA_LIST_FREE(list, info)
{ {
eina_stringshare_del(info->name); eina_stringshare_del(info->name);
free(info); free(info);
} }
} }
static int static int
_cb_system_update(void *data, E_Mixer_System *sys) _cb_system_update(void *data, E_Mixer_System *sys __UNUSED__)
{ {
E_Mixer_App_Dialog_Data *app; E_Mixer_App_Dialog_Data *app = data;
E_Mixer_Channel_State state; E_Mixer_Channel_State state;
app = data;
if ((!app->sys) || (!app->channel_info)) if ((!app->sys) || (!app->channel_info))
return 1; return 1;
e_mixer_system_get_state(app->sys, app->channel_info->id, &state); e_mixer_system_get_state(app->sys, app->channel_info->id, &state);
_update_channel_editor_state(app, state); _update_channel_editor_state(app, state);
@ -264,7 +258,7 @@ _populate_channels(E_Mixer_App_Dialog_Data *app)
e_widget_ilist_clear(ilist); e_widget_ilist_clear(ilist);
if (app->sys) if (app->sys)
e_mixer_system_del(app->sys); e_mixer_system_del(app->sys);
app->sys = e_mixer_system_new(app->card); app->sys = e_mixer_system_new(app->card);
e_mixer_system_callback_set(app->sys, _cb_system_update, app); e_mixer_system_callback_set(app->sys, _cb_system_update, app);
@ -272,47 +266,47 @@ _populate_channels(E_Mixer_App_Dialog_Data *app)
app->channel_name = e_mixer_system_get_default_channel_name(app->sys); app->channel_name = e_mixer_system_get_default_channel_name(app->sys);
if (app->channels_infos) if (app->channels_infos)
_channels_info_free(app->channels_infos); _channels_info_free(app->channels_infos);
app->channels_infos = _channels_info_new(app->sys); app->channels_infos = _channels_info_new(app->sys);
if (app->channels_infos) if (app->channels_infos)
{ {
struct channel_info *info = app->channels_infos->data; struct channel_info *info = app->channels_infos->data;
if (info->has_capture) if (info->has_capture)
{ {
e_widget_ilist_header_append(ilist, NULL, _("Input")); e_widget_ilist_header_append(ilist, NULL, _("Input"));
header_input = 1; header_input = 1;
i = 1; i = 1;
} }
else else
{ {
e_widget_ilist_header_append(ilist, NULL, _("Output")); e_widget_ilist_header_append(ilist, NULL, _("Output"));
header_input = 0; header_input = 0;
i = 1; i = 1;
} }
} }
for (l = app->channels_infos; l != NULL; l = l->next, i++) for (l = app->channels_infos; l != NULL; l = l->next, i++)
{ {
struct channel_info *info = l->data; struct channel_info *info = l->data;
if ((!header_input) && info->has_capture) if ((!header_input) && info->has_capture)
{ {
e_widget_ilist_header_append(ilist, NULL, _("Input")); e_widget_ilist_header_append(ilist, NULL, _("Input"));
header_input = 1; header_input = 1;
i++; i++;
} }
info->app = app; info->app = app;
e_widget_ilist_append(ilist, NULL, info->name, _cb_channel_selected, e_widget_ilist_append(ilist, NULL, info->name, _cb_channel_selected,
info, info->name); info, info->name);
if (app->channel_name && info->name && if (app->channel_name && info->name &&
(strcmp(app->channel_name, info->name) == 0)) (strcmp(app->channel_name, info->name) == 0))
{ {
e_widget_ilist_selected_set(ilist, i); e_widget_ilist_selected_set(ilist, i);
app->channel_info = info; app->channel_info = info;
} }
} }
e_widget_ilist_go(ilist); e_widget_ilist_go(ilist);
e_widget_ilist_thaw(ilist); e_widget_ilist_thaw(ilist);
@ -333,32 +327,31 @@ _cb_card_selected(void *data)
} }
static void static void
_create_cards(E_Dialog *dialog, Evas *evas, E_Mixer_App_Dialog_Data *app) _create_cards(E_Dialog *dialog __UNUSED__, Evas *evas, E_Mixer_App_Dialog_Data *app)
{ {
struct e_mixer_app_ui_cards *ui; struct e_mixer_app_ui_cards *ui = &app->ui.cards;
const char *card; const char *card;
Eina_List *l; Eina_List *l;
app->card = e_mixer_system_get_default_card(); app->card = e_mixer_system_get_default_card();
app->cards = e_mixer_system_get_cards(); app->cards = e_mixer_system_get_cards();
if (eina_list_count(app->cards) < 2) if (eina_list_count(app->cards) < 2)
return; return;
ui = &app->ui.cards;
ui->list = e_widget_ilist_add(evas, 32, 32, &app->card); ui->list = e_widget_ilist_add(evas, 32, 32, &app->card);
e_widget_size_min_set(ui->list, 180, 100); e_widget_size_min_set(ui->list, 180, 100);
e_widget_ilist_go(ui->list); e_widget_ilist_go(ui->list);
EINA_LIST_FOREACH(app->cards, l, card) EINA_LIST_FOREACH(app->cards, l, card)
{ {
const char *card_name; const char *card_name;
card_name = e_mixer_system_get_card_name(card); card_name = e_mixer_system_get_card_name(card);
e_widget_ilist_append(ui->list, NULL, card_name, _cb_card_selected, e_widget_ilist_append(ui->list, NULL, card_name, _cb_card_selected,
app, card); app, card);
eina_stringshare_del(card_name); eina_stringshare_del(card_name);
} }
ui->frame = e_widget_framelist_add(evas, _("Cards"), 0); ui->frame = e_widget_framelist_add(evas, _("Cards"), 0);
e_widget_framelist_object_append(ui->frame, ui->list); e_widget_framelist_object_append(ui->frame, ui->list);
@ -366,11 +359,9 @@ _create_cards(E_Dialog *dialog, Evas *evas, E_Mixer_App_Dialog_Data *app)
} }
static void static void
_create_channels(E_Dialog *dialog, Evas *evas, E_Mixer_App_Dialog_Data *app) _create_channels(E_Dialog *dialog __UNUSED__, Evas *evas, E_Mixer_App_Dialog_Data *app)
{ {
struct e_mixer_app_ui_channels *ui; struct e_mixer_app_ui_channels *ui = &app->ui.channels;
ui = &app->ui.channels;
ui->list = e_widget_ilist_add(evas, 24, 24, &app->channel_name); ui->list = e_widget_ilist_add(evas, 24, 24, &app->channel_name);
e_widget_size_min_set(ui->list, 180, 100); e_widget_size_min_set(ui->list, 180, 100);
e_widget_ilist_go(ui->list); e_widget_ilist_go(ui->list);
@ -381,11 +372,9 @@ _create_channels(E_Dialog *dialog, Evas *evas, E_Mixer_App_Dialog_Data *app)
} }
static void static void
_create_channel_editor(E_Dialog *dialog, Evas *evas, E_Mixer_App_Dialog_Data *app) _create_channel_editor(E_Dialog *dialog __UNUSED__, Evas *evas, E_Mixer_App_Dialog_Data *app)
{ {
struct e_mixer_app_ui_channel_editor *ui; struct e_mixer_app_ui_channel_editor *ui = &app->ui.channel_editor;
ui = &app->ui.channel_editor;
ui->label_card = e_widget_label_add(evas, _("Card:")); ui->label_card = e_widget_label_add(evas, _("Card:"));
ui->card = e_widget_entry_add(evas, NULL, NULL, NULL, NULL); ui->card = e_widget_entry_add(evas, NULL, NULL, NULL, NULL);
@ -436,30 +425,28 @@ _create_channel_editor(E_Dialog *dialog, Evas *evas, E_Mixer_App_Dialog_Data *ap
static void static void
_create_ui(E_Dialog *dialog, E_Mixer_App_Dialog_Data *app) _create_ui(E_Dialog *dialog, E_Mixer_App_Dialog_Data *app)
{ {
struct e_mixer_app_ui *ui; struct e_mixer_app_ui *ui = &app->ui;
Evas *evas; Evas *evas;
int mw, mh; int mw, mh;
evas = e_win_evas_get(dialog->win); evas = e_win_evas_get(dialog->win);
ui = &app->ui;
ui->hlayout = e_widget_list_add(evas, 0, 1); ui->hlayout = e_widget_list_add(evas, 0, 1);
_create_cards(dialog, evas, app); _create_cards(dialog, evas, app);
_create_channels(dialog, evas, app); _create_channels(dialog, evas, app);
_create_channel_editor(dialog, evas, app); _create_channel_editor(dialog, evas, app);
if (ui->cards.list) if (ui->cards.list)
e_widget_ilist_selected_set(ui->cards.list, 0); e_widget_ilist_selected_set(ui->cards.list, 0);
else else
select_card(app); select_card(app);
e_widget_ilist_selected_set(ui->channels.list, 1); e_widget_ilist_selected_set(ui->channels.list, 1);
e_widget_size_min_get(ui->hlayout, &mw, &mh); e_widget_size_min_get(ui->hlayout, &mw, &mh);
if (mw < 300) if (mw < 300)
mw = 300; mw = 300;
if (mh < 200) if (mh < 200)
mh = 200; mh = 200;
e_dialog_content_set(dialog, ui->hlayout, mw, mh); e_dialog_content_set(dialog, ui->hlayout, mw, mh);
} }
@ -467,14 +454,14 @@ static void
_mixer_app_dialog_del(E_Dialog *dialog, E_Mixer_App_Dialog_Data *app) _mixer_app_dialog_del(E_Dialog *dialog, E_Mixer_App_Dialog_Data *app)
{ {
if (app->del.func) if (app->del.func)
app->del.func(dialog, app->del.data); app->del.func(dialog, app->del.data);
eina_stringshare_del(app->card); eina_stringshare_del(app->card);
eina_stringshare_del(app->channel_name); eina_stringshare_del(app->channel_name);
if (app->cards) if (app->cards)
e_mixer_system_free_cards(app->cards); e_mixer_system_free_cards(app->cards);
if (app->channels_infos) if (app->channels_infos)
_channels_info_free(app->channels_infos); _channels_info_free(app->channels_infos);
e_mixer_system_del(app->sys); e_mixer_system_del(app->sys);
e_util_defer_object_del(E_OBJECT(dialog)); e_util_defer_object_del(E_OBJECT(dialog));
@ -485,12 +472,8 @@ _mixer_app_dialog_del(E_Dialog *dialog, E_Mixer_App_Dialog_Data *app)
static void static void
_cb_win_del(E_Win *win) _cb_win_del(E_Win *win)
{ {
E_Dialog *dialog; E_Dialog *dialog = win->data;
E_Mixer_App_Dialog_Data *app; E_Mixer_App_Dialog_Data *app = dialog->data;
dialog = win->data;
app = dialog->data;
_mixer_app_dialog_del(dialog, app); _mixer_app_dialog_del(dialog, app);
} }
@ -508,14 +491,14 @@ e_mixer_app_dialog_new(E_Container *con, void (*func)(E_Dialog *dialog, void *da
dialog = e_dialog_new(con, _e_mixer_Name, "e_mixer_app_dialog"); dialog = e_dialog_new(con, _e_mixer_Name, "e_mixer_app_dialog");
if (!dialog) if (!dialog)
return NULL; return NULL;
app = E_NEW(E_Mixer_App_Dialog_Data, 1); app = E_NEW(E_Mixer_App_Dialog_Data, 1);
if (!app) if (!app)
{ {
e_object_del(E_OBJECT(dialog)); e_object_del(E_OBJECT(dialog));
return NULL; return NULL;
} }
dialog->data = app; dialog->data = app;
app->del.data = data; app->del.data = data;
@ -546,8 +529,8 @@ _find_card_by_name(E_Mixer_App_Dialog_Data *app, const char *card_name)
int i; int i;
for (i = 0, l = app->cards; l != NULL; i++, l = l->next) for (i = 0, l = app->cards; l != NULL; i++, l = l->next)
if (strcmp(card_name, l->data) == 0) if (strcmp(card_name, l->data) == 0)
return i; return i;
return -1; return -1;
} }
@ -561,26 +544,26 @@ _find_channel_by_name(E_Mixer_App_Dialog_Data *app, const char *channel_name)
int header_input; int header_input;
if (app->channels_infos) if (app->channels_infos)
{ {
struct channel_info *info = app->channels_infos->data; struct channel_info *info = app->channels_infos->data;
header_input = !!info->has_capture; header_input = !!info->has_capture;
i = 1; i = 1;
} }
EINA_LIST_FOREACH(app->channels_infos, l, info) EINA_LIST_FOREACH(app->channels_infos, l, info)
{ {
if ((!header_input) && info->has_capture) if ((!header_input) && info->has_capture)
{ {
header_input = 1; header_input = 1;
i++; i++;
} }
if (strcmp(channel_name, info->name) == 0) if (strcmp(channel_name, info->name) == 0)
return i; return i;
++i; ++i;
} }
return -1; return -1;
} }
@ -592,21 +575,21 @@ e_mixer_app_dialog_select(E_Dialog *dialog, const char *card_name, const char *c
int n; int n;
if (!dialog) if (!dialog)
return 0; return 0;
app = dialog->data; app = dialog->data;
if (!app) if (!app)
return 0; return 0;
n = _find_card_by_name(app, card_name); n = _find_card_by_name(app, card_name);
if (n < 0) if (n < 0)
return 0; return 0;
if (app->ui.cards.list) if (app->ui.cards.list)
e_widget_ilist_selected_set(app->ui.cards.list, n); e_widget_ilist_selected_set(app->ui.cards.list, n);
n = _find_channel_by_name(app, channel_name); n = _find_channel_by_name(app, channel_name);
if (n < 0) if (n < 0)
return 0; return 0;
e_widget_ilist_selected_set(app->ui.channels.list, n); e_widget_ilist_selected_set(app->ui.channels.list, n);
return 1; return 1;

View File

@ -51,19 +51,19 @@ _mixer_fill_cards_info(E_Config_Dialog_Data *cfdata)
cfdata->cards = e_mixer_system_get_cards(); cfdata->cards = e_mixer_system_get_cards();
cfdata->cards_names = NULL; cfdata->cards_names = NULL;
EINA_LIST_FOREACH(cfdata->cards, l, card) EINA_LIST_FOREACH(cfdata->cards, l, card)
{ {
name = e_mixer_system_get_card_name(card); name = e_mixer_system_get_card_name(card);
if ((cfdata->card_num < 0) && card && cfdata->card && if ((cfdata->card_num < 0) && card && cfdata->card &&
(strcmp(card, cfdata->card) == 0)) (strcmp(card, cfdata->card) == 0))
cfdata->card_num = i; cfdata->card_num = i;
cfdata->cards_names = eina_list_append(cfdata->cards_names, name); cfdata->cards_names = eina_list_append(cfdata->cards_names, name);
i++; i++;
} }
if (cfdata->card_num < 0) if (cfdata->card_num < 0)
cfdata->card_num = 0; cfdata->card_num = 0;
} }
static void static void
@ -76,23 +76,23 @@ _mixer_fill_channels_info(E_Config_Dialog_Data *cfdata)
sys = e_mixer_system_new(cfdata->card); sys = e_mixer_system_new(cfdata->card);
if (!sys) if (!sys)
return; return;
cfdata->channel = 0; cfdata->channel = 0;
cfdata->channel_name = eina_stringshare_add(cfdata->conf->channel_name); cfdata->channel_name = eina_stringshare_add(cfdata->conf->channel_name);
cfdata->channels_names = e_mixer_system_get_channels_names(sys); cfdata->channels_names = e_mixer_system_get_channels_names(sys);
EINA_LIST_FOREACH(cfdata->channels_names, l, channel) EINA_LIST_FOREACH(cfdata->channels_names, l, channel)
{ {
if (channel && cfdata->channel_name && if (channel && cfdata->channel_name &&
(channel == cfdata->channel_name || (channel == cfdata->channel_name ||
strcmp(channel, cfdata->channel_name) == 0)) strcmp(channel, cfdata->channel_name) == 0))
{ {
cfdata->channel = i; cfdata->channel = i;
break; break;
} }
i++; i++;
} }
e_mixer_system_del(sys); e_mixer_system_del(sys);
} }
@ -104,7 +104,7 @@ _create_data(E_Config_Dialog *dialog)
cfdata = E_NEW(E_Config_Dialog_Data, 1); cfdata = E_NEW(E_Config_Dialog_Data, 1);
if (!cfdata) if (!cfdata)
return NULL; return NULL;
conf = dialog->data; conf = dialog->data;
cfdata->conf = conf; cfdata->conf = conf;
@ -120,23 +120,22 @@ _create_data(E_Config_Dialog *dialog)
static void static void
_free_data(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata) _free_data(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata)
{ {
E_Mixer_Gadget_Config *conf; E_Mixer_Gadget_Config *conf = dialog->data;
const char *card; const char *card;
conf = dialog->data;
if (conf) if (conf)
conf->dialog = NULL; conf->dialog = NULL;
if (!cfdata) if (!cfdata)
return; return;
EINA_LIST_FREE(cfdata->cards_names, card) EINA_LIST_FREE(cfdata->cards_names, card)
eina_stringshare_del(card); eina_stringshare_del(card);
if (cfdata->channels_names) if (cfdata->channels_names)
e_mixer_system_free_channels_names(cfdata->channels_names); e_mixer_system_free_channels_names(cfdata->channels_names);
if (cfdata->cards) if (cfdata->cards)
e_mixer_system_free_cards(cfdata->cards); e_mixer_system_free_cards(cfdata->cards);
eina_stringshare_del(cfdata->card); eina_stringshare_del(cfdata->card);
eina_stringshare_del(cfdata->channel_name); eina_stringshare_del(cfdata->channel_name);
@ -149,57 +148,52 @@ _free_data(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata)
static int static int
_basic_apply(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata) _basic_apply(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata)
{ {
E_Mixer_Gadget_Config *conf; E_Mixer_Gadget_Config *conf = dialog->data;
const char *card, *channel; const char *card, *channel;
conf = dialog->data;
conf->lock_sliders = cfdata->lock_sliders; conf->lock_sliders = cfdata->lock_sliders;
conf->show_locked = cfdata->show_locked; conf->show_locked = cfdata->show_locked;
card = eina_list_nth(cfdata->cards, cfdata->card_num); card = eina_list_nth(cfdata->cards, cfdata->card_num);
if (card) if (card)
{ {
eina_stringshare_del(conf->card); eina_stringshare_del(conf->card);
conf->card = eina_stringshare_ref(card); conf->card = eina_stringshare_ref(card);
} }
channel = eina_list_nth(cfdata->channels_names, cfdata->channel); channel = eina_list_nth(cfdata->channels_names, cfdata->channel);
if (channel) if (channel)
{ {
eina_stringshare_del(conf->channel_name); eina_stringshare_del(conf->channel_name);
conf->channel_name = eina_stringshare_ref(channel); conf->channel_name = eina_stringshare_ref(channel);
} }
e_mixer_update(conf->instance); e_mixer_update(conf->instance);
return 1; return 1;
} }
static void static void
_lock_change(void *data, Evas_Object *obj, void *event) _lock_change(void *data, Evas_Object *obj __UNUSED__, void *event __UNUSED__)
{ {
E_Config_Dialog_Data *cfdata; E_Config_Dialog_Data *cfdata = data;
cfdata = data;
e_widget_disabled_set(cfdata->ui.general.show_locked, !cfdata->lock_sliders); e_widget_disabled_set(cfdata->ui.general.show_locked, !cfdata->lock_sliders);
} }
static void static void
_basic_create_general(Evas *evas, E_Config_Dialog_Data *cfdata) _basic_create_general(Evas *evas, E_Config_Dialog_Data *cfdata)
{ {
struct mixer_config_ui_general *ui; struct mixer_config_ui_general *ui = &cfdata->ui.general;
ui = &cfdata->ui.general;
ui->frame = e_widget_framelist_add(evas, _("General Settings"), 0); ui->frame = e_widget_framelist_add(evas, _("General Settings"), 0);
ui->lock_sliders = e_widget_check_add( ui->lock_sliders = e_widget_check_add(
evas, _("Lock Sliders"), &cfdata->lock_sliders); evas, _("Lock Sliders"), &cfdata->lock_sliders);
evas_object_smart_callback_add( evas_object_smart_callback_add(
ui->lock_sliders, "changed", _lock_change, cfdata); ui->lock_sliders, "changed", _lock_change, cfdata);
e_widget_framelist_object_append(ui->frame, ui->lock_sliders); e_widget_framelist_object_append(ui->frame, ui->lock_sliders);
ui->show_locked = e_widget_check_add( ui->show_locked = e_widget_check_add(
evas, _("Show both sliders when locked"), &cfdata->show_locked); evas, _("Show both sliders when locked"), &cfdata->show_locked);
e_widget_disabled_set(ui->show_locked, !cfdata->lock_sliders); e_widget_disabled_set(ui->show_locked, !cfdata->lock_sliders);
e_widget_framelist_object_append(ui->frame, ui->show_locked); e_widget_framelist_object_append(ui->frame, ui->show_locked);
} }
@ -210,59 +204,56 @@ _clear_channels(E_Config_Dialog_Data *cfdata)
Evas_Object *o; Evas_Object *o;
EINA_LIST_FREE(cfdata->ui.channels.radios, o) EINA_LIST_FREE(cfdata->ui.channels.radios, o)
evas_object_del(o); evas_object_del(o);
} }
static void static void
_fill_channels(Evas *evas, E_Config_Dialog_Data *cfdata) _fill_channels(Evas *evas, E_Config_Dialog_Data *cfdata)
{ {
struct mixer_config_ui_channels *ui; struct mixer_config_ui_channels *ui = &cfdata->ui.channels;;
Evas_Object *selected; Evas_Object *selected;
Evas_Coord mw, mh; Evas_Coord mw, mh;
const char *name; const char *name;
Eina_List *l; Eina_List *l;
int i = 0; int i = 0;
ui = &cfdata->ui.channels;
ui->radio = e_widget_radio_group_new(&cfdata->channel); ui->radio = e_widget_radio_group_new(&cfdata->channel);
EINA_LIST_FOREACH(cfdata->channels_names, l, name) EINA_LIST_FOREACH(cfdata->channels_names, l, name)
{ {
Evas_Object *ow; Evas_Object *ow;
if (!name) continue; if (!name) continue;
ow = e_widget_radio_add(evas, name, i, ui->radio); ow = e_widget_radio_add(evas, name, i, ui->radio);
ui->radios = eina_list_append(ui->radios, ow); ui->radios = eina_list_append(ui->radios, ow);
e_widget_list_object_append(ui->list, ow, 1, 1, 0.0); e_widget_list_object_append(ui->list, ow, 1, 1, 0.0);
++i; ++i;
} }
e_widget_size_min_get(ui->list, &mw, &mh); e_widget_size_min_get(ui->list, &mw, &mh);
evas_object_resize(ui->list, mw, mh); evas_object_resize(ui->list, mw, mh);
selected = eina_list_nth(ui->radios, cfdata->channel); selected = eina_list_nth(ui->radios, cfdata->channel);
if (selected) if (selected)
{ {
Evas_Coord x, y, w, h, lx, ly; Evas_Coord x, y, w, h, lx, ly;
evas_object_geometry_get(selected, &x, &y, &w, &h); evas_object_geometry_get(selected, &x, &y, &w, &h);
evas_object_geometry_get(ui->list, &lx, &ly, NULL, NULL); evas_object_geometry_get(ui->list, &lx, &ly, NULL, NULL);
x -= lx; x -= lx;
y -= ly - 10; y -= ly - 10;
h += 20; h += 20;
e_widget_scrollframe_child_region_show(ui->scroll, x, y, w, h); e_widget_scrollframe_child_region_show(ui->scroll, x, y, w, h);
} }
} }
static void static void
_channel_scroll_set_min_size(struct mixer_config_ui_channels *ui) _channel_scroll_set_min_size(struct mixer_config_ui_channels *ui)
{ {
Evas_Coord w, h; Evas_Coord w, h;
int len; int len = eina_list_count(ui->radios);
len = eina_list_count(ui->radios);
if (len < 1) if (len < 1)
return; return;
e_widget_size_min_get(ui->list, &w, &h); e_widget_size_min_get(ui->list, &w, &h);
h = 4 * h / len; h = 4 * h / len;
@ -272,9 +263,8 @@ _channel_scroll_set_min_size(struct mixer_config_ui_channels *ui)
static void static void
_basic_create_channels(Evas *evas, E_Config_Dialog_Data *cfdata) _basic_create_channels(Evas *evas, E_Config_Dialog_Data *cfdata)
{ {
struct mixer_config_ui_channels *ui; struct mixer_config_ui_channels *ui = &cfdata->ui.channels;
ui = &cfdata->ui.channels;
ui->list = e_widget_list_add(evas, 1, 0); ui->list = e_widget_list_add(evas, 1, 0);
ui->scroll = e_widget_scrollframe_simple_add(evas, ui->list); ui->scroll = e_widget_scrollframe_simple_add(evas, ui->list);
ui->frame = e_widget_framelist_add(evas, _("Channels"), 0); ui->frame = e_widget_framelist_add(evas, _("Channels"), 0);
@ -286,14 +276,12 @@ _basic_create_channels(Evas *evas, E_Config_Dialog_Data *cfdata)
} }
static void static void
_card_change(void *data, Evas_Object *obj, void *event) _card_change(void *data, Evas_Object *obj, void *event __UNUSED__)
{ {
E_Config_Dialog_Data *cfdata; E_Config_Dialog_Data *cfdata = data;
Evas *evas; Evas *evas;
char *card; char *card;
cfdata = data;
eina_stringshare_del(cfdata->card); eina_stringshare_del(cfdata->card);
e_mixer_system_free_channels_names(cfdata->channels_names); e_mixer_system_free_channels_names(cfdata->channels_names);
@ -312,34 +300,32 @@ _card_change(void *data, Evas_Object *obj, void *event)
static void static void
_basic_create_cards(Evas *evas, E_Config_Dialog_Data *cfdata) _basic_create_cards(Evas *evas, E_Config_Dialog_Data *cfdata)
{ {
struct mixer_config_ui_cards *ui; struct mixer_config_ui_cards *ui = &cfdata->ui.cards;
const char *card; const char *card;
Eina_List *l; Eina_List *l;
int i = 0; int i = 0;
ui = &cfdata->ui.cards;
ui->frame = e_widget_framelist_add(evas, _("Sound Cards"), 0); ui->frame = e_widget_framelist_add(evas, _("Sound Cards"), 0);
ui->radio = e_widget_radio_group_new(&cfdata->card_num); ui->radio = e_widget_radio_group_new(&cfdata->card_num);
EINA_LIST_FOREACH(cfdata->cards_names, l, card) EINA_LIST_FOREACH(cfdata->cards_names, l, card)
{ {
Evas_Object *ow; Evas_Object *ow;
if (!card) continue; if (!card) continue;
ow = e_widget_radio_add(evas, card, i, ui->radio); ow = e_widget_radio_add(evas, card, i, ui->radio);
e_widget_framelist_object_append(ui->frame, ow); e_widget_framelist_object_append(ui->frame, ow);
evas_object_smart_callback_add(ow, "changed", _card_change, cfdata); evas_object_smart_callback_add(ow, "changed", _card_change, cfdata);
++i; ++i;
} }
} }
static Evas_Object * static Evas_Object *
_basic_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata) _basic_create(E_Config_Dialog *cfd __UNUSED__, Evas *evas, E_Config_Dialog_Data *cfdata)
{ {
if (!cfdata) if (!cfdata)
return NULL; return NULL;
cfdata->ui.table = e_widget_table_add(evas, 0); cfdata->ui.table = e_widget_table_add(evas, 0);
_basic_create_general(evas, cfdata); _basic_create_general(evas, cfdata);
@ -363,11 +349,11 @@ e_mixer_config_dialog_new(E_Container *con, E_Mixer_Gadget_Config *conf)
E_Config_Dialog_View *view; E_Config_Dialog_View *view;
if (e_config_dialog_find(_e_mixer_Name, "e_mixer_config_dialog_new")) if (e_config_dialog_find(_e_mixer_Name, "e_mixer_config_dialog_new"))
return NULL; return NULL;
view = E_NEW(E_Config_Dialog_View, 1); view = E_NEW(E_Config_Dialog_View, 1);
if (!view) if (!view)
return NULL; return NULL;
view->create_cfdata = _create_data; view->create_cfdata = _create_data;
view->free_cfdata = _free_data; view->free_cfdata = _free_data;

View File

@ -23,8 +23,8 @@ _find_default_instance_index(E_Mixer_Module_Context *ctxt)
int i; int i;
for (i = 0, l = ctxt->instances; l != NULL; l = l->next, i++) for (i = 0, l = ctxt->instances; l != NULL; l = l->next, i++)
if (l->data == ctxt->default_instance) if (l->data == ctxt->default_instance)
return i; return i;
return 0; return 0;
} }
@ -37,7 +37,7 @@ _create_data(E_Config_Dialog *dialog)
cfdata = E_NEW(E_Config_Dialog_Data, 1); cfdata = E_NEW(E_Config_Dialog_Data, 1);
if (!cfdata) if (!cfdata)
return NULL; return NULL;
ctxt = dialog->data; ctxt = dialog->data;
cfdata->default_instance = _find_default_instance_index(ctxt); cfdata->default_instance = _find_default_instance_index(ctxt);
@ -48,11 +48,9 @@ _create_data(E_Config_Dialog *dialog)
static void static void
_free_data(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata) _free_data(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata)
{ {
E_Mixer_Module_Context *ctxt; E_Mixer_Module_Context *ctxt = dialog->data;
ctxt = dialog->data;
if (ctxt) if (ctxt)
ctxt->conf_dialog = NULL; ctxt->conf_dialog = NULL;
E_FREE(cfdata); E_FREE(cfdata);
} }
@ -60,23 +58,21 @@ _free_data(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata)
static int static int
_basic_apply(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata) _basic_apply(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata)
{ {
E_Mixer_Module_Context *ctxt; E_Mixer_Module_Context *ctxt = dialog->data;
ctxt = dialog->data;
ctxt->default_instance = eina_list_nth(ctxt->instances, ctxt->default_instance = eina_list_nth(ctxt->instances,
cfdata->default_instance); cfdata->default_instance);
if (ctxt->default_instance) if (ctxt->default_instance)
{ {
E_Mixer_Module_Config *conf; E_Mixer_Module_Config *conf;
const char *id; const char *id;
conf = ctxt->conf; conf = ctxt->conf;
if (conf->default_gc_id) if (conf->default_gc_id)
eina_stringshare_del(conf->default_gc_id); eina_stringshare_del(conf->default_gc_id);
id = ctxt->default_instance->gcc->cf->id; id = ctxt->default_instance->gcc->cf->id;
conf->default_gc_id = eina_stringshare_add(id); conf->default_gc_id = eina_stringshare_add(id);
} }
return 1; return 1;
} }
@ -84,15 +80,12 @@ _basic_apply(E_Config_Dialog *dialog, E_Config_Dialog_Data *cfdata)
static void static void
_basic_create_general(E_Config_Dialog *dialog, Evas *evas, E_Config_Dialog_Data *cfdata) _basic_create_general(E_Config_Dialog *dialog, Evas *evas, E_Config_Dialog_Data *cfdata)
{ {
struct mixer_config_ui_general *ui; struct mixer_config_ui_general *ui = &cfdata->ui.general;
E_Mixer_Module_Context *ctxt; E_Mixer_Module_Context *ctxt = dialog->data;
Evas_Object *label; Evas_Object *label;
Eina_List *l; Eina_List *l;
int i; int i;
ui = &cfdata->ui.general;
ctxt = dialog->data;
ui->frame = e_widget_framelist_add(evas, _("General Settings"), 0); ui->frame = e_widget_framelist_add(evas, _("General Settings"), 0);
label = e_widget_label_add(evas, _("Mixer to use for global actions:")); label = e_widget_label_add(evas, _("Mixer to use for global actions:"));
@ -100,45 +93,45 @@ _basic_create_general(E_Config_Dialog *dialog, Evas *evas, E_Config_Dialog_Data
ui->radio = e_widget_radio_group_new(&cfdata->default_instance); ui->radio = e_widget_radio_group_new(&cfdata->default_instance);
for (i = 0, l = ctxt->instances; l != NULL; l = l->next, i++) for (i = 0, l = ctxt->instances; l != NULL; l = l->next, i++)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst;
E_Mixer_Gadget_Config *conf; E_Mixer_Gadget_Config *conf;
Evas_Object *o; Evas_Object *o;
char name[128]; char name[128];
const char *card_name; const char *card_name;
inst = l->data; inst = l->data;
conf = inst->conf; conf = inst->conf;
card_name = e_mixer_system_get_card_name(conf->card); card_name = e_mixer_system_get_card_name(conf->card);
snprintf(name, sizeof(name), "%s: %s", card_name, conf->channel_name); snprintf(name, sizeof(name), "%s: %s", card_name, conf->channel_name);
eina_stringshare_del(card_name); eina_stringshare_del(card_name);
o = e_widget_radio_add(evas, name, i, ui->radio); o = e_widget_radio_add(evas, name, i, ui->radio);
e_widget_framelist_object_append(ui->frame, o); e_widget_framelist_object_append(ui->frame, o);
} }
e_widget_list_object_append(cfdata->ui.list, ui->frame, 1, 1, 0.5); e_widget_list_object_append(cfdata->ui.list, ui->frame, 1, 1, 0.5);
} }
static void static void
cb_mixer_app_del(E_Dialog *dialog, void *data) cb_mixer_app_del(E_Dialog *dialog __UNUSED__, void *data)
{ {
E_Mixer_Module_Context *ctxt = data; E_Mixer_Module_Context *ctxt = data;
ctxt->mixer_dialog = NULL; ctxt->mixer_dialog = NULL;
} }
static void static void
cb_mixer_call(void *data, void *data2) cb_mixer_call(void *data, void *data2 __UNUSED__)
{ {
E_Mixer_Module_Context *ctxt = data; E_Mixer_Module_Context *ctxt = data;
E_Container *con; E_Container *con;
if (ctxt->mixer_dialog) if (ctxt->mixer_dialog)
{ {
e_dialog_show(ctxt->mixer_dialog); e_dialog_show(ctxt->mixer_dialog);
return; return;
} }
con = e_container_current_get(e_manager_current_get()); con = e_container_current_get(e_manager_current_get());
ctxt->mixer_dialog = e_mixer_app_dialog_new(con, cb_mixer_app_del, ctxt); ctxt->mixer_dialog = e_mixer_app_dialog_new(con, cb_mixer_app_del, ctxt);
@ -158,7 +151,7 @@ static Evas_Object *
_basic_create(E_Config_Dialog *dialog, Evas *evas, E_Config_Dialog_Data *cfdata) _basic_create(E_Config_Dialog *dialog, Evas *evas, E_Config_Dialog_Data *cfdata)
{ {
if (!cfdata) if (!cfdata)
return NULL; return NULL;
cfdata->ui.list = e_widget_list_add(evas, 0, 0); cfdata->ui.list = e_widget_list_add(evas, 0, 0);
_basic_create_general(dialog, evas, cfdata); _basic_create_general(dialog, evas, cfdata);
@ -173,11 +166,11 @@ e_mixer_config_module_dialog_new(E_Container *con, E_Mixer_Module_Context *ctxt)
E_Config_Dialog_View *view; E_Config_Dialog_View *view;
if (e_config_dialog_find(_e_mixer_Name, "extensions/mixer")) if (e_config_dialog_find(_e_mixer_Name, "extensions/mixer"))
return NULL; return NULL;
view = E_NEW(E_Config_Dialog_View, 1); view = E_NEW(E_Config_Dialog_View, 1);
if (!view) if (!view)
return NULL; return NULL;
view->create_cfdata = _create_data; view->create_cfdata = _create_data;
view->free_cfdata = _free_data; view->free_cfdata = _free_data;

View File

@ -12,7 +12,7 @@ const char *
e_mixer_theme_path(void) e_mixer_theme_path(void)
{ {
#define TF "/e-module-mixer.edj" #define TF "/e-module-mixer.edj"
int dirlen; size_t dirlen;
dirlen = strlen(mixer_mod->dir); dirlen = strlen(mixer_mod->dir);
if (dirlen >= sizeof(tmpbuf) - sizeof(TF)) if (dirlen >= sizeof(tmpbuf) - sizeof(TF))
@ -111,7 +111,7 @@ _mixer_gadget_configuration_free(E_Mixer_Module_Config *mod_conf, E_Mixer_Gadget
} }
static Eina_Bool static Eina_Bool
_mixer_gadget_configuration_free_foreach(const Eina_Hash *hash, const void *key, void *hdata, void *fdata) _mixer_gadget_configuration_free_foreach(const Eina_Hash *hash __UNUSED__, const void *key __UNUSED__, void *hdata, void *fdata __UNUSED__)
{ {
_mixer_gadget_configuration_free_int(hdata); _mixer_gadget_configuration_free_int(hdata);
return 1; return 1;
@ -317,16 +317,11 @@ _mixer_toggle_mute(E_Mixer_Instance *inst)
} }
static void static void
_mixer_popup_cb_volume_left_change(void *data, Evas_Object *obj, void *event) _mixer_popup_cb_volume_left_change(void *data, Evas_Object *obj, void *event __UNUSED__)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = data;
E_Mixer_Channel_State *state; E_Mixer_Channel_State *state = &inst->mixer_state;
inst = data;
if (!inst)
return;
state = &inst->mixer_state;
e_mixer_system_get_volume(inst->sys, inst->channel, e_mixer_system_get_volume(inst->sys, inst->channel,
&state->left, &state->right); &state->left, &state->right);
@ -343,16 +338,11 @@ _mixer_popup_cb_volume_left_change(void *data, Evas_Object *obj, void *event)
} }
static void static void
_mixer_popup_cb_volume_right_change(void *data, Evas_Object *obj, void *event) _mixer_popup_cb_volume_right_change(void *data, Evas_Object *obj, void *event __UNUSED__)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = data;
E_Mixer_Channel_State *state; E_Mixer_Channel_State *state = &inst->mixer_state;
inst = data;
if (!inst)
return;
state = &inst->mixer_state;
e_mixer_system_get_volume(inst->sys, inst->channel, e_mixer_system_get_volume(inst->sys, inst->channel,
&state->left, &state->right); &state->left, &state->right);
@ -369,16 +359,11 @@ _mixer_popup_cb_volume_right_change(void *data, Evas_Object *obj, void *event)
} }
static void static void
_mixer_popup_cb_mute_change(void *data, Evas_Object *obj, void *event) _mixer_popup_cb_mute_change(void *data, Evas_Object *obj, void *event __UNUSED__)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = data;
E_Mixer_Channel_State *state; E_Mixer_Channel_State *state = &inst->mixer_state;
inst = data;
if (!inst)
return;
state = &inst->mixer_state;
state->mute = e_widget_check_checked_get(obj); state->mute = e_widget_check_checked_get(obj);
e_mixer_system_set_mute(inst->sys, inst->channel, state->mute); e_mixer_system_set_mute(inst->sys, inst->channel, state->mute);
@ -388,9 +373,7 @@ _mixer_popup_cb_mute_change(void *data, Evas_Object *obj, void *event)
static Evas_Object * static Evas_Object *
_mixer_popup_add_slider(E_Mixer_Instance *inst, int value, void (*cb) (void *data, Evas_Object *obj, void *event_info)) _mixer_popup_add_slider(E_Mixer_Instance *inst, int value, void (*cb) (void *data, Evas_Object *obj, void *event_info))
{ {
Evas_Object *slider; Evas_Object *slider = e_slider_add(inst->popup->win->evas);
slider = e_slider_add(inst->popup->win->evas);
evas_object_show(slider); evas_object_show(slider);
e_slider_orientation_set(slider, 0); e_slider_orientation_set(slider, 0);
e_slider_value_set(slider, value); e_slider_value_set(slider, value);
@ -402,7 +385,7 @@ _mixer_popup_add_slider(E_Mixer_Instance *inst, int value, void (*cb) (void *dat
} }
static void static void
_mixer_app_cb_del(E_Dialog *dialog, void *data) _mixer_app_cb_del(E_Dialog *dialog __UNUSED__, void *data)
{ {
E_Mixer_Module_Context *ctxt = data; E_Mixer_Module_Context *ctxt = data;
ctxt->mixer_dialog = NULL; ctxt->mixer_dialog = NULL;
@ -411,7 +394,7 @@ _mixer_app_cb_del(E_Dialog *dialog, void *data)
static void _mixer_popup_del(E_Mixer_Instance *inst); static void _mixer_popup_del(E_Mixer_Instance *inst);
static int static int
_mixer_popup_input_window_mouse_up_cb(void *data, int type, void *event) _mixer_popup_input_window_mouse_up_cb(void *data, int type __UNUSED__, void *event)
{ {
Ecore_Event_Mouse_Button *ev = event; Ecore_Event_Mouse_Button *ev = event;
E_Mixer_Instance *inst = data; E_Mixer_Instance *inst = data;
@ -425,7 +408,7 @@ _mixer_popup_input_window_mouse_up_cb(void *data, int type, void *event)
} }
static int static int
_mixer_popup_input_window_key_down_cb(void *data, int type, void *event) _mixer_popup_input_window_key_down_cb(void *data, int type __UNUSED__, void *event)
{ {
Ecore_Event_Key *ev = event; Ecore_Event_Key *ev = event;
E_Mixer_Instance *inst = data; E_Mixer_Instance *inst = data;
@ -515,7 +498,7 @@ _mixer_app_select_current(E_Dialog *dialog, E_Mixer_Instance *inst)
static void static void
_mixer_popup_cb_mixer(void *data, void *data2) _mixer_popup_cb_mixer(void *data, void *data2 __UNUSED__)
{ {
E_Mixer_Instance *inst = data; E_Mixer_Instance *inst = data;
E_Mixer_Module_Context *ctxt; E_Mixer_Module_Context *ctxt;
@ -616,11 +599,9 @@ _mixer_popup_new(E_Mixer_Instance *inst)
} }
static void static void
_mixer_menu_cb_post(void *data, E_Menu *menu) _mixer_menu_cb_post(void *data, E_Menu *menu __UNUSED__)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = data;
inst = data;
if ((!inst) || (!inst->menu)) if ((!inst) || (!inst->menu))
return; return;
if (inst->menu) if (inst->menu)
@ -631,14 +612,11 @@ _mixer_menu_cb_post(void *data, E_Menu *menu)
} }
static void static void
_mixer_menu_cb_cfg(void *data, E_Menu *menu, E_Menu_Item *mi) _mixer_menu_cb_cfg(void *data, E_Menu *menu __UNUSED__, E_Menu_Item *mi __UNUSED__)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = data;
E_Container *con; E_Container *con;
inst = data;
if (!inst)
return;
if (inst->popup) if (inst->popup)
_mixer_popup_del(inst); _mixer_popup_del(inst);
con = e_container_current_get(e_manager_current_get()); con = e_container_current_get(e_manager_current_get());
@ -673,16 +651,11 @@ _mixer_menu_new(E_Mixer_Instance *inst, Evas_Event_Mouse_Down *ev)
} }
static void static void
_mixer_cb_mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event) _mixer_cb_mouse_down(void *data, Evas *evas __UNUSED__, Evas_Object *obj __UNUSED__, void *event)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = data;
Evas_Event_Mouse_Down *ev; Evas_Event_Mouse_Down *ev = event;
inst = data;
if (!inst)
return;
ev = event;
if (ev->button == 1) if (ev->button == 1)
{ {
if (!inst->popup) if (!inst->popup)
@ -697,16 +670,11 @@ _mixer_cb_mouse_down(void *data, Evas *evas, Evas_Object *obj, void *event)
} }
static void static void
_mixer_cb_mouse_wheel(void *data, Evas *evas, Evas_Object *obj, void *event) _mixer_cb_mouse_wheel(void *data, Evas *evas __UNUSED__, Evas_Object *obj __UNUSED__, void *event)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = data;
Evas_Event_Mouse_Wheel *ev; Evas_Event_Mouse_Wheel *ev = event;
inst = data;
if (!inst)
return;
ev = event;
if (ev->direction == 0) if (ev->direction == 0)
{ {
if (ev->z > 0) if (ev->z > 0)
@ -746,11 +714,9 @@ _mixer_sys_setup(E_Mixer_Instance *inst)
} }
static int static int
_mixer_system_cb_update(void *data, E_Mixer_System *sys) _mixer_system_cb_update(void *data, E_Mixer_System *sys __UNUSED__)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = data;
inst = data;
e_mixer_system_get_state(inst->sys, inst->channel, &inst->mixer_state); e_mixer_system_get_state(inst->sys, inst->channel, &inst->mixer_state);
_mixer_gadget_update(inst); _mixer_gadget_update(inst);
@ -943,30 +909,28 @@ _gc_shutdown(E_Gadcon_Client *gcc)
} }
static void static void
_gc_orient(E_Gadcon_Client *gcc, E_Gadcon_Orient orient) _gc_orient(E_Gadcon_Client *gcc, E_Gadcon_Orient orient __UNUSED__)
{ {
e_gadcon_client_aspect_set(gcc, 16, 16); e_gadcon_client_aspect_set(gcc, 16, 16);
e_gadcon_client_min_size_set(gcc, 16, 16); e_gadcon_client_min_size_set(gcc, 16, 16);
} }
static char * static char *
_gc_label(E_Gadcon_Client_Class *client_class) _gc_label(E_Gadcon_Client_Class *client_class __UNUSED__)
{ {
return _(_e_mixer_Name); return _(_e_mixer_Name);
} }
static Evas_Object * static Evas_Object *
_gc_icon(E_Gadcon_Client_Class *client_class, Evas *evas) _gc_icon(E_Gadcon_Client_Class *client_class __UNUSED__, Evas *evas)
{ {
Evas_Object *o; Evas_Object *o = edje_object_add(evas);
o = edje_object_add(evas);
edje_object_file_set(o, e_mixer_theme_path(), "icon"); edje_object_file_set(o, e_mixer_theme_path(), "icon");
return o; return o;
} }
static const char * static const char *
_gc_id_new(E_Gadcon_Client_Class *client_class) _gc_id_new(E_Gadcon_Client_Class *client_class __UNUSED__)
{ {
E_Mixer_Module_Context *ctxt; E_Mixer_Module_Context *ctxt;
Eina_List *instances; Eina_List *instances;
@ -998,7 +962,7 @@ static const E_Gadcon_Client_Class _gc_class =
EAPI E_Module_Api e_modapi = {E_MODULE_API_VERSION, _e_mixer_Name}; EAPI E_Module_Api e_modapi = {E_MODULE_API_VERSION, _e_mixer_Name};
static void static void
_mixer_cb_volume_increase(E_Object *obj, const char *params) _mixer_cb_volume_increase(E_Object *obj __UNUSED__, const char *params __UNUSED__)
{ {
E_Mixer_Module_Context *ctxt; E_Mixer_Module_Context *ctxt;
@ -1014,7 +978,7 @@ _mixer_cb_volume_increase(E_Object *obj, const char *params)
} }
static void static void
_mixer_cb_volume_decrease(E_Object *obj, const char *params) _mixer_cb_volume_decrease(E_Object *obj __UNUSED__, const char *params __UNUSED__)
{ {
E_Mixer_Module_Context *ctxt; E_Mixer_Module_Context *ctxt;
@ -1030,7 +994,7 @@ _mixer_cb_volume_decrease(E_Object *obj, const char *params)
} }
static void static void
_mixer_cb_volume_mute(E_Object *obj, const char *params) _mixer_cb_volume_mute(E_Object *obj __UNUSED__, const char *params __UNUSED__)
{ {
E_Mixer_Module_Context *ctxt; E_Mixer_Module_Context *ctxt;
@ -1254,9 +1218,7 @@ _mixer_instances_free(E_Mixer_Module_Context *ctxt)
{ {
while (ctxt->instances) while (ctxt->instances)
{ {
E_Mixer_Instance *inst; E_Mixer_Instance *inst = ctxt->instances->data;
inst = ctxt->instances->data;
e_object_del(E_OBJECT(inst->gcc)); e_object_del(E_OBJECT(inst->gcc));
} }
} }

View File

@ -5,6 +5,7 @@
#include <alloca.h> #include <alloca.h>
#include <Ecore.h> #include <Ecore.h>
#include "e_mod_system.h" #include "e_mod_system.h"
#include "e.h"
struct e_mixer_callback_desc struct e_mixer_callback_desc
{ {
@ -32,7 +33,7 @@ _cb_dispatch(void *data)
desc->idler = NULL; desc->idler = NULL;
if (!r) if (!r)
_mixer_callback_del(desc->self, desc); /* desc is invalid then. */ _mixer_callback_del(desc->self, desc); /* desc is invalid then. */
return 0; return 0;
} }
@ -45,25 +46,25 @@ _cb_fd_handler(void *data, Ecore_Fd_Handler *fd_handler)
desc = data; desc = data;
if (ecore_main_fd_handler_active_get(fd_handler, ECORE_FD_ERROR)) if (ecore_main_fd_handler_active_get(fd_handler, ECORE_FD_ERROR))
{ {
desc->handlers = eina_list_remove(desc->handlers, fd_handler); desc->handlers = eina_list_remove(desc->handlers, fd_handler);
if (!desc->handlers) if (!desc->handlers)
{ {
E_Mixer_System *s; E_Mixer_System *s;
int (*f)(void *, E_Mixer_System *); int (*f)(void *, E_Mixer_System *);
void *d; void *d;
s = desc->self; s = desc->self;
f = desc->func; f = desc->func;
d = desc->data; d = desc->data;
_mixer_callback_del(s, desc); _mixer_callback_del(s, desc);
_mixer_callback_add(s, f, d); _mixer_callback_add(s, f, d);
} }
return 0; return 0;
} }
if (!desc->idler) if (!desc->idler)
desc->idler = ecore_idler_add(_cb_dispatch, desc); desc->idler = ecore_idler_add(_cb_dispatch, desc);
return 1; return 1;
} }
@ -76,11 +77,11 @@ _mixer_callback_add(E_Mixer_System *self, int (*func)(void *data, E_Mixer_System
len = snd_mixer_poll_descriptors_count(self); len = snd_mixer_poll_descriptors_count(self);
if (len <= 0) if (len <= 0)
return 0; return 0;
desc = malloc(sizeof(struct e_mixer_callback_desc)); desc = malloc(sizeof(struct e_mixer_callback_desc));
if (!desc) if (!desc)
return 0; return 0;
desc->func = func; desc->func = func;
desc->data = data; desc->data = data;
@ -91,20 +92,20 @@ _mixer_callback_add(E_Mixer_System *self, int (*func)(void *data, E_Mixer_System
pfds = alloca(len * sizeof(struct pollfd)); pfds = alloca(len * sizeof(struct pollfd));
len = snd_mixer_poll_descriptors(self, pfds, len); len = snd_mixer_poll_descriptors(self, pfds, len);
if (len <= 0) if (len <= 0)
{ {
free(desc); free(desc);
return 0; return 0;
} }
while (len > 0) while (len > 0)
{ {
Ecore_Fd_Handler *fd_handler; Ecore_Fd_Handler *fd_handler;
len--; len--;
fd_handler = ecore_main_fd_handler_add( fd_handler = ecore_main_fd_handler_add(
pfds[len].fd, ECORE_FD_READ, _cb_fd_handler, desc, NULL, NULL); pfds[len].fd, ECORE_FD_READ, _cb_fd_handler, desc, NULL, NULL);
desc->handlers = eina_list_prepend(desc->handlers, fd_handler); desc->handlers = eina_list_prepend(desc->handlers, fd_handler);
} }
snd_mixer_set_callback_private(self, desc); snd_mixer_set_callback_private(self, desc);
@ -119,7 +120,7 @@ _mixer_callback_del(E_Mixer_System *self, struct e_mixer_callback_desc *desc)
snd_mixer_set_callback_private(self, NULL); snd_mixer_set_callback_private(self, NULL);
EINA_LIST_FREE(desc->handlers, handler) EINA_LIST_FREE(desc->handlers, handler)
ecore_main_fd_handler_del(handler); ecore_main_fd_handler_del(handler);
free(desc); free(desc);
@ -127,7 +128,7 @@ _mixer_callback_del(E_Mixer_System *self, struct e_mixer_callback_desc *desc)
} }
static int static int
_mixer_callback_replace(E_Mixer_System *self, struct e_mixer_callback_desc *desc, int (*func)(void *data, E_Mixer_System *self), void *data) _mixer_callback_replace(E_Mixer_System *self __UNUSED__, struct e_mixer_callback_desc *desc, int (*func)(void *data, E_Mixer_System *self), void *data)
{ {
desc->func = func; desc->func = func;
desc->data = data; desc->data = data;
@ -142,29 +143,29 @@ e_mixer_system_new(const char *name)
int err; int err;
if (!name) if (!name)
return NULL; return NULL;
err = snd_mixer_open(&handle, 0); err = snd_mixer_open(&handle, 0);
if (err < 0) if (err < 0)
goto error_open; goto error_open;
err = snd_mixer_attach(handle, name); err = snd_mixer_attach(handle, name);
if (err < 0) if (err < 0)
goto error_load; goto error_load;
err = snd_mixer_selem_register(handle, NULL, NULL); err = snd_mixer_selem_register(handle, NULL, NULL);
if (err < 0) if (err < 0)
goto error_load; goto error_load;
err = snd_mixer_load(handle); err = snd_mixer_load(handle);
if (err < 0) if (err < 0)
goto error_load; goto error_load;
return handle; return handle;
error_load: error_load:
snd_mixer_close(handle); snd_mixer_close(handle);
error_open: error_open:
fprintf(stderr, "MIXER: Cannot get hardware info: %s\n", snd_strerror(err)); fprintf(stderr, "MIXER: Cannot get hardware info: %s\n", snd_strerror(err));
return NULL; return NULL;
} }
@ -174,12 +175,12 @@ e_mixer_system_del(E_Mixer_System *self)
{ {
struct e_mixer_callback_desc *desc; struct e_mixer_callback_desc *desc;
if (self <= 0) if (!self)
return; return;
desc = snd_mixer_get_callback_private(self); desc = snd_mixer_get_callback_private(self);
if (desc) if (desc)
_mixer_callback_del(self, desc); _mixer_callback_del(self, desc);
snd_mixer_close(self); snd_mixer_close(self);
} }
@ -190,22 +191,22 @@ e_mixer_system_callback_set(E_Mixer_System *self, int (*func)(void *data, E_Mixe
struct e_mixer_callback_desc *desc; struct e_mixer_callback_desc *desc;
if (!self) if (!self)
return 0; return 0;
desc = snd_mixer_get_callback_private(self); desc = snd_mixer_get_callback_private(self);
if (!desc) if (!desc)
{ {
if (func) if (func)
return _mixer_callback_add(self, func, data); return _mixer_callback_add(self, func, data);
return 1; return 1;
} }
else else
{ {
if (func) if (func)
return _mixer_callback_replace(self, desc, func, data); return _mixer_callback_replace(self, desc, func, data);
else else
return _mixer_callback_del(self, desc); return _mixer_callback_del(self, desc);
} }
} }
Eina_List * Eina_List *
@ -217,21 +218,21 @@ e_mixer_system_get_cards(void)
cards = NULL; cards = NULL;
card_num = -1; card_num = -1;
while (((err = snd_card_next(&card_num)) == 0) && (card_num >= 0)) while (((err = snd_card_next(&card_num)) == 0) && (card_num >= 0))
{ {
snd_ctl_t *control; snd_ctl_t *control;
char buf[256]; char buf[256];
snprintf(buf, sizeof(buf), "hw:%d", card_num); snprintf(buf, sizeof(buf), "hw:%d", card_num);
if (snd_ctl_open(&control, buf, 0) < 0) if (snd_ctl_open(&control, buf, 0) < 0)
break; break;
snd_ctl_close(control); snd_ctl_close(control);
cards = eina_list_append(cards, eina_stringshare_add(buf)); cards = eina_list_append(cards, eina_stringshare_add(buf));
} }
if (err < 0) if (err < 0)
fprintf(stderr, "MIXER: Cannot get available card number: %s\n", fprintf(stderr, "MIXER: Cannot get available card number: %s\n",
snd_strerror(err)); snd_strerror(err));
return cards; return cards;
} }
@ -242,7 +243,7 @@ e_mixer_system_free_cards(Eina_List *cards)
const char *card; const char *card;
EINA_LIST_FREE(cards, card) EINA_LIST_FREE(cards, card)
eina_stringshare_del(card); eina_stringshare_del(card);
} }
const char * const char *
@ -252,7 +253,7 @@ e_mixer_system_get_default_card(void)
snd_ctl_t *control; snd_ctl_t *control;
if (snd_ctl_open(&control, buf, 0) < 0) if (snd_ctl_open(&control, buf, 0) < 0)
return NULL; return NULL;
snd_ctl_close(control); snd_ctl_close(control);
return eina_stringshare_add(buf); return eina_stringshare_add(buf);
} }
@ -266,30 +267,30 @@ e_mixer_system_get_card_name(const char *card)
int err; int err;
if (!card) if (!card)
return NULL; return NULL;
snd_ctl_card_info_alloca(&hw_info); snd_ctl_card_info_alloca(&hw_info);
err = snd_ctl_open(&control, card, 0); err = snd_ctl_open(&control, card, 0);
if (err < 0) if (err < 0)
return NULL; return NULL;
err = snd_ctl_card_info(control, hw_info); err = snd_ctl_card_info(control, hw_info);
if (err < 0) if (err < 0)
{ {
fprintf(stderr, "MIXER: Cannot get hardware info: %s: %s\n", card, fprintf(stderr, "MIXER: Cannot get hardware info: %s: %s\n", card,
snd_strerror(err)); snd_strerror(err));
snd_ctl_close(control); snd_ctl_close(control);
return NULL; return NULL;
} }
snd_ctl_close(control); snd_ctl_close(control);
name = snd_ctl_card_info_get_name(hw_info); name = snd_ctl_card_info_get_name(hw_info);
if (!name) if (!name)
{ {
fprintf(stderr, "MIXER: Cannot get hardware name: %s\n", card); fprintf(stderr, "MIXER: Cannot get hardware name: %s\n", card);
return NULL; return NULL;
} }
return eina_stringshare_add(name); return eina_stringshare_add(name);
} }
@ -301,19 +302,19 @@ e_mixer_system_get_channels(E_Mixer_System *self)
snd_mixer_elem_t *elem; snd_mixer_elem_t *elem;
if (!self) if (!self)
return NULL; return NULL;
channels = NULL; channels = NULL;
elem = snd_mixer_first_elem(self); elem = snd_mixer_first_elem(self);
for (; elem != NULL; elem = snd_mixer_elem_next(elem)) for (; elem != NULL; elem = snd_mixer_elem_next(elem))
{ {
if ((!snd_mixer_selem_is_active(elem)) || if ((!snd_mixer_selem_is_active(elem)) ||
(!snd_mixer_selem_has_playback_volume(elem))) (!snd_mixer_selem_has_playback_volume(elem)))
continue; continue;
channels = eina_list_append(channels, elem); channels = eina_list_append(channels, elem);
} }
return channels; return channels;
} }
@ -332,24 +333,24 @@ e_mixer_system_get_channels_names(E_Mixer_System *self)
snd_mixer_selem_id_t *sid; snd_mixer_selem_id_t *sid;
if (!self) if (!self)
return NULL; return NULL;
channels = NULL; channels = NULL;
snd_mixer_selem_id_alloca(&sid); snd_mixer_selem_id_alloca(&sid);
elem = snd_mixer_first_elem(self); elem = snd_mixer_first_elem(self);
for (; elem != NULL; elem = snd_mixer_elem_next(elem)) for (; elem != NULL; elem = snd_mixer_elem_next(elem))
{ {
const char *name; const char *name;
if ((!snd_mixer_selem_is_active(elem)) || if ((!snd_mixer_selem_is_active(elem)) ||
(!snd_mixer_selem_has_playback_volume(elem))) (!snd_mixer_selem_has_playback_volume(elem)))
continue; continue;
snd_mixer_selem_get_id(elem, sid); snd_mixer_selem_get_id(elem, sid);
name = snd_mixer_selem_id_get_name(sid); name = snd_mixer_selem_id_get_name(sid);
if (name) if (name)
channels = eina_list_append(channels, eina_stringshare_add(name)); channels = eina_list_append(channels, eina_stringshare_add(name));
} }
return channels; return channels;
} }
@ -360,7 +361,7 @@ e_mixer_system_free_channels_names(Eina_List *channels_names)
const char *channel; const char *channel;
EINA_LIST_FREE(channels_names, channel) EINA_LIST_FREE(channels_names, channel)
eina_stringshare_del(channel); eina_stringshare_del(channel);
} }
const char * const char *
@ -370,23 +371,23 @@ e_mixer_system_get_default_channel_name(E_Mixer_System *self)
snd_mixer_selem_id_t *sid; snd_mixer_selem_id_t *sid;
if (!self) if (!self)
return NULL; return NULL;
snd_mixer_selem_id_alloca(&sid); snd_mixer_selem_id_alloca(&sid);
elem = snd_mixer_first_elem(self); elem = snd_mixer_first_elem(self);
for (; elem != NULL; elem = snd_mixer_elem_next(elem)) for (; elem != NULL; elem = snd_mixer_elem_next(elem))
{ {
const char *name; const char *name;
if ((!snd_mixer_selem_is_active(elem)) || if ((!snd_mixer_selem_is_active(elem)) ||
(!snd_mixer_selem_has_playback_volume(elem))) (!snd_mixer_selem_has_playback_volume(elem)))
continue; continue;
snd_mixer_selem_get_id(elem, sid); snd_mixer_selem_get_id(elem, sid);
name = snd_mixer_selem_id_get_name(sid); name = snd_mixer_selem_id_get_name(sid);
if (name) if (name)
return eina_stringshare_add(name); return eina_stringshare_add(name);
} }
return NULL; return NULL;
} }
@ -398,29 +399,29 @@ e_mixer_system_get_channel_by_name(E_Mixer_System *self, const char *name)
snd_mixer_selem_id_t *sid; snd_mixer_selem_id_t *sid;
if ((!self) || (!name)) if ((!self) || (!name))
return NULL; return NULL;
snd_mixer_selem_id_alloca(&sid); snd_mixer_selem_id_alloca(&sid);
elem = snd_mixer_first_elem(self); elem = snd_mixer_first_elem(self);
for (; elem != NULL; elem = snd_mixer_elem_next(elem)) for (; elem != NULL; elem = snd_mixer_elem_next(elem))
{ {
const char *n; const char *n;
if ((!snd_mixer_selem_is_active(elem)) || if ((!snd_mixer_selem_is_active(elem)) ||
(!snd_mixer_selem_has_playback_volume(elem))) (!snd_mixer_selem_has_playback_volume(elem)))
continue; continue;
snd_mixer_selem_get_id(elem, sid); snd_mixer_selem_get_id(elem, sid);
n = snd_mixer_selem_id_get_name(sid); n = snd_mixer_selem_id_get_name(sid);
if (n && (strcmp(n, name) == 0)) if (n && (strcmp(n, name) == 0))
return elem; return elem;
} }
return NULL; return NULL;
} }
void void
e_mixer_system_channel_del(E_Mixer_Channel *channel) e_mixer_system_channel_del(E_Mixer_Channel *channel __UNUSED__)
{ {
} }
@ -431,7 +432,7 @@ e_mixer_system_get_channel_name(E_Mixer_System *self, E_Mixer_Channel *channel)
const char *name; const char *name;
if ((!self) || (!channel)) if ((!self) || (!channel))
return NULL; return NULL;
snd_mixer_selem_id_alloca(&sid); snd_mixer_selem_id_alloca(&sid);
snd_mixer_selem_get_id(channel, sid); snd_mixer_selem_get_id(channel, sid);
@ -446,27 +447,27 @@ e_mixer_system_get_volume(E_Mixer_System *self, E_Mixer_Channel *channel, int *l
long lvol, rvol, range, min, max; long lvol, rvol, range, min, max;
if ((!self) || (!channel) || (!left) || (!right)) if ((!self) || (!channel) || (!left) || (!right))
return 0; return 0;
snd_mixer_handle_events(self); snd_mixer_handle_events(self);
snd_mixer_selem_get_playback_volume_range(channel, &min, &max); snd_mixer_selem_get_playback_volume_range(channel, &min, &max);
range = max - min; range = max - min;
if (range < 1) if (range < 1)
return 0; return 0;
if (snd_mixer_selem_has_playback_channel(channel, 0)) if (snd_mixer_selem_has_playback_channel(channel, 0))
snd_mixer_selem_get_playback_volume(channel, 0, &lvol); snd_mixer_selem_get_playback_volume(channel, 0, &lvol);
else else
lvol = min; lvol = min;
if (snd_mixer_selem_has_playback_channel(channel, 1)) if (snd_mixer_selem_has_playback_channel(channel, 1))
snd_mixer_selem_get_playback_volume(channel, 1, &rvol); snd_mixer_selem_get_playback_volume(channel, 1, &rvol);
else else
rvol = min; rvol = min;
if (snd_mixer_selem_is_playback_mono(channel) || if (snd_mixer_selem_is_playback_mono(channel) ||
snd_mixer_selem_has_playback_volume_joined(channel)) snd_mixer_selem_has_playback_volume_joined(channel))
rvol = lvol; rvol = lvol;
*left = rint((double)(lvol - min) * 100 / (double)range); *left = rint((double)(lvol - min) * 100 / (double)range);
*right = rint((double)(rvol - min) * 100 / (double)range); *right = rint((double)(rvol - min) * 100 / (double)range);
@ -481,44 +482,44 @@ e_mixer_system_set_volume(E_Mixer_System *self, E_Mixer_Channel *channel, int le
int mode; int mode;
if ((!self) || (!channel)) if ((!self) || (!channel))
return 0; return 0;
snd_mixer_handle_events(self); snd_mixer_handle_events(self);
snd_mixer_selem_get_playback_volume_range(channel, &min, &max); snd_mixer_selem_get_playback_volume_range(channel, &min, &max);
div = 100 + min; div = 100 + min;
if (div == 0) if (div == 0)
{ {
div = 1; /* no zero-division */ div = 1; /* no zero-division */
min++; min++;
} }
range = max - min; range = max - min;
if (range < 1) if (range < 1)
return 0; return 0;
mode = 0; mode = 0;
if (left >= 0) if (left >= 0)
{ {
left = (((range * left) + (range / 2)) / div) - min; left = (((range * left) + (range / 2)) / div) - min;
mode |= 1; mode |= 1;
} }
if (right >= 0) if (right >= 0)
{ {
right = (((range * right) + (range / 2)) / div) - min; right = (((range * right) + (range / 2)) / div) - min;
mode |= 2; mode |= 2;
} }
if (mode & 1) if (mode & 1)
snd_mixer_selem_set_playback_volume(channel, 0, left); snd_mixer_selem_set_playback_volume(channel, 0, left);
if ((!snd_mixer_selem_is_playback_mono(channel)) && if ((!snd_mixer_selem_is_playback_mono(channel)) &&
(!snd_mixer_selem_has_playback_volume_joined(channel)) && (!snd_mixer_selem_has_playback_volume_joined(channel)) &&
(mode & 2)) (mode & 2))
{ {
if (snd_mixer_selem_has_playback_channel(channel, 1)) if (snd_mixer_selem_has_playback_channel(channel, 1))
snd_mixer_selem_set_playback_volume(channel, 1, right); snd_mixer_selem_set_playback_volume(channel, 1, right);
} }
return 1; return 1;
} }
@ -527,7 +528,7 @@ int
e_mixer_system_can_mute(E_Mixer_System *self, E_Mixer_Channel *channel) e_mixer_system_can_mute(E_Mixer_System *self, E_Mixer_Channel *channel)
{ {
if ((!self) || (!channel)) if ((!self) || (!channel))
return 0; return 0;
snd_mixer_handle_events(self); snd_mixer_handle_events(self);
return (snd_mixer_selem_has_playback_switch(channel) || return (snd_mixer_selem_has_playback_switch(channel) ||
@ -538,22 +539,22 @@ int
e_mixer_system_get_mute(E_Mixer_System *self, E_Mixer_Channel *channel, int *mute) e_mixer_system_get_mute(E_Mixer_System *self, E_Mixer_Channel *channel, int *mute)
{ {
if ((!self) || (!channel) || (!mute)) if ((!self) || (!channel) || (!mute))
return 0; return 0;
snd_mixer_handle_events(self); snd_mixer_handle_events(self);
if (snd_mixer_selem_has_playback_switch(channel) || if (snd_mixer_selem_has_playback_switch(channel) ||
snd_mixer_selem_has_playback_switch_joined(channel)) snd_mixer_selem_has_playback_switch_joined(channel))
{ {
int m; int m;
/* XXX: not checking for return, always returns 0 even if it worked. /* XXX: not checking for return, always returns 0 even if it worked.
* alsamixer also don't check it. Bug? * alsamixer also don't check it. Bug?
*/ */
snd_mixer_selem_get_playback_switch(channel, 0, &m); snd_mixer_selem_get_playback_switch(channel, 0, &m);
*mute = !m; *mute = !m;
} }
else else
*mute = 0; *mute = 0;
return 1; return 1;
} }
@ -562,14 +563,14 @@ int
e_mixer_system_set_mute(E_Mixer_System *self, E_Mixer_Channel *channel, int mute) e_mixer_system_set_mute(E_Mixer_System *self, E_Mixer_Channel *channel, int mute)
{ {
if ((!self) || (!channel)) if ((!self) || (!channel))
return 0; return 0;
snd_mixer_handle_events(self); snd_mixer_handle_events(self);
if (snd_mixer_selem_has_playback_switch(channel) || if (snd_mixer_selem_has_playback_switch(channel) ||
snd_mixer_selem_has_playback_switch_joined(channel)) snd_mixer_selem_has_playback_switch_joined(channel))
return snd_mixer_selem_set_playback_switch_all(channel, !mute); return snd_mixer_selem_set_playback_switch_all(channel, !mute);
else else
return 0; return 0;
} }
int int
@ -578,7 +579,7 @@ e_mixer_system_get_state(E_Mixer_System *self, E_Mixer_Channel *channel, E_Mixer
int r; int r;
if (!state) if (!state)
return 0; return 0;
r = e_mixer_system_get_mute(self, channel, &state->mute); r = e_mixer_system_get_mute(self, channel, &state->mute);
r &= e_mixer_system_get_volume(self, channel, &state->left, &state->right); r &= e_mixer_system_get_volume(self, channel, &state->left, &state->right);
@ -591,7 +592,7 @@ e_mixer_system_set_state(E_Mixer_System *self, E_Mixer_Channel *channel, const E
int r; int r;
if (!state) if (!state)
return 0; return 0;
r = e_mixer_system_set_mute(self, channel, state->mute); r = e_mixer_system_set_mute(self, channel, state->mute);
r &= e_mixer_system_set_volume(self, channel, state->left, state->right); r &= e_mixer_system_set_volume(self, channel, state->left, state->right);
@ -602,7 +603,7 @@ int
e_mixer_system_has_capture(E_Mixer_System *self, E_Mixer_Channel *channel) e_mixer_system_has_capture(E_Mixer_System *self, E_Mixer_Channel *channel)
{ {
if ((!self) || (!channel)) if ((!self) || (!channel))
return 0; return 0;
return snd_mixer_selem_has_capture_switch(channel); return snd_mixer_selem_has_capture_switch(channel);
} }