im.pidgin.pidgin: 2a30e00005809366a1e544824043c204cd66c1a1

sadrul at pidgin.im sadrul at pidgin.im
Thu Nov 22 23:10:37 EST 2007


-----------------------------------------------------------------
Revision: 2a30e00005809366a1e544824043c204cd66c1a1
Ancestor: 8fa8d1ac381cffb7bd0d248780d753b7056d8a43
Author: sadrul at pidgin.im
Date: 2007-11-23T04:04:33
Branch: im.pidgin.pidgin

Modified files:
        finch/libgnt/gntwm.c

ChangeLog: 

Switch to 'normal' state when: switching windows or workspaces, closing
window or getting the action/window lists.

-------------- next part --------------
============================================================
--- finch/libgnt/gntwm.c	b97e4eaef92e5bca804e30dc4634fed47b749e1f
+++ finch/libgnt/gntwm.c	e9067557d773b963285eb7247a26f512852ad2c0
@@ -81,6 +81,7 @@ static int widestringwidth(wchar_t *wide
 static int widestringwidth(wchar_t *wide);
 #endif
 
+static void ensure_normal_mode(GntWM *wm);
 static gboolean write_already(gpointer data);
 static int write_timeout;
 static time_t last_active_time;
@@ -392,6 +393,10 @@ switch_window(GntWM *wm, int direction)
 	if (!wm->cws->ordered || !wm->cws->ordered->next)
 		return;
 
+	if (wm->mode != GNT_KP_MODE_NORMAL) {
+		ensure_normal_mode(wm);
+	}
+
 	w = wm->cws->ordered->data;
 	pos = g_list_index(wm->cws->list, w);
 	pos += direction;
@@ -503,6 +508,7 @@ window_close(GntBindable *bindable, GLis
 
 	if (wm->cws->ordered) {
 		gnt_widget_destroy(wm->cws->ordered->data);
+		ensure_normal_mode(wm);
 	}
 
 	return TRUE;
@@ -522,6 +528,7 @@ setup__list(GntWM *wm)
 setup__list(GntWM *wm)
 {
 	GntWidget *tree, *win;
+	ensure_normal_mode(wm);
 	win = wm->_list.window = gnt_box_new(FALSE, FALSE);
 	gnt_box_set_toplevel(GNT_BOX(win), TRUE);
 	gnt_box_set_pad(GNT_BOX(win), 0);
@@ -972,6 +979,16 @@ window_reverse(GntWidget *win, gboolean 
 	update_screen(wm);
 }
 
+static void
+ensure_normal_mode(GntWM *wm)
+{
+	if (wm->mode != GNT_KP_MODE_NORMAL) {
+		if (wm->cws->ordered)
+			window_reverse(wm->cws->ordered->data, FALSE, wm);
+		wm->mode = GNT_KP_MODE_NORMAL;
+	}
+}
+
 static gboolean
 start_move(GntBindable *bindable, GList *null)
 {
@@ -1453,6 +1470,7 @@ gnt_wm_switch_workspace(GntWM *wm, gint 
 	if (wm->_list.window) {
 		gnt_widget_destroy(wm->_list.window);
 	}
+	ensure_normal_mode(wm);
 	gnt_ws_hide(wm->cws, wm->nodes);
 	wm->cws = s;
 	gnt_ws_show(wm->cws, wm->nodes);


More information about the Commits mailing list