diff options
Diffstat (limited to 'media-sound/gnomeradio/files')
-rw-r--r-- | media-sound/gnomeradio/files/gnomeradio-1.8-crash.patch | 166 | ||||
-rw-r--r-- | media-sound/gnomeradio/files/gnomeradio-1.8-v4l2.patch | 24 |
2 files changed, 190 insertions, 0 deletions
diff --git a/media-sound/gnomeradio/files/gnomeradio-1.8-crash.patch b/media-sound/gnomeradio/files/gnomeradio-1.8-crash.patch new file mode 100644 index 000000000000..60b66723a358 --- /dev/null +++ b/media-sound/gnomeradio/files/gnomeradio-1.8-crash.patch @@ -0,0 +1,166 @@ +From 7694c70f99731724dad64444484d070ff760db89 Mon Sep 17 00:00:00 2001 +From: Jörgen Scheibengruber <mfcn@src.gnome.org> +Date: Sat, 13 Sep 2008 21:00:09 +0000 +Subject: Don't update menus while main-view and tray-icon are not visible yet + + * src/gui.c (main): + * src/prefs.c (add_button_clicked_cb), (del_button_clicked_cb), + (name_cell_edited_cb): + Don't update menus while main-view and tray-icon are not visible yet + + +svn path=/trunk/; revision=208 +--- +diff --git a/ChangeLog b/ChangeLog +index 973a754..814a52d 100644 +--- a/ChangeLog ++++ b/ChangeLog +@@ -1,5 +1,12 @@ + 2008-09-13 Jörgen Scheibengruber <mfcn@gmx.de> + ++ * src/gui.c (main): ++ * src/prefs.c (add_button_clicked_cb), (del_button_clicked_cb), ++ (name_cell_edited_cb): ++ Don't update menus while main-view and tray-icon are not visible yet ++ ++2008-09-13 Jörgen Scheibengruber <mfcn@gmx.de> ++ + * configure.in: + * src/Makefile.am: + +diff --git a/src/gui.c b/src/gui.c +index faca2b7..6c2155f 100644 +--- a/src/gui.c ++++ b/src/gui.c +@@ -54,6 +54,8 @@ GtkTooltips *tooltips; + int mom_ps; + gnomeradio_settings settings; + ++gboolean main_visible; ++ + static GtkWidget *drawing_area; + static GdkPixmap *digits, *signal_s, *stereo; + static GtkWidget *freq_scale; +@@ -1110,6 +1112,7 @@ int main(int argc, char* argv[]) + NULL); + gtk_window_set_default_icon_name("gnomeradio"); + /* Main app */ ++ main_visible = FALSE; + app = gnome_radio_gui(); + + /* Initizialize GStreamer */ +@@ -1150,6 +1153,7 @@ int main(int argc, char* argv[]) + preset_combo_set_item(mom_ps); + + gtk_widget_show_all(app); ++ main_visible = TRUE; + + /* Create an tray icon */ + create_tray_icon(app); +diff --git a/src/prefs.c b/src/prefs.c +index 425d116..7b8ee20 100644 +--- a/src/prefs.c ++++ b/src/prefs.c +@@ -30,6 +30,8 @@ extern GtkTooltips *tooltips; + extern int mom_ps; + extern gnomeradio_settings settings; + ++extern gboolean main_visible; ++ + static GtkWidget *device_entry; + static GtkWidget *mixer_combo; + static GtkWidget *mute_on_exit_cb; +@@ -310,16 +312,18 @@ static void add_button_clicked_cb(GtkWidget *widget, gpointer data) + v_scb = gtk_tree_view_get_vadjustment(GTK_TREE_VIEW(list_view)); + gtk_adjustment_set_value(v_scb, v_scb->upper); + +- gtk_combo_box_append_text(GTK_COMBO_BOX(preset_combo), ps->title); +- mom_ps = g_list_length(settings.presets) - 1; +- preset_combo_set_item(mom_ps); +- +- menuitems = GTK_MENU_SHELL(tray_menu)->children; +- menuitem = gtk_menu_item_new_with_label(ps->title); +- +- gtk_menu_shell_insert(GTK_MENU_SHELL(tray_menu), menuitem, mom_ps); +- g_signal_connect(G_OBJECT(menuitem), "activate", (GCallback)preset_menuitem_activate_cb, (gpointer)mom_ps); +- gtk_widget_show(menuitem); ++ if (main_visible) { ++ gtk_combo_box_append_text(GTK_COMBO_BOX(preset_combo), ps->title); ++ mom_ps = g_list_length(settings.presets) - 1; ++ preset_combo_set_item(mom_ps); ++ ++ menuitems = GTK_MENU_SHELL(tray_menu)->children; ++ menuitem = gtk_menu_item_new_with_label(ps->title); ++ ++ gtk_menu_shell_insert(GTK_MENU_SHELL(tray_menu), menuitem, mom_ps); ++ g_signal_connect(G_OBJECT(menuitem), "activate", (GCallback)preset_menuitem_activate_cb, (gpointer)mom_ps); ++ gtk_widget_show(menuitem); ++ } + + buffer = g_strdup_printf("%d", g_list_length(settings.presets) - 1); + path = gtk_tree_path_new_from_string(buffer); +@@ -356,15 +360,17 @@ static void del_button_clicked_cb(GtkWidget *widget, gpointer data) + gtk_tree_model_get_iter(GTK_TREE_MODEL(list_store), &iter, path); + gtk_list_store_remove(list_store, &iter); + +- gtk_combo_box_remove_text(GTK_COMBO_BOX(preset_combo), *row + 1); +- if (--mom_ps < 0) mom_ps = 0; +- if (!g_list_length(settings.presets)) mom_ps = -1; +- preset_combo_set_item(mom_ps); ++ if (main_visible) { ++ gtk_combo_box_remove_text(GTK_COMBO_BOX(preset_combo), *row + 1); ++ if (--mom_ps < 0) mom_ps = 0; ++ if (!g_list_length(settings.presets)) mom_ps = -1; ++ preset_combo_set_item(mom_ps); + +- menuitems = GTK_MENU_SHELL(tray_menu)->children; +- g_assert(*row < g_list_length(menuitems)); +- menuitem = g_list_nth_data(menuitems, *row); +- gtk_widget_destroy(menuitem); ++ menuitems = GTK_MENU_SHELL(tray_menu)->children; ++ g_assert(*row < g_list_length(menuitems)); ++ menuitem = g_list_nth_data(menuitems, *row); ++ gtk_widget_destroy(menuitem); ++ } + + gtk_tree_path_prev(path); + gtk_tree_view_set_cursor(GTK_TREE_VIEW(list_view), path, NULL, FALSE); +@@ -420,20 +426,22 @@ static void name_cell_edited_cb(GtkCellRendererText *cellrenderertext, gchar *pa + if (ps->title) g_free(ps->title); + ps->title = g_strdup(new_val); + +- gtk_combo_box_remove_text(GTK_COMBO_BOX(preset_combo), *row + 1); +- gtk_combo_box_insert_text(GTK_COMBO_BOX(preset_combo), *row + 1, ps->title); +- mom_ps = *row; +- preset_combo_set_item(mom_ps); +- +- menuitems = GTK_MENU_SHELL(tray_menu)->children; +- g_assert(mom_ps < g_list_length(menuitems)); +- menuitem = g_list_nth_data(menuitems, mom_ps); +- gtk_widget_destroy(menuitem); +- menuitem = gtk_menu_item_new_with_label(ps->title); +- +- gtk_menu_shell_insert(GTK_MENU_SHELL(tray_menu), menuitem, *row); +- g_signal_connect(G_OBJECT(menuitem), "activate", (GCallback)preset_menuitem_activate_cb, (gpointer)mom_ps); +- gtk_widget_show(menuitem); ++ if (main_visible) { ++ gtk_combo_box_remove_text(GTK_COMBO_BOX(preset_combo), *row + 1); ++ gtk_combo_box_insert_text(GTK_COMBO_BOX(preset_combo), *row + 1, ps->title); ++ mom_ps = *row; ++ preset_combo_set_item(mom_ps); ++ ++ menuitems = GTK_MENU_SHELL(tray_menu)->children; ++ g_assert(mom_ps < g_list_length(menuitems)); ++ menuitem = g_list_nth_data(menuitems, mom_ps); ++ gtk_widget_destroy(menuitem); ++ menuitem = gtk_menu_item_new_with_label(ps->title); ++ ++ gtk_menu_shell_insert(GTK_MENU_SHELL(tray_menu), menuitem, *row); ++ g_signal_connect(G_OBJECT(menuitem), "activate", (GCallback)preset_menuitem_activate_cb, (gpointer)mom_ps); ++ gtk_widget_show(menuitem); ++ } + + gtk_tree_model_get_iter(GTK_TREE_MODEL(list_store), &iter, path); + gtk_list_store_set(GTK_LIST_STORE(list_store), &iter, 0, new_val, -1); +-- +cgit v0.8.3.1 diff --git a/media-sound/gnomeradio/files/gnomeradio-1.8-v4l2.patch b/media-sound/gnomeradio/files/gnomeradio-1.8-v4l2.patch new file mode 100644 index 000000000000..b527cdd2b3a5 --- /dev/null +++ b/media-sound/gnomeradio/files/gnomeradio-1.8-v4l2.patch @@ -0,0 +1,24 @@ +--- src/prefs.c ++++ src/prefs.c +@@ -112,7 +112,7 @@ + /* Load general settings */ + settings.device = gconf_client_get_string(client, "/apps/gnomeradio/device" , NULL); + if (!settings.device) +- settings.device = g_strdup("/dev/radio"); ++ settings.device = g_strdup("/dev/radio0"); + settings.driver = gconf_client_get_string(client, "/apps/gnomeradio/driver" , NULL); + if (!settings.driver) + settings.driver = g_strdup("any"); +--- src/radio.c ++++ src/radio.c +@@ -41,9 +41,9 @@ + } + + switch (driver) { ++ case DRIVER_ANY: + case DRIVER_V4L2: + goto try_v4l2; +- case DRIVER_ANY: + case DRIVER_V4L1: + default: + goto try_v4l1; |