summaryrefslogtreecommitdiff
path: root/bspwm/change_update_order.patch
blob: f27dce926681ba49e57b4ab76fb89b492b50cba0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
diff --git a/src/ewmh.c b/src/ewmh.c
index 52f7e53..bdda6a7 100644
--- a/src/ewmh.c
+++ b/src/ewmh.c
@@ -93,7 +93,12 @@ void ewmh_update_current_desktop(void)
 	if (mon == NULL) {
 		return;
 	}
-	uint32_t i = ewmh_get_desktop_index(mon->desk);
+	ewmh_set_current_desktop(mon->desk);
+}
+
+void ewmh_set_current_desktop(desktop_t *d)
+{
+	uint32_t i = ewmh_get_desktop_index(d);
 	xcb_ewmh_set_current_desktop(ewmh, default_screen, i);
 }
 
diff --git a/src/ewmh.h b/src/ewmh.h
index 3b50e35..0781eb6 100644
--- a/src/ewmh.h
+++ b/src/ewmh.h
@@ -35,6 +35,7 @@ void ewmh_update_number_of_desktops(void);
 uint32_t ewmh_get_desktop_index(desktop_t *d);
 bool ewmh_locate_desktop(uint32_t i, coordinates_t *loc);
 void ewmh_update_current_desktop(void);
+void ewmh_set_current_desktop(desktop_t *d);
 void ewmh_set_wm_desktop(node_t *n, desktop_t *d);
 void ewmh_update_wm_desktops(void);
 void ewmh_update_desktop_names(void);
diff --git a/src/tree.c b/src/tree.c
index 52055c5..3762335 100644
--- a/src/tree.c
+++ b/src/tree.c
@@ -643,14 +643,18 @@ bool focus_node(monitor_t *m, desktop_t *d, node_t *n)
 	}
 
 	if (m->desk != d) {
+		ewmh_set_current_desktop(d);
+		put_status(SBSC_MASK_DESKTOP_FOCUS, "desktop_focus 0x%08X 0x%08X\n", m->id, d->id);
+
 		show_desktop(d);
 		set_input_focus(n);
 		has_input_focus = true;
 		hide_desktop(m->desk);
 		m->desk = d;
+
 	}
 
-	if (desk_changed) {
+	if (m != mon) {
 		ewmh_update_current_desktop();
 		put_status(SBSC_MASK_DESKTOP_FOCUS, "desktop_focus 0x%08X 0x%08X\n", m->id, d->id);
 	}