/soc/2013/ankitkv/gobjectification: 84a411b5b569: Merged soc.201...

Ankit Vani a at nevitus.org
Fri Sep 13 09:44:38 EDT 2013


Changeset: 84a411b5b5696597deeacbfe4f9b9af2d6323433
Author:	 Ankit Vani <a at nevitus.org>
Date:	 2013-09-13 19:14 +0530
Branch:	 soc.2013.gobjectification.plugins
URL: https://hg.pidgin.im/soc/2013/ankitkv/gobjectification/rev/84a411b5b569

Description:

Merged soc.2013.gobjectification branch

diffstat:

 pidgin/gtkrequest.c |  69 +++++++++++++++++++++++++++++++++++++++-------------
 pidgin/gtkutils.c   |  19 +++++++++-----
 2 files changed, 63 insertions(+), 25 deletions(-)

diffs (198 lines):

diff --git a/pidgin/gtkrequest.c b/pidgin/gtkrequest.c
--- a/pidgin/gtkrequest.c
+++ b/pidgin/gtkrequest.c
@@ -124,6 +124,9 @@ generic_response_start(PidginRequestData
 
 	/* Tell the user we're doing something. */
 	pidgin_set_cursor(GTK_WIDGET(data->dialog), GDK_WATCH);
+
+	g_object_set_data(G_OBJECT(data->dialog),
+		"pidgin-window-is-closing", GINT_TO_POINTER(TRUE));
 }
 
 static void
@@ -434,6 +437,19 @@ pidgin_request_dialog_icon(PurpleRequest
 }
 
 static void
+pidgin_request_help_clicked(GtkButton *button, gpointer _unused)
+{
+	PurpleRequestHelpCb cb;
+	gpointer data;
+
+	cb = g_object_get_data(G_OBJECT(button), "pidgin-help-cb");
+	data = g_object_get_data(G_OBJECT(button), "pidgin-help-data");
+
+	g_return_if_fail(cb != NULL);
+	cb(data);
+}
+
+static void
 pidgin_request_add_help(GtkDialog *dialog, PurpleRequestCommonParameters *cpar)
 {
 	GtkWidget *button;
@@ -446,8 +462,12 @@ pidgin_request_add_help(GtkDialog *dialo
 
 	button = gtk_dialog_add_button(dialog, GTK_STOCK_HELP,
 		GTK_RESPONSE_HELP);
-	g_signal_connect(G_OBJECT(button), "clicked", (GCallback)help_cb,
-		help_data);
+
+	g_object_set_data(G_OBJECT(button), "pidgin-help-cb", help_cb);
+	g_object_set_data(G_OBJECT(button), "pidgin-help-data", help_data);
+
+	g_signal_connect(G_OBJECT(button), "clicked",
+		G_CALLBACK(pidgin_request_help_clicked), NULL);
 }
 
 static void *
@@ -1061,9 +1081,10 @@ create_choice_field(PurpleRequestField *
 	GList *l;
 	gpointer *values = g_new(gpointer, num_labels);
 	gpointer default_value;
+	gboolean default_found = FALSE;
 	int i;
 
-	default_value = purple_request_field_choice_get_default_value(field);
+	default_value = purple_request_field_choice_get_value(field);
 	if (num_labels > 5 || purple_request_cpar_is_compact(cpar))
 	{
 		int default_index = 0;
@@ -1082,8 +1103,10 @@ create_choice_field(PurpleRequestField *
 			l = g_list_next(l);
 
 			gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(widget), text);
-			if (value == default_value)
+			if (value == default_value) {
 				default_index = i;
+				default_found = TRUE;
+			}
 			values[i++] = value;
 		}
 
@@ -1128,8 +1151,10 @@ create_choice_field(PurpleRequestField *
 			if (first_radio == NULL)
 				first_radio = radio;
 
-			if (value == default_value)
+			if (value == default_value) {
 				gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(radio), TRUE);
+				default_found = TRUE;
+			}
 			values[i++] = value;
 
 			gtk_box_pack_start(GTK_BOX(box), radio, TRUE, TRUE, 0);
@@ -1140,6 +1165,9 @@ create_choice_field(PurpleRequestField *
 		}
 	}
 
+	if (!default_found && i > 0)
+		purple_request_field_choice_set_value(field, values[0]);
+
 	g_object_set_data_full(G_OBJECT(widget), "values", values, g_free);
 
 	return widget;
@@ -1890,26 +1918,34 @@ pidgin_request_folder(const char *title,
 	return (void *)data;
 }
 
-#ifdef _WIN32
-
-/* Not needed (yet) for non-win32, but should work everywhere. */
+/* if request callback issues another request, it should be attached to the
+ * primary request parent */
 static void
-pidgin_window_detach_children(GtkWindow* parent)
+pidgin_window_detach_children(GtkWindow* win)
 {
 	GList *it;
+	GtkWindow *par;
 
-	g_return_if_fail(parent != NULL);
+	g_return_if_fail(win != NULL);
 
+	par = gtk_window_get_transient_for(win);
 	it = gtk_window_list_toplevels();
 	for (it = g_list_first(it); it != NULL; it = g_list_next(it)) {
-		GtkWindow *win = GTK_WINDOW(it->data);
-		if (gtk_window_get_transient_for(win) == parent)
-			gtk_window_set_transient_for(win, NULL);
+		GtkWindow *child = GTK_WINDOW(it->data);
+		if (gtk_window_get_transient_for(child) != win)
+			continue;
+		if (gtk_window_get_destroy_with_parent(child)) {
+#ifdef _WIN32
+			/* XXX test/verify it: Win32 gtk ignores
+			 * gtk_window_set_destroy_with_parent(..., FALSE). */
+			gtk_window_set_transient_for(child, NULL);
+#endif
+			continue;
+		}
+		gtk_window_set_transient_for(child, par);
 	}
 }
 
-#endif
-
 static void
 pidgin_close_request(PurpleRequestType type, void *ui_handle)
 {
@@ -1917,10 +1953,7 @@ pidgin_close_request(PurpleRequestType t
 
 	g_free(data->cbs);
 
-#ifdef _WIN32
-	/* Win32 gtk ignores gtk_window_set_destroy_with_parent(..., FALSE). */
 	pidgin_window_detach_children(GTK_WINDOW(data->dialog));
-#endif
 
 	gtk_widget_destroy(data->dialog);
 
diff --git a/pidgin/gtkutils.c b/pidgin/gtkutils.c
--- a/pidgin/gtkutils.c
+++ b/pidgin/gtkutils.c
@@ -2922,7 +2922,7 @@ gboolean pidgin_auto_parent_window(GtkWi
 #else
 	/* This finds the currently active window and makes that the parent window. */
 	GList *windows = NULL;
-	GtkWidget *parent = NULL;
+	GtkWindow *parent = NULL;
 	GdkEvent *event = gtk_get_current_event();
 	GdkWindow *menu = NULL;
 
@@ -2942,24 +2942,29 @@ gboolean pidgin_auto_parent_window(GtkWi
 
 	windows = gtk_window_list_toplevels();
 	while (windows) {
-		GtkWidget *window = windows->data;
+		GtkWindow *window = GTK_WINDOW(windows->data);
 		windows = g_list_delete_link(windows, windows);
 
-		if (window == widget ||
-				!gtk_widget_get_visible(window)) {
+		if (GTK_WIDGET(window) == widget ||
+				!gtk_widget_get_visible(GTK_WIDGET(window))) {
 			continue;
 		}
 
-		if (gtk_window_has_toplevel_focus(GTK_WINDOW(window)) ||
-				(menu && menu == gtk_widget_get_window(window))) {
+		if (gtk_window_has_toplevel_focus(window) ||
+				(menu && menu == gtk_widget_get_window(GTK_WIDGET(window)))) {
 			parent = window;
 			break;
 		}
 	}
 	if (windows)
 		g_list_free(windows);
+	if (GPOINTER_TO_INT(g_object_get_data(G_OBJECT(parent),
+		"pidgin-window-is-closing")))
+	{
+		parent = gtk_window_get_transient_for(parent);
+	}
 	if (parent) {
-		gtk_window_set_transient_for(GTK_WINDOW(widget), GTK_WINDOW(parent));
+		gtk_window_set_transient_for(GTK_WINDOW(widget), parent);
 		return TRUE;
 	}
 	return FALSE;



More information about the Commits mailing list