Mercurial > audlegacy
diff Plugins/Output/alsa/configure.c @ 211:0b48662886e9 trunk
[svn] Sync ALSA plugin with enhancements/patches from Fatal (XMMS cvs)
author | nenolod |
---|---|
date | Sun, 20 Nov 2005 00:34:09 -0800 |
parents | fa848bd484d8 |
children | acae8fa925c3 |
line wrap: on
line diff
--- a/Plugins/Output/alsa/configure.c Sat Nov 19 14:42:28 2005 -0800 +++ b/Plugins/Output/alsa/configure.c Sun Nov 20 00:34:09 2005 -0800 @@ -1,6 +1,6 @@ /* XMMS - ALSA output plugin * Copyright (C) 2001-2003 Matthieu Sozeau <mattam@altern.org> - * Copyright (C) 2003-2004 Haavard Kvaalen + * Copyright (C) 2003-2005 Haavard Kvaalen * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -18,17 +18,10 @@ */ #include "alsa.h" #include <stdio.h> -#include <libaudacious/configdb.h> -#include <glib/gi18n.h> - static GtkWidget *configure_win = NULL; static GtkWidget *buffer_time_spin, *period_time_spin; -static GtkWidget *mmap_button, *softvolume_toggle_button; - -static GtkWidget *thread_buffer_time_spin; -static GtkWidget *mthread_button; - +static GtkWidget *softvolume_toggle_button, *thread_buffer_time_spin; static GtkWidget *devices_combo, *mixer_devices_combo; @@ -39,414 +32,418 @@ #define GET_TOGGLE(tb) gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(tb)) #define GET_CHARS(edit) gtk_editable_get_chars(GTK_EDITABLE(edit), 0, -1) -static void -configure_win_ok_cb(GtkWidget * w, gpointer data) +static void configure_win_ok_cb(GtkWidget * w, gpointer data) { - g_free(alsa_cfg.pcm_device); - alsa_cfg.pcm_device = GET_CHARS(GTK_COMBO(devices_combo)->entry); - alsa_cfg.buffer_time = GET_SPIN_INT(buffer_time_spin); - alsa_cfg.period_time = GET_SPIN_INT(period_time_spin); + g_free(alsa_cfg.pcm_device); + alsa_cfg.pcm_device = GET_CHARS(GTK_COMBO(devices_combo)->entry); + alsa_cfg.buffer_time = GET_SPIN_INT(buffer_time_spin); + alsa_cfg.period_time = GET_SPIN_INT(period_time_spin); alsa_cfg.thread_buffer_time = GET_SPIN_INT(thread_buffer_time_spin); - alsa_cfg.multi_thread = GET_TOGGLE(mthread_button); - alsa_cfg.mmap = GET_TOGGLE(mmap_button); - alsa_cfg.soft_volume = GET_TOGGLE(softvolume_toggle_button); - alsa_cfg.mixer_card = current_mixer_card; - alsa_cfg.mixer_device = GET_CHARS(GTK_COMBO(mixer_devices_combo)->entry); + alsa_cfg.soft_volume = GET_TOGGLE(softvolume_toggle_button); + alsa_cfg.mixer_card = current_mixer_card; + alsa_cfg.mixer_device = GET_CHARS(GTK_COMBO(mixer_devices_combo)->entry); + + alsa_save_config(); + gtk_widget_destroy(configure_win); +} + +void alsa_save_config(void) +{ + ConfigDb *cfgfile = bmp_cfg_db_open(); - alsa_save_config(); - gtk_widget_destroy(configure_win); + bmp_cfg_db_set_int(cfgfile, "ALSA", "buffer_time", alsa_cfg.buffer_time); + bmp_cfg_db_set_int(cfgfile, "ALSA", "period_time", alsa_cfg.period_time); + bmp_cfg_db_set_int(cfgfile, "ALSA", "thread_buffer_time", alsa_cfg.thread_buffer_time); + bmp_cfg_db_set_string(cfgfile,"ALSA","pcm_device", alsa_cfg.pcm_device); + bmp_cfg_db_set_int(cfgfile, "ALSA", "mixer_card", alsa_cfg.mixer_card); + bmp_cfg_db_set_string(cfgfile,"ALSA","mixer_device", alsa_cfg.mixer_device); + bmp_cfg_db_set_bool(cfgfile, "ALSA", "soft_volume", + alsa_cfg.soft_volume); + bmp_cfg_db_set_int(cfgfile, "ALSA", "volume_left", alsa_cfg.vol.left); + bmp_cfg_db_set_int(cfgfile, "ALSA", "volume_right", alsa_cfg.vol.right); + bmp_cfg_db_close(cfgfile); } -void -alsa_save_config(void) -{ - //ConfigFile *cfgfile = xmms_cfg_open_default_file(); - ConfigDb *cfgfile; - - cfgfile = bmp_cfg_db_open(); - bmp_cfg_db_set_int(cfgfile, "ALSA", "buffer_time", alsa_cfg.buffer_time); - bmp_cfg_db_set_int(cfgfile, "ALSA", "thread_buffer_time", alsa_cfg.thread_buffer_time); - bmp_cfg_db_set_int(cfgfile, "ALSA", "period_time", alsa_cfg.period_time); - bmp_cfg_db_set_bool(cfgfile, "ALSA", "multi_thread", alsa_cfg.multi_thread); - bmp_cfg_db_set_bool(cfgfile, "ALSA", "mmap", alsa_cfg.mmap); - bmp_cfg_db_set_string(cfgfile, "ALSA", "pcm_device", alsa_cfg.pcm_device); - bmp_cfg_db_set_int(cfgfile, "ALSA", "mixer_card", alsa_cfg.mixer_card); - bmp_cfg_db_set_string(cfgfile, "ALSA", "mixer_device", - alsa_cfg.mixer_device); - bmp_cfg_db_set_bool(cfgfile, "ALSA", "soft_volume", alsa_cfg.soft_volume); - bmp_cfg_db_set_int(cfgfile, "ALSA", "volume_left", alsa_cfg.vol.left); - bmp_cfg_db_set_int(cfgfile, "ALSA", "volume_right", alsa_cfg.vol.right); -// bmp_cfg_db_set_default_file(cfgfile); -// xmms_cfg_free(cfgfile); - bmp_cfg_db_close(cfgfile); -} - -static int -get_cards(GtkOptionMenu * omenu, GCallback cb, int active) +static int get_cards(GtkOptionMenu *omenu, GtkSignalFunc cb, int active) { - GtkWidget *menu, *item; - int card = -1, err, set = 0, curr = -1; + GtkWidget *menu, *item; + int card = -1, err, set = 0, curr = -1; - menu = gtk_menu_new(); - if ((err = snd_card_next(&card)) != 0) - g_warning("snd_next_card() failed: %s", snd_strerror(-err)); + menu = gtk_menu_new(); + if ((err = snd_card_next(&card)) != 0) + g_warning("snd_next_card() failed: %s", snd_strerror(-err)); - while (card > -1) { - char *label; + while (card > -1) + { + char *label; - curr++; - if (card == active) - set = curr; - if ((err = snd_card_get_name(card, &label)) != 0) { - g_warning("snd_carg_get_name() failed: %s", snd_strerror(-err)); - break; - } + curr++; + if (card == active) + set = curr; + if ((err = snd_card_get_name(card, &label)) != 0) + { + g_warning("snd_carg_get_name() failed: %s", + snd_strerror(-err)); + break; + } - item = gtk_menu_item_new_with_label(label); - g_signal_connect(item, "activate", G_CALLBACK(cb), - GINT_TO_POINTER(card)); - gtk_widget_show(item); - gtk_menu_append(GTK_MENU(menu), item); - if ((err = snd_card_next(&card)) != 0) { - g_warning("snd_next_card() failed: %s", snd_strerror(-err)); - break; - } - } + item = gtk_menu_item_new_with_label(label); + gtk_signal_connect(GTK_OBJECT(item), "activate", cb, + GINT_TO_POINTER(card)); + gtk_widget_show(item); + gtk_menu_append(GTK_MENU(menu), item); + if ((err = snd_card_next(&card)) != 0) + { + g_warning("snd_next_card() failed: %s", + snd_strerror(-err)); + break; + } + } - gtk_option_menu_set_menu(omenu, menu); - return set; + gtk_option_menu_set_menu(omenu, menu); + return set; } -static int -get_mixer_devices(GtkCombo * combo, int card) +static int get_mixer_devices(GtkCombo *combo, int card) { - GList *items = NULL; - int err; - snd_mixer_t *mixer; - snd_mixer_elem_t *current; + GList *items = NULL; + int err; + snd_mixer_t *mixer; + snd_mixer_elem_t *current; - if ((err = alsa_get_mixer(&mixer, card)) < 0) - return err; + if ((err = alsa_get_mixer(&mixer, card)) < 0) + return err; + + current = snd_mixer_first_elem(mixer); - current = snd_mixer_first_elem(mixer); + while (current) + { + const char *sname = snd_mixer_selem_get_name(current); + if (snd_mixer_selem_is_active(current) && + snd_mixer_selem_has_playback_volume(current)) + items = g_list_append(items, g_strdup(sname)); + current = snd_mixer_elem_next(current); + } - while (current) { - const char *sname = snd_mixer_selem_get_name(current); - if (snd_mixer_selem_is_active(current) && - snd_mixer_selem_has_playback_volume(current)) - items = g_list_append(items, g_strdup(sname)); - current = snd_mixer_elem_next(current); - } + gtk_combo_set_popdown_strings(combo, items); - gtk_combo_set_popdown_strings(combo, items); - - return 0; + return 0; } -static void -get_devices_for_card(GtkCombo * combo, int card) +static void get_devices_for_card(GtkCombo *combo, int card) { - GtkWidget *item; - int pcm_device = -1, err; - snd_pcm_info_t *pcm_info; - snd_ctl_t *ctl; - char dev[64], *card_name; + GtkWidget *item; + int pcm_device = -1, err; + snd_pcm_info_t *pcm_info; + snd_ctl_t *ctl; + char dev[64], *card_name; - sprintf(dev, "hw:%i", card); + sprintf(dev, "hw:%i", card); - if ((err = snd_ctl_open(&ctl, dev, 0)) < 0) { - printf("snd_ctl_open() failed: %s", snd_strerror(-err)); - return; - } + if ((err = snd_ctl_open(&ctl, dev, 0)) < 0) + { + printf("snd_ctl_open() failed: %s", snd_strerror(-err)); + return; + } - if ((err = snd_card_get_name(card, &card_name)) != 0) { - g_warning("snd_card_get_name() failed: %s", snd_strerror(-err)); - card_name = _("Unknown soundcard"); - } + if ((err = snd_card_get_name(card, &card_name)) != 0) + { + g_warning("snd_card_get_name() failed: %s", snd_strerror(-err)); + card_name = _("Unknown soundcard"); + } - snd_pcm_info_alloca(&pcm_info); + snd_pcm_info_alloca(&pcm_info); - for (;;) { - char *device, *descr; - if ((err = snd_ctl_pcm_next_device(ctl, &pcm_device)) < 0) { - g_warning("snd_ctl_pcm_next_device() failed: %s", - snd_strerror(-err)); - pcm_device = -1; - } - if (pcm_device < 0) - break; + for (;;) + { + char *device, *descr; + if ((err = snd_ctl_pcm_next_device(ctl, &pcm_device)) < 0) + { + g_warning("snd_ctl_pcm_next_device() failed: %s", + snd_strerror(-err)); + pcm_device = -1; + } + if (pcm_device < 0) + break; - snd_pcm_info_set_device(pcm_info, pcm_device); - snd_pcm_info_set_subdevice(pcm_info, 0); - snd_pcm_info_set_stream(pcm_info, SND_PCM_STREAM_PLAYBACK); + snd_pcm_info_set_device(pcm_info, pcm_device); + snd_pcm_info_set_subdevice(pcm_info, 0); + snd_pcm_info_set_stream(pcm_info, SND_PCM_STREAM_PLAYBACK); - if ((err = snd_ctl_pcm_info(ctl, pcm_info)) < 0) { - if (err != -ENOENT) - g_warning("get_devices_for_card(): " - "snd_ctl_pcm_info() " - "failed (%d:%d): %s.", card, - pcm_device, snd_strerror(-err)); - continue; - } + if ((err = snd_ctl_pcm_info(ctl, pcm_info)) < 0) + { + if (err != -ENOENT) + g_warning("get_devices_for_card(): " + "snd_ctl_pcm_info() " + "failed (%d:%d): %s.", card, + pcm_device, snd_strerror(-err)); + continue; + } - device = g_strdup_printf("hw:%d,%d", card, pcm_device); - descr = g_strconcat(card_name, ": ", - snd_pcm_info_get_name(pcm_info), - " (", device, ")", NULL); - item = gtk_list_item_new_with_label(descr); - gtk_widget_show(item); - g_free(descr); - gtk_combo_set_item_string(combo, GTK_ITEM(item), device); - g_free(device); - gtk_container_add(GTK_CONTAINER(combo->list), item); - } + device = g_strdup_printf("hw:%d,%d", card, pcm_device); + descr = g_strconcat(card_name, ": ", + snd_pcm_info_get_name(pcm_info), + " (", device, ")", NULL); + item = gtk_list_item_new_with_label(descr); + gtk_widget_show(item); + g_free(descr); + gtk_combo_set_item_string(combo, GTK_ITEM(item), device); + g_free(device); + gtk_container_add(GTK_CONTAINER(combo->list), item); + } - snd_ctl_close(ctl); + snd_ctl_close(ctl); } -static void -get_devices(GtkCombo * combo) +static void get_devices(GtkCombo *combo) { - GtkWidget *item; - int card = -1; - int err = 0; - char *descr; + GtkWidget *item; + int card = -1; + int err = 0; + char *descr; + + descr = g_strdup_printf(_("Default PCM device (%s)"), "default"); + item = gtk_list_item_new_with_label(descr); + gtk_widget_show(item); + g_free(descr); + gtk_combo_set_item_string(combo, GTK_ITEM(item), "default"); + gtk_container_add(GTK_CONTAINER(combo->list), item); - descr = g_strdup_printf(_("Default PCM device (%s)"), "default"); - item = gtk_list_item_new_with_label(descr); - gtk_widget_show(item); - g_free(descr); - gtk_combo_set_item_string(combo, GTK_ITEM(item), "default"); - gtk_container_add(GTK_CONTAINER(combo->list), item); + if ((err = snd_card_next(&card)) != 0) + { + g_warning("snd_next_card() failed: %s", snd_strerror(-err)); + return; + } - if ((err = snd_card_next(&card)) != 0) { - g_warning("snd_next_card() failed: %s", snd_strerror(-err)); - return; - } - - while (card > -1) { - get_devices_for_card(combo, card); - if ((err = snd_card_next(&card)) != 0) { - g_warning("snd_next_card() failed: %s", snd_strerror(-err)); - break; - } - } + while (card > -1) + { + get_devices_for_card(combo, card); + if ((err = snd_card_next(&card)) != 0) + { + g_warning("snd_next_card() failed: %s", + snd_strerror(-err)); + break; + } + } } -static void -mixer_card_cb(GtkWidget * widget, gpointer card) +static void mixer_card_cb(GtkWidget * widget, gpointer card) { - if (current_mixer_card == GPOINTER_TO_INT(card)) - return; - current_mixer_card = GPOINTER_TO_INT(card); - get_mixer_devices(GTK_COMBO(mixer_devices_combo), current_mixer_card); + if (current_mixer_card == GPOINTER_TO_INT(card)) + return; + current_mixer_card = GPOINTER_TO_INT(card); + get_mixer_devices(GTK_COMBO(mixer_devices_combo), + current_mixer_card); } -static void -softvolume_toggle_cb(GtkToggleButton * widget, gpointer data) +static void softvolume_toggle_cb(GtkToggleButton * widget, gpointer data) { - gboolean softvolume = gtk_toggle_button_get_active(widget); - gtk_widget_set_sensitive(GTK_WIDGET(data), !softvolume); - gtk_widget_set_sensitive(mixer_devices_combo, !softvolume); + gboolean softvolume = gtk_toggle_button_get_active(widget); + gtk_widget_set_sensitive(GTK_WIDGET(data), !softvolume); + gtk_widget_set_sensitive(mixer_devices_combo, !softvolume); } -void -alsa_configure(void) +void alsa_configure(void) { - GtkWidget *vbox, *notebook; - GtkWidget *dev_vbox, *adevice_frame, *adevice_box; - GtkWidget *mixer_frame, *mixer_box, *mixer_table, *mixer_card_om; - GtkWidget *mixer_card_label, *mixer_device_label; - GtkWidget *buffer_frame, *buffer_vbox, *buffer_table; - GtkWidget *buffer_time_label, *period_time_label; - GtkObject *buffer_time_adj, *period_time_adj; - GtkWidget *bbox, *ok, *cancel; + GtkWidget *vbox, *notebook; + GtkWidget *dev_vbox, *adevice_frame, *adevice_box; + GtkWidget *mixer_frame, *mixer_box, *mixer_table, *mixer_card_om; + GtkWidget *mixer_card_label, *mixer_device_label; + GtkWidget *advanced_vbox, *card_vbox; + GtkWidget *buffer_frame, *buffer_vbox, *buffer_table; + GtkWidget *card_frame, *buffer_time_label, *period_time_label; GtkWidget *thread_buffer_time_label; - GtkObject *thread_buffer_time_adj; + GtkObject *buffer_time_adj, *period_time_adj, *thread_buffer_time_adj; + GtkWidget *bbox, *ok, *cancel; - int mset; + int mset; - if (configure_win) { - gtk_window_present(GTK_WINDOW(configure_win)); - return; - } + if (configure_win) + { + gdk_window_raise(configure_win->window); + return; + } - configure_win = gtk_window_new(GTK_WINDOW_TOPLEVEL); - g_signal_connect(configure_win, "destroy", - G_CALLBACK(gtk_widget_destroyed), &configure_win); - gtk_window_set_title(GTK_WINDOW(configure_win), - _("ALSA Driver configuration")); - gtk_window_set_type_hint(GTK_WINDOW(configure_win), - GDK_WINDOW_TYPE_HINT_DIALOG); - gtk_window_set_resizable(GTK_WINDOW(configure_win), FALSE); - gtk_container_border_width(GTK_CONTAINER(configure_win), 10); + configure_win = gtk_window_new(GTK_WINDOW_TOPLEVEL); + gtk_signal_connect(GTK_OBJECT(configure_win), "destroy", + GTK_SIGNAL_FUNC(gtk_widget_destroyed), + &configure_win); + gtk_window_set_title(GTK_WINDOW(configure_win), + _("ALSA Driver configuration")); + gtk_window_set_policy(GTK_WINDOW(configure_win), + FALSE, TRUE, FALSE); + gtk_container_border_width(GTK_CONTAINER(configure_win), 10); - vbox = gtk_vbox_new(FALSE, 10); - gtk_container_add(GTK_CONTAINER(configure_win), vbox); + vbox = gtk_vbox_new(FALSE, 10); + gtk_container_add(GTK_CONTAINER(configure_win), vbox); + + notebook = gtk_notebook_new(); + gtk_box_pack_start(GTK_BOX(vbox), notebook, TRUE, TRUE, 0); + + dev_vbox = gtk_vbox_new(FALSE, 5); + gtk_container_set_border_width(GTK_CONTAINER(dev_vbox), 5); - notebook = gtk_notebook_new(); - gtk_box_pack_start(GTK_BOX(vbox), notebook, TRUE, TRUE, 0); + adevice_frame = gtk_frame_new(_("Audio device:")); + gtk_box_pack_start(GTK_BOX(dev_vbox), adevice_frame, FALSE, FALSE, 0); - dev_vbox = gtk_vbox_new(FALSE, 5); - gtk_container_set_border_width(GTK_CONTAINER(dev_vbox), 5); + adevice_box = gtk_vbox_new(FALSE, 5); + gtk_container_set_border_width(GTK_CONTAINER(adevice_box), 5); + gtk_container_add(GTK_CONTAINER(adevice_frame), adevice_box); - adevice_frame = gtk_frame_new(_("Audio device:")); - gtk_box_pack_start(GTK_BOX(dev_vbox), adevice_frame, FALSE, FALSE, 0); + devices_combo = gtk_combo_new(); + gtk_box_pack_start(GTK_BOX(adevice_box), devices_combo, + FALSE, FALSE, 0); + get_devices(GTK_COMBO(devices_combo)); + gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(devices_combo)->entry), + alsa_cfg.pcm_device); - adevice_box = gtk_vbox_new(FALSE, 5); - gtk_container_set_border_width(GTK_CONTAINER(adevice_box), 5); - gtk_container_add(GTK_CONTAINER(adevice_frame), adevice_box); + mixer_frame = gtk_frame_new(_("Mixer:")); + gtk_box_pack_start(GTK_BOX(dev_vbox), mixer_frame, FALSE, FALSE, 0); + + mixer_box = gtk_vbox_new(FALSE, 5); + gtk_container_set_border_width(GTK_CONTAINER(mixer_box), 5); + gtk_container_add(GTK_CONTAINER(mixer_frame), mixer_box); - devices_combo = gtk_combo_new(); - gtk_box_pack_start(GTK_BOX(adevice_box), devices_combo, FALSE, FALSE, 0); - get_devices(GTK_COMBO(devices_combo)); - gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(devices_combo)->entry), - alsa_cfg.pcm_device); + softvolume_toggle_button = gtk_check_button_new_with_label( + _("Use software volume control")); - mixer_frame = gtk_frame_new(_("Mixer:")); - gtk_box_pack_start(GTK_BOX(dev_vbox), mixer_frame, FALSE, FALSE, 0); + gtk_box_pack_start(GTK_BOX(mixer_box), softvolume_toggle_button, + FALSE, FALSE, 0); - mixer_box = gtk_vbox_new(FALSE, 5); - gtk_container_set_border_width(GTK_CONTAINER(mixer_box), 5); - gtk_container_add(GTK_CONTAINER(mixer_frame), mixer_box); - - softvolume_toggle_button = - gtk_check_button_new_with_label(_("Use software volume control")); + mixer_table = gtk_table_new(2, 2, FALSE); + gtk_table_set_row_spacings(GTK_TABLE(mixer_table), 5); + gtk_table_set_col_spacings(GTK_TABLE(mixer_table), 5); + gtk_box_pack_start(GTK_BOX(mixer_box), mixer_table, FALSE, FALSE, 0); - gtk_box_pack_start(GTK_BOX(mixer_box), softvolume_toggle_button, - FALSE, FALSE, 0); + mixer_card_label = gtk_label_new(_("Mixer card:")); + gtk_label_set_justify(GTK_LABEL(mixer_card_label), GTK_JUSTIFY_LEFT); + gtk_misc_set_alignment(GTK_MISC(mixer_card_label), 0, 0.5); + gtk_table_attach(GTK_TABLE(mixer_table), mixer_card_label, + 0, 1, 0, 1, GTK_FILL, 0, 0, 0); - mixer_table = gtk_table_new(2, 2, FALSE); - gtk_table_set_row_spacings(GTK_TABLE(mixer_table), 5); - gtk_table_set_col_spacings(GTK_TABLE(mixer_table), 5); - gtk_box_pack_start(GTK_BOX(mixer_box), mixer_table, FALSE, FALSE, 0); + mixer_card_om = gtk_option_menu_new(); + mset = get_cards(GTK_OPTION_MENU(mixer_card_om), + mixer_card_cb, alsa_cfg.mixer_card); - mixer_card_label = gtk_label_new(_("Mixer card:")); - gtk_label_set_justify(GTK_LABEL(mixer_card_label), GTK_JUSTIFY_LEFT); - gtk_misc_set_alignment(GTK_MISC(mixer_card_label), 0, 0.5); - gtk_table_attach(GTK_TABLE(mixer_table), mixer_card_label, - 0, 1, 0, 1, GTK_FILL, 0, 0, 0); + gtk_table_attach(GTK_TABLE(mixer_table), mixer_card_om, + 1, 2, 0, 1, GTK_FILL | GTK_EXPAND, GTK_FILL, 0, 0); - mixer_card_om = gtk_option_menu_new(); - mset = get_cards(GTK_OPTION_MENU(mixer_card_om), - G_CALLBACK(mixer_card_cb), alsa_cfg.mixer_card); + mixer_device_label = gtk_label_new(_("Mixer device:")); + gtk_label_set_justify(GTK_LABEL(mixer_device_label), GTK_JUSTIFY_LEFT); + gtk_misc_set_alignment(GTK_MISC(mixer_device_label), 0, 0.5); + gtk_table_attach(GTK_TABLE(mixer_table), mixer_device_label, + 0, 1, 1, 2, GTK_FILL, 0, 0, 0); + mixer_devices_combo = gtk_combo_new(); + gtk_option_menu_set_history(GTK_OPTION_MENU(mixer_card_om), mset); + get_mixer_devices(GTK_COMBO(mixer_devices_combo), alsa_cfg.mixer_card); + gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(mixer_devices_combo)->entry), + alsa_cfg.mixer_device); - gtk_table_attach(GTK_TABLE(mixer_table), mixer_card_om, - 1, 2, 0, 1, GTK_FILL | GTK_EXPAND, GTK_FILL, 0, 0); + gtk_table_attach(GTK_TABLE(mixer_table), mixer_devices_combo, + 1, 2, 1, 2, GTK_FILL | GTK_EXPAND, 0, 0, 0); - mixer_device_label = gtk_label_new(_("Mixer device:")); - gtk_label_set_justify(GTK_LABEL(mixer_device_label), GTK_JUSTIFY_LEFT); - gtk_misc_set_alignment(GTK_MISC(mixer_device_label), 0, 0.5); - gtk_table_attach(GTK_TABLE(mixer_table), mixer_device_label, - 0, 1, 1, 2, GTK_FILL, 0, 0, 0); - mixer_devices_combo = gtk_combo_new(); - gtk_option_menu_set_history(GTK_OPTION_MENU(mixer_card_om), mset); - get_mixer_devices(GTK_COMBO(mixer_devices_combo), alsa_cfg.mixer_card); - gtk_entry_set_text(GTK_ENTRY(GTK_COMBO(mixer_devices_combo)->entry), - alsa_cfg.mixer_device); + gtk_signal_connect(GTK_OBJECT(softvolume_toggle_button), "toggled", + softvolume_toggle_cb, mixer_card_om); + gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(softvolume_toggle_button), + alsa_cfg.soft_volume); + + gtk_notebook_append_page(GTK_NOTEBOOK(notebook), dev_vbox, + gtk_label_new(_("Device settings"))); + + + advanced_vbox = gtk_vbox_new(FALSE, 0); + gtk_container_set_border_width(GTK_CONTAINER(advanced_vbox), 5); - gtk_table_attach(GTK_TABLE(mixer_table), mixer_devices_combo, - 1, 2, 1, 2, GTK_FILL | GTK_EXPAND, 0, 0, 0); + card_frame = gtk_frame_new(_("Soundcard:")); + gtk_box_pack_start_defaults(GTK_BOX(advanced_vbox), card_frame); + + card_vbox = gtk_vbox_new(FALSE, 0); + gtk_container_add(GTK_CONTAINER(card_frame), card_vbox); - g_signal_connect(softvolume_toggle_button, "toggled", - G_CALLBACK(softvolume_toggle_cb), mixer_card_om); - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(softvolume_toggle_button), - alsa_cfg.soft_volume); + gtk_container_set_border_width(GTK_CONTAINER(card_vbox), 5); - gtk_notebook_append_page(GTK_NOTEBOOK(notebook), dev_vbox, - gtk_label_new(_("Device settings"))); - - buffer_frame = gtk_frame_new(_("Advanced settings:")); - gtk_container_set_border_width(GTK_CONTAINER(buffer_frame), 5); + buffer_table = gtk_table_new(2, 2, TRUE); + gtk_table_set_row_spacings(GTK_TABLE(buffer_table), 5); + gtk_table_set_col_spacings(GTK_TABLE(buffer_table), 5); + gtk_box_pack_start_defaults(GTK_BOX(card_vbox), buffer_table); - buffer_vbox = gtk_vbox_new(FALSE, 0); - gtk_container_add(GTK_CONTAINER(buffer_frame), buffer_vbox); - - gtk_container_set_border_width(GTK_CONTAINER(buffer_vbox), 5); + buffer_time_label = gtk_label_new(_("Buffer time (ms):")); + gtk_label_set_justify(GTK_LABEL(buffer_time_label), GTK_JUSTIFY_LEFT); + gtk_misc_set_alignment(GTK_MISC(buffer_time_label), 0, 0.5); + gtk_table_attach(GTK_TABLE(buffer_table), buffer_time_label, + 0, 1, 0, 1, GTK_FILL, 0, 0, 0); - buffer_table = gtk_table_new(2, 3, FALSE); - gtk_table_set_row_spacings(GTK_TABLE(buffer_table), 5); - gtk_table_set_col_spacings(GTK_TABLE(buffer_table), 5); - gtk_box_pack_start(GTK_BOX(buffer_vbox), buffer_table, FALSE, FALSE, 0); - - buffer_time_label = gtk_label_new(_("Buffer time (ms):")); - gtk_label_set_justify(GTK_LABEL(buffer_time_label), GTK_JUSTIFY_LEFT); - gtk_misc_set_alignment(GTK_MISC(buffer_time_label), 0, 0.5); - gtk_table_attach(GTK_TABLE(buffer_table), buffer_time_label, - 0, 1, 0, 1, GTK_FILL, 0, 0, 0); + buffer_time_adj = gtk_adjustment_new(alsa_cfg.buffer_time, + 200, 10000, 100, 100, 100); + buffer_time_spin = gtk_spin_button_new(GTK_ADJUSTMENT(buffer_time_adj), + 8, 0); + gtk_widget_set_usize(buffer_time_spin, 60, -1); + gtk_table_attach(GTK_TABLE(buffer_table), buffer_time_spin, + 1, 2, 0, 1, 0, 0, 0, 0); - buffer_time_adj = gtk_adjustment_new(alsa_cfg.buffer_time, - 200, 1000000, 100, 100, 100); - buffer_time_spin = gtk_spin_button_new(GTK_ADJUSTMENT(buffer_time_adj), - 8, 0); - gtk_widget_set_usize(buffer_time_spin, 60, -1); - gtk_table_attach(GTK_TABLE(buffer_table), buffer_time_spin, - 1, 2, 0, 1, 0, 0, 0, 0); + period_time_label = gtk_label_new(_("Period time (ms):")); + gtk_label_set_justify(GTK_LABEL(period_time_label), GTK_JUSTIFY_LEFT); + gtk_misc_set_alignment(GTK_MISC(period_time_label), 0, 0.5); + gtk_table_attach(GTK_TABLE(buffer_table), period_time_label, + 0, 1, 1, 2, GTK_FILL, 0, 0, 0); + period_time_adj = gtk_adjustment_new(alsa_cfg.period_time, + 1, 500, 1, 100, 100); + period_time_spin = gtk_spin_button_new(GTK_ADJUSTMENT(period_time_adj), + 8, 0); + + gtk_widget_set_usize(period_time_spin, 60, -1); + gtk_table_attach(GTK_TABLE(buffer_table), period_time_spin, + 1, 2, 1, 2, 0, 0, 0, 0); + - period_time_label = gtk_label_new(_("Period time (ms):")); - gtk_label_set_justify(GTK_LABEL(period_time_label), GTK_JUSTIFY_LEFT); - gtk_misc_set_alignment(GTK_MISC(period_time_label), 0, 0.5); - gtk_table_attach(GTK_TABLE(buffer_table), period_time_label, - 0, 1, 1, 2, GTK_FILL, 0, 0, 0); - period_time_adj = gtk_adjustment_new(alsa_cfg.period_time, - 1, 500, 1, 100, 100); - period_time_spin = gtk_spin_button_new(GTK_ADJUSTMENT(period_time_adj), - 8, 0); + buffer_frame = gtk_frame_new(_("XMMS:")); + gtk_box_pack_start_defaults(GTK_BOX(advanced_vbox), buffer_frame); + + buffer_vbox = gtk_vbox_new(FALSE, 0); + gtk_container_add(GTK_CONTAINER(buffer_frame), buffer_vbox); - gtk_widget_set_usize(period_time_spin, 60, -1); - gtk_table_attach(GTK_TABLE(buffer_table), period_time_spin, - 1, 2, 1, 2, 0, 0, 0, 0); + gtk_container_set_border_width(GTK_CONTAINER(buffer_vbox), 5); - thread_buffer_time_label = gtk_label_new(_("Thread buffer time (ms):")); + buffer_table = gtk_table_new(1, 2, TRUE); + gtk_table_set_row_spacings(GTK_TABLE(buffer_table), 5); + gtk_table_set_col_spacings(GTK_TABLE(buffer_table), 5); + gtk_box_pack_start_defaults(GTK_BOX(buffer_vbox), buffer_table); + + thread_buffer_time_label = gtk_label_new(_("Buffer time (ms):")); gtk_label_set_justify(GTK_LABEL(thread_buffer_time_label), GTK_JUSTIFY_LEFT); gtk_misc_set_alignment(GTK_MISC(thread_buffer_time_label), 0, 0.5); gtk_table_attach(GTK_TABLE(buffer_table), thread_buffer_time_label, - 0, 1, 2, 3, GTK_FILL, 0, 0, 0); + 0, 1, 0, 1, GTK_FILL, 0, 0, 0); thread_buffer_time_adj = gtk_adjustment_new(alsa_cfg.thread_buffer_time, - 1000, 1000000, 100, 100, 100); - thread_buffer_time_spin = gtk_spin_button_new(GTK_ADJUSTMENT(thread_buffer_time_adj), - 8, 0); - + 1000, 10000, 100, 100, 100); + thread_buffer_time_spin = + gtk_spin_button_new(GTK_ADJUSTMENT(thread_buffer_time_adj), 8, 0); + gtk_widget_set_usize(thread_buffer_time_spin, 60, -1); gtk_table_attach(GTK_TABLE(buffer_table), thread_buffer_time_spin, - 1, 2, 2, 3, 0, 0, 0, 0); - - mthread_button = gtk_check_button_new_with_label(_("Multi-thread mode")); - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(mthread_button), - alsa_cfg.multi_thread); - gtk_box_pack_start(GTK_BOX(buffer_vbox), mthread_button, FALSE, FALSE, 0); - - mmap_button = gtk_check_button_new_with_label(_("Mmap mode")); - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(mmap_button), - alsa_cfg.mmap); - gtk_box_pack_start(GTK_BOX(buffer_vbox), mmap_button, FALSE, FALSE, 0); + 1, 2, 0, 1, 0, 0, 0, 0); + + gtk_notebook_append_page(GTK_NOTEBOOK(notebook), advanced_vbox, + gtk_label_new(_("Advanced settings"))); - gtk_notebook_append_page(GTK_NOTEBOOK(notebook), buffer_frame, - gtk_label_new(_("Advanced settings"))); - - bbox = gtk_hbutton_box_new(); - gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_END); - gtk_button_box_set_spacing(GTK_BUTTON_BOX(bbox), 5); - gtk_box_pack_start(GTK_BOX(vbox), bbox, FALSE, FALSE, 0); + bbox = gtk_hbutton_box_new(); + gtk_button_box_set_layout(GTK_BUTTON_BOX(bbox), GTK_BUTTONBOX_END); + gtk_button_box_set_spacing(GTK_BUTTON_BOX(bbox), 5); + gtk_box_pack_start(GTK_BOX(vbox), bbox, FALSE, FALSE, 0); - cancel = gtk_button_new_from_stock(GTK_STOCK_CANCEL); - gtk_box_pack_start(GTK_BOX(bbox), cancel, TRUE, TRUE, 0); - - ok = gtk_button_new_from_stock(GTK_STOCK_OK); - gtk_box_pack_start(GTK_BOX(bbox), ok, TRUE, TRUE, 0); - - g_signal_connect(ok, "clicked", G_CALLBACK(configure_win_ok_cb), NULL); - GTK_WIDGET_SET_FLAGS(ok, GTK_CAN_DEFAULT); - gtk_widget_grab_default(ok); + ok = gtk_button_new_with_label(_("OK")); + gtk_signal_connect(GTK_OBJECT(ok), "clicked", configure_win_ok_cb, NULL); + GTK_WIDGET_SET_FLAGS(ok, GTK_CAN_DEFAULT); + gtk_box_pack_start(GTK_BOX(bbox), ok, TRUE, TRUE, 0); + gtk_widget_grab_default(ok); - g_signal_connect_swapped(cancel, "clicked", - G_CALLBACK(gtk_widget_destroy), - configure_win); - GTK_WIDGET_SET_FLAGS(cancel, GTK_CAN_DEFAULT); + cancel = gtk_button_new_with_label(_("Cancel")); + gtk_signal_connect_object(GTK_OBJECT(cancel), "clicked", + gtk_widget_destroy, GTK_OBJECT(configure_win)); + GTK_WIDGET_SET_FLAGS(cancel, GTK_CAN_DEFAULT); + gtk_box_pack_start(GTK_BOX(bbox), cancel, TRUE, TRUE, 0); - - - gtk_widget_show_all(configure_win); + gtk_widget_show_all(configure_win); }