Merge lp:~attente/gtk/refresh-mir-backend into lp:~ubuntu-desktop/gtk/ubuntugtk3
- refresh-mir-backend
- Merge into ubuntugtk3
Proposed by
William Hua
Status: | Merged |
---|---|
Merged at revision: | 392 |
Proposed branch: | lp:~attente/gtk/refresh-mir-backend |
Merge into: | lp:~ubuntu-desktop/gtk/ubuntugtk3 |
Diff against target: |
1516 lines (+1041/-130) 4 files modified
debian/changelog (+7/-1) debian/patches/mir-backend-unmerged.patch (+686/-0) debian/patches/mir-backend.patch (+347/-129) debian/patches/series (+1/-0) |
To merge this branch: | bzr merge lp:~attente/gtk/refresh-mir-backend |
Related bugs: |
Reviewer | Review Type | Date Requested | Status |
---|---|---|---|
Ubuntu Desktop | Pending | ||
Review via email: mp+244491@code.launchpad.net |
Commit message
Refresh mir backend.
Description of the change
Refresh mir backend.
To post a comment you must log in.
Preview Diff
[H/L] Next/Prev Comment, [J/K] Next/Prev File, [N/P] Next/Prev Hunk
1 | === modified file 'debian/changelog' | |||
2 | --- debian/changelog 2014-12-11 12:58:39 +0000 | |||
3 | +++ debian/changelog 2014-12-13 16:59:39 +0000 | |||
4 | @@ -65,7 +65,13 @@ | |||
5 | 65 | - Add back changes from 3.12.2-0ubuntu14 | 65 | - Add back changes from 3.12.2-0ubuntu14 |
6 | 66 | - Fix touch events not generating GDK events (LP: #1388875) | 66 | - Fix touch events not generating GDK events (LP: #1388875) |
7 | 67 | 67 | ||
9 | 68 | -- Lars Uebernickel <lars.uebernickel@ubuntu.com> Mon, 20 Oct 2014 13:44:53 -0400 | 68 | [ William Hua ] |
10 | 69 | * debian/patches/mir-backend.patch: | ||
11 | 70 | - Backport more mir patches from master | ||
12 | 71 | * debian/patches/mir-backend-unmerged.patch: | ||
13 | 72 | - Backport unmerged mir patches from wip/mir2 | ||
14 | 73 | |||
15 | 74 | -- William Hua <william.hua@canonical.com> Thu, 11 Dec 2014 12:43:44 -0500 | ||
16 | 69 | 75 | ||
17 | 70 | gtk+3.0 (3.14.5-1) unstable; urgency=medium | 76 | gtk+3.0 (3.14.5-1) unstable; urgency=medium |
18 | 71 | 77 | ||
19 | 72 | 78 | ||
20 | === added file 'debian/patches/mir-backend-unmerged.patch' | |||
21 | --- debian/patches/mir-backend-unmerged.patch 1970-01-01 00:00:00 +0000 | |||
22 | +++ debian/patches/mir-backend-unmerged.patch 2014-12-13 16:59:39 +0000 | |||
23 | @@ -0,0 +1,686 @@ | |||
24 | 1 | From 447c406a112e5dd6cc3b49f17bfa779d24e2ef3a Mon Sep 17 00:00:00 2001 | ||
25 | 2 | From: William Hua <william@attente.ca> | ||
26 | 3 | Date: Fri, 28 Nov 2014 08:33:03 -0500 | ||
27 | 4 | Subject: [PATCH 2/2] mir: unmerged commits from wip/mir2 branch | ||
28 | 5 | |||
29 | 6 | Backported from: | ||
30 | 7 | ce596da0d8eee33016bae8bda3d621860b45bccb | ||
31 | 8 | af8cf6945cea6b4257b7ca8b589efc69a8f48129 | ||
32 | 9 | d8fc26da795d2b1730291879eac961441764c80a | ||
33 | 10 | 13eb820d7f37a7a4b7e9eb00dd897acfbe116c3c | ||
34 | 11 | 73002dca915da3834c6ccf4af422f9fb443637de | ||
35 | 12 | c9c85e1d9f87120c2f43764c78263d216fe04585 | ||
36 | 13 | 6db489dc399bfb1fb0fc206d0bd206ac3468c3c7 | ||
37 | 14 | 731b01de1f18354be1da21eeaf6ed8066b622a74 | ||
38 | 15 | 92dd2b7cb0a53f9d4480472d1a3756bcfae778c8 | ||
39 | 16 | 292229fa415133cc6801121eedc460caee287618 | ||
40 | 17 | d2a0e3d013d5521f790aaf81cf68ff531adc7e3d | ||
41 | 18 | 7d3257af05e364a7efa250a692e8e0dd2af6280a | ||
42 | 19 | f060bfbc338d109cc12f143761bf9d8d235171e7 | ||
43 | 20 | 310faf6c914967c58fa944577cd2238658e9f22a | ||
44 | 21 | 62f25bef0f30350faf152b0d885ce01ad341ea70 | ||
45 | 22 | 52504167c1aeda2b76c24ad701d44a79968f715c | ||
46 | 23 | ada2ed8eca7f3e116a0e171dcbf6c13eda28c9c4 | ||
47 | 24 | cc0f748f4d883103b50cfa09acda5c239f1a80d1 | ||
48 | 25 | 84119c20f297e4d02f4667a3d4d921e785fd77e9 | ||
49 | 26 | d4d6d519bc88c79bfca6902f8f9f17a2392ae4ba | ||
50 | 27 | b9890b3d9ee8a8d3cbb31db6d4446910987f63ec | ||
51 | 28 | --- | ||
52 | 29 | gdk/mir/gdkmir-private.h | 9 ++++ | ||
53 | 30 | gdk/mir/gdkmirdisplay.c | 17 +++++-- | ||
54 | 31 | gdk/mir/gdkmireventsource.c | 109 ++++++++++++++++++++++++++++++-------------- | ||
55 | 32 | gdk/mir/gdkmirkeymap.c | 14 ++++++ | ||
56 | 33 | gdk/mir/gdkmirpointer.c | 6 +++ | ||
57 | 34 | gdk/mir/gdkmirscreen.c | 22 ++++----- | ||
58 | 35 | gdk/mir/gdkmirwindowimpl.c | 86 ++++++++++++++++++++++++++-------- | ||
59 | 36 | 7 files changed, 195 insertions(+), 68 deletions(-) | ||
60 | 37 | |||
61 | 38 | diff --git a/gdk/mir/gdkmir-private.h b/gdk/mir/gdkmir-private.h | ||
62 | 39 | index 8305096..a5802f7 100644 | ||
63 | 40 | --- a/gdk/mir/gdkmir-private.h | ||
64 | 41 | +++ b/gdk/mir/gdkmir-private.h | ||
65 | 42 | @@ -45,6 +45,8 @@ GdkDevice *_gdk_mir_device_manager_get_keyboard (GdkDeviceManager *device_manage | ||
66 | 43 | |||
67 | 44 | GdkKeymap *_gdk_mir_keymap_new (void); | ||
68 | 45 | |||
69 | 46 | +gboolean _gdk_mir_keymap_key_is_modifier (GdkKeymap *keymap, guint keycode); | ||
70 | 47 | + | ||
71 | 48 | GdkDevice *_gdk_mir_keyboard_new (GdkDeviceManager *device_manager, const gchar *name); | ||
72 | 49 | |||
73 | 50 | GdkDevice *_gdk_mir_pointer_new (GdkDeviceManager *device_manager, const gchar *name); | ||
74 | 51 | @@ -89,4 +91,11 @@ void _gdk_mir_print_resize_event (const MirResizeEvent *event); | ||
75 | 52 | |||
76 | 53 | void _gdk_mir_print_event (const MirEvent *event); | ||
77 | 54 | |||
78 | 55 | +/* TODO: Remove once we have proper transient window support. */ | ||
79 | 56 | +GdkWindow * _gdk_mir_window_get_visible_transient_child (GdkWindow *window, | ||
80 | 57 | + gint x, | ||
81 | 58 | + gint y, | ||
82 | 59 | + gint *out_x, | ||
83 | 60 | + gint *out_y); | ||
84 | 61 | + | ||
85 | 62 | #endif /* __GDK_PRIVATE_MIR_H__ */ | ||
86 | 63 | diff --git a/gdk/mir/gdkmirdisplay.c b/gdk/mir/gdkmirdisplay.c | ||
87 | 64 | index 207342c..13793ec 100644 | ||
88 | 65 | --- a/gdk/mir/gdkmirdisplay.c | ||
89 | 66 | +++ b/gdk/mir/gdkmirdisplay.c | ||
90 | 67 | @@ -391,9 +391,20 @@ gdk_mir_display_create_window_impl (GdkDisplay *display, | ||
91 | 68 | g_printerr (" location=(%d, %d)", window->x, window->y); | ||
92 | 69 | g_printerr (" size=(%d, %d)", window->width, window->height); | ||
93 | 70 | g_printerr ("\n"); | ||
94 | 71 | - if (attributes->wclass != GDK_INPUT_OUTPUT) | ||
95 | 72 | - return; | ||
96 | 73 | - window->impl = _gdk_mir_window_impl_new (); | ||
97 | 74 | + | ||
98 | 75 | + if (attributes->wclass == GDK_INPUT_OUTPUT) | ||
99 | 76 | + { | ||
100 | 77 | + window->impl = _gdk_mir_window_impl_new (); | ||
101 | 78 | + window->impl_window = window; | ||
102 | 79 | + } | ||
103 | 80 | + else /* attributes->wclass == GDK_INPUT_ONLY */ | ||
104 | 81 | + { | ||
105 | 82 | + window->impl = g_object_ref (real_parent->impl); | ||
106 | 83 | + window->impl_window = real_parent; | ||
107 | 84 | + | ||
108 | 85 | + /* FIXME: this is called in gdk_window_new, which sets window->impl_window | ||
109 | 86 | + * back to window after this function returns. */ | ||
110 | 87 | + } | ||
111 | 88 | } | ||
112 | 89 | |||
113 | 90 | static GdkKeymap * | ||
114 | 91 | diff --git a/gdk/mir/gdkmireventsource.c b/gdk/mir/gdkmireventsource.c | ||
115 | 92 | index cfe36e8..18364b0 100644 | ||
116 | 93 | --- a/gdk/mir/gdkmireventsource.c | ||
117 | 94 | +++ b/gdk/mir/gdkmireventsource.c | ||
118 | 95 | @@ -22,6 +22,8 @@ | ||
119 | 96 | #include "gdkmir.h" | ||
120 | 97 | #include "gdkmir-private.h" | ||
121 | 98 | |||
122 | 99 | +#define NANO_TO_MILLI(x) ((x) / 1000000) | ||
123 | 100 | + | ||
124 | 101 | struct _GdkMirWindowReference { | ||
125 | 102 | GdkMirEventSource *source; | ||
126 | 103 | GdkWindow *window; | ||
127 | 104 | @@ -39,6 +41,7 @@ struct _GdkMirEventSource | ||
128 | 105 | |||
129 | 106 | GMutex mir_event_lock; | ||
130 | 107 | GQueue mir_events; | ||
131 | 108 | + gboolean log_events; | ||
132 | 109 | |||
133 | 110 | GdkDisplay *display; | ||
134 | 111 | }; | ||
135 | 112 | @@ -50,6 +53,7 @@ send_event (GdkWindow *window, GdkDevice *device, GdkEvent *event) | ||
136 | 113 | GList *node; | ||
137 | 114 | |||
138 | 115 | gdk_event_set_device (event, device); | ||
139 | 116 | + gdk_event_set_source_device (event, device); | ||
140 | 117 | gdk_event_set_screen (event, gdk_display_get_screen (gdk_window_get_display (window), 0)); | ||
141 | 118 | event->any.window = g_object_ref (window); | ||
142 | 119 | |||
143 | 120 | @@ -118,7 +122,7 @@ set_key_event_string (GdkEventKey *event) | ||
144 | 121 | } | ||
145 | 122 | |||
146 | 123 | static void | ||
147 | 124 | -generate_key_event (GdkWindow *window, GdkEventType type, guint state, guint keyval, guint16 keycode, gboolean is_modifier) | ||
148 | 125 | +generate_key_event (GdkWindow *window, GdkEventType type, guint state, guint keyval, guint16 keycode, gboolean is_modifier, guint32 event_time) | ||
149 | 126 | { | ||
150 | 127 | GdkEvent *event; | ||
151 | 128 | |||
152 | 129 | @@ -127,6 +131,7 @@ generate_key_event (GdkWindow *window, GdkEventType type, guint state, guint key | ||
153 | 130 | event->key.keyval = keyval; | ||
154 | 131 | event->key.hardware_keycode = keycode + 8; | ||
155 | 132 | event->key.is_modifier = is_modifier; | ||
156 | 133 | + event->key.time = event_time; | ||
157 | 134 | set_key_event_string (&event->key); | ||
158 | 135 | |||
159 | 136 | send_event (window, _gdk_mir_device_manager_get_keyboard (gdk_display_get_device_manager (gdk_window_get_display (window))), event); | ||
160 | 137 | @@ -139,7 +144,7 @@ get_pointer (GdkWindow *window) | ||
161 | 138 | } | ||
162 | 139 | |||
163 | 140 | static void | ||
164 | 141 | -generate_button_event (GdkWindow *window, GdkEventType type, gdouble x, gdouble y, guint button, guint state) | ||
165 | 142 | +generate_button_event (GdkWindow *window, GdkEventType type, gdouble x, gdouble y, guint button, guint state, guint32 event_time) | ||
166 | 143 | { | ||
167 | 144 | GdkEvent *event; | ||
168 | 145 | |||
169 | 146 | @@ -148,12 +153,13 @@ generate_button_event (GdkWindow *window, GdkEventType type, gdouble x, gdouble | ||
170 | 147 | event->button.y = y; | ||
171 | 148 | event->button.state = state; | ||
172 | 149 | event->button.button = button; | ||
173 | 150 | + event->button.time = event_time; | ||
174 | 151 | |||
175 | 152 | send_event (window, get_pointer (window), event); | ||
176 | 153 | } | ||
177 | 154 | |||
178 | 155 | static void | ||
179 | 156 | -generate_scroll_event (GdkWindow *window, gdouble x, gdouble y, gdouble delta_x, gdouble delta_y, guint state) | ||
180 | 157 | +generate_scroll_event (GdkWindow *window, gdouble x, gdouble y, gdouble delta_x, gdouble delta_y, guint state, guint32 event_time) | ||
181 | 158 | { | ||
182 | 159 | GdkEvent *event; | ||
183 | 160 | |||
184 | 161 | @@ -161,15 +167,28 @@ generate_scroll_event (GdkWindow *window, gdouble x, gdouble y, gdouble delta_x, | ||
185 | 162 | event->scroll.x = x; | ||
186 | 163 | event->scroll.y = y; | ||
187 | 164 | event->scroll.state = state; | ||
188 | 165 | - event->scroll.direction = GDK_SCROLL_SMOOTH; | ||
189 | 166 | - event->scroll.delta_x = -delta_x; | ||
190 | 167 | - event->scroll.delta_y = -delta_y; | ||
191 | 168 | + event->scroll.time = event_time; | ||
192 | 169 | + | ||
193 | 170 | + if (ABS (delta_x) == 1 && delta_y == 0) | ||
194 | 171 | + { | ||
195 | 172 | + event->scroll.direction = (delta_x < 0) ? GDK_SCROLL_LEFT : GDK_SCROLL_RIGHT; | ||
196 | 173 | + } | ||
197 | 174 | + else if (ABS (delta_y) == 1 && delta_x == 0) | ||
198 | 175 | + { | ||
199 | 176 | + event->scroll.direction = (delta_y < 0) ? GDK_SCROLL_DOWN : GDK_SCROLL_UP; | ||
200 | 177 | + } | ||
201 | 178 | + else | ||
202 | 179 | + { | ||
203 | 180 | + event->scroll.direction = GDK_SCROLL_SMOOTH; | ||
204 | 181 | + event->scroll.delta_x = -delta_x; | ||
205 | 182 | + event->scroll.delta_y = -delta_y; | ||
206 | 183 | + } | ||
207 | 184 | |||
208 | 185 | send_event (window, get_pointer (window), event); | ||
209 | 186 | } | ||
210 | 187 | |||
211 | 188 | static void | ||
212 | 189 | -generate_motion_event (GdkWindow *window, gdouble x, gdouble y, guint state) | ||
213 | 190 | +generate_motion_event (GdkWindow *window, gdouble x, gdouble y, guint state, guint32 event_time) | ||
214 | 191 | { | ||
215 | 192 | GdkEvent *event; | ||
216 | 193 | |||
217 | 194 | @@ -178,12 +197,13 @@ generate_motion_event (GdkWindow *window, gdouble x, gdouble y, guint state) | ||
218 | 195 | event->motion.y = y; | ||
219 | 196 | event->motion.state = state; | ||
220 | 197 | event->motion.is_hint = FALSE; | ||
221 | 198 | + event->motion.time = event_time; | ||
222 | 199 | |||
223 | 200 | send_event (window, get_pointer (window), event); | ||
224 | 201 | } | ||
225 | 202 | |||
226 | 203 | static void | ||
227 | 204 | -generate_crossing_event (GdkWindow *window, GdkEventType type, gdouble x, gdouble y) | ||
228 | 205 | +generate_crossing_event (GdkWindow *window, GdkEventType type, gdouble x, gdouble y, guint32 event_time) | ||
229 | 206 | { | ||
230 | 207 | GdkEvent *event; | ||
231 | 208 | |||
232 | 209 | @@ -193,6 +213,7 @@ generate_crossing_event (GdkWindow *window, GdkEventType type, gdouble x, gdoubl | ||
233 | 210 | event->crossing.mode = GDK_CROSSING_NORMAL; | ||
234 | 211 | event->crossing.detail = GDK_NOTIFY_ANCESTOR; | ||
235 | 212 | event->crossing.focus = TRUE; | ||
236 | 213 | + event->crossing.time = event_time; | ||
237 | 214 | |||
238 | 215 | send_event (window, get_pointer (window), event); | ||
239 | 216 | } | ||
240 | 217 | @@ -239,35 +260,30 @@ get_modifier_state (unsigned int modifiers, unsigned int button_state) | ||
241 | 218 | return modifier_state; | ||
242 | 219 | } | ||
243 | 220 | |||
244 | 221 | -/* | ||
245 | 222 | - GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (event_data->window->impl); | ||
246 | 223 | - MirMotionButton changed_button_state; | ||
247 | 224 | - GdkEventType event_type; | ||
248 | 225 | - gdouble x, y; | ||
249 | 226 | - guint modifier_state; | ||
250 | 227 | - gboolean is_modifier = FALSE; | ||
251 | 228 | -*/ | ||
252 | 229 | - | ||
253 | 230 | static void | ||
254 | 231 | handle_key_event (GdkWindow *window, const MirKeyEvent *event) | ||
255 | 232 | { | ||
256 | 233 | + GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (window->impl); | ||
257 | 234 | + GdkKeymap *keymap; | ||
258 | 235 | guint modifier_state; | ||
259 | 236 | - gboolean is_modifier = FALSE; | ||
260 | 237 | - | ||
261 | 238 | - modifier_state = get_modifier_state (event->modifiers, 0); // FIXME: Need to track button state | ||
262 | 239 | + MirMotionButton button_state; | ||
263 | 240 | |||
264 | 241 | switch (event->action) | ||
265 | 242 | { | ||
266 | 243 | case mir_key_action_down: | ||
267 | 244 | case mir_key_action_up: | ||
268 | 245 | // FIXME: Convert keycode | ||
269 | 246 | - // FIXME: is_modifier | ||
270 | 247 | + _gdk_mir_window_impl_get_cursor_state (impl, NULL, NULL, NULL, &button_state); | ||
271 | 248 | + modifier_state = get_modifier_state (event->modifiers, button_state); | ||
272 | 249 | + keymap = gdk_keymap_get_for_display (gdk_window_get_display (window)); | ||
273 | 250 | + | ||
274 | 251 | generate_key_event (window, | ||
275 | 252 | event->action == mir_key_action_down ? GDK_KEY_PRESS : GDK_KEY_RELEASE, | ||
276 | 253 | modifier_state, | ||
277 | 254 | event->key_code, | ||
278 | 255 | event->scan_code, | ||
279 | 256 | - is_modifier); | ||
280 | 257 | + _gdk_mir_keymap_key_is_modifier (keymap, event->key_code), | ||
281 | 258 | + NANO_TO_MILLI (event->event_time)); | ||
282 | 259 | break; | ||
283 | 260 | default: | ||
284 | 261 | //case mir_key_action_multiple: | ||
285 | 262 | @@ -284,6 +300,7 @@ handle_motion_event (GdkWindow *window, const MirMotionEvent *event) | ||
286 | 263 | gboolean cursor_inside; | ||
287 | 264 | MirMotionButton button_state; | ||
288 | 265 | guint modifier_state; | ||
289 | 266 | + guint32 event_time; | ||
290 | 267 | GdkEventType event_type; | ||
291 | 268 | MirMotionButton changed_button_state; | ||
292 | 269 | |||
293 | 270 | @@ -294,13 +311,14 @@ handle_motion_event (GdkWindow *window, const MirMotionEvent *event) | ||
294 | 271 | y = event->pointer_coordinates[0].y; | ||
295 | 272 | } | ||
296 | 273 | modifier_state = get_modifier_state (event->modifiers, event->button_state); | ||
297 | 274 | + event_time = NANO_TO_MILLI (event->event_time); | ||
298 | 275 | |||
299 | 276 | /* The Mir events generate hover-exits even while inside the window so | ||
300 | 277 | counteract this by always generating an enter notify on all other events */ | ||
301 | 278 | if (!cursor_inside && event->action != mir_motion_action_hover_exit) | ||
302 | 279 | { | ||
303 | 280 | cursor_inside = TRUE; | ||
304 | 281 | - generate_crossing_event (window, GDK_ENTER_NOTIFY, x, y); | ||
305 | 282 | + generate_crossing_event (window, GDK_ENTER_NOTIFY, x, y, event_time); | ||
306 | 283 | } | ||
307 | 284 | |||
308 | 285 | /* Update which window has focus */ | ||
309 | 286 | @@ -312,23 +330,23 @@ handle_motion_event (GdkWindow *window, const MirMotionEvent *event) | ||
310 | 287 | event_type = event->action == mir_motion_action_down ? GDK_BUTTON_PRESS : GDK_BUTTON_RELEASE; | ||
311 | 288 | changed_button_state = button_state ^ event->button_state; | ||
312 | 289 | if (changed_button_state == 0 || (changed_button_state & mir_motion_button_primary) != 0) | ||
313 | 290 | - generate_button_event (window, event_type, x, y, GDK_BUTTON_PRIMARY, modifier_state); | ||
314 | 291 | + generate_button_event (window, event_type, x, y, GDK_BUTTON_PRIMARY, modifier_state, event_time); | ||
315 | 292 | if ((changed_button_state & mir_motion_button_secondary) != 0) | ||
316 | 293 | - generate_button_event (window, event_type, x, y, GDK_BUTTON_SECONDARY, modifier_state); | ||
317 | 294 | + generate_button_event (window, event_type, x, y, GDK_BUTTON_SECONDARY, modifier_state, event_time); | ||
318 | 295 | if ((changed_button_state & mir_motion_button_tertiary) != 0) | ||
319 | 296 | - generate_button_event (window, event_type, x, y, GDK_BUTTON_MIDDLE, modifier_state); | ||
320 | 297 | + generate_button_event (window, event_type, x, y, GDK_BUTTON_MIDDLE, modifier_state, event_time); | ||
321 | 298 | button_state = event->button_state; | ||
322 | 299 | break; | ||
323 | 300 | case mir_motion_action_scroll: | ||
324 | 301 | - generate_scroll_event (window, x, y, event->pointer_coordinates[0].hscroll, event->pointer_coordinates[0].vscroll, modifier_state); | ||
325 | 302 | + generate_scroll_event (window, x, y, event->pointer_coordinates[0].hscroll, event->pointer_coordinates[0].vscroll, modifier_state, event_time); | ||
326 | 303 | break; | ||
327 | 304 | case mir_motion_action_move: // move with button | ||
328 | 305 | case mir_motion_action_hover_move: // move without button | ||
329 | 306 | - generate_motion_event (window, x, y, modifier_state); | ||
330 | 307 | + generate_motion_event (window, x, y, modifier_state, event_time); | ||
331 | 308 | break; | ||
332 | 309 | case mir_motion_action_hover_exit: | ||
333 | 310 | cursor_inside = FALSE; | ||
334 | 311 | - generate_crossing_event (window, GDK_LEAVE_NOTIFY, x, y); | ||
335 | 312 | + generate_crossing_event (window, GDK_LEAVE_NOTIFY, x, y, event_time); | ||
336 | 313 | break; | ||
337 | 314 | } | ||
338 | 315 | |||
339 | 316 | @@ -396,9 +414,6 @@ gdk_mir_event_source_queue_event (GdkDisplay *display, | ||
340 | 317 | GdkWindow *window, | ||
341 | 318 | const MirEvent *event) | ||
342 | 319 | { | ||
343 | 320 | - if (g_getenv ("GDK_MIR_LOG_EVENTS")) | ||
344 | 321 | - _gdk_mir_print_event (event); | ||
345 | 322 | - | ||
346 | 323 | // FIXME: Only generate events if the window wanted them? | ||
347 | 324 | switch (event->type) | ||
348 | 325 | { | ||
349 | 326 | @@ -459,7 +474,34 @@ gdk_mir_event_source_convert_events (GdkMirEventSource *source) | ||
350 | 327 | * event was being dispatched... | ||
351 | 328 | */ | ||
352 | 329 | if (window != NULL) | ||
353 | 330 | - gdk_mir_event_source_queue_event (source->display, window, &event->event); | ||
354 | 331 | + { | ||
355 | 332 | + /* TODO: Remove once we have proper transient window support. */ | ||
356 | 333 | + if (event->event.type == mir_event_type_motion) | ||
357 | 334 | + { | ||
358 | 335 | + GdkWindow *child; | ||
359 | 336 | + gint x; | ||
360 | 337 | + gint y; | ||
361 | 338 | + | ||
362 | 339 | + x = event->event.motion.pointer_coordinates[0].x; | ||
363 | 340 | + y = event->event.motion.pointer_coordinates[0].y; | ||
364 | 341 | + | ||
365 | 342 | + child = _gdk_mir_window_get_visible_transient_child (window, x, y, &x, &y); | ||
366 | 343 | + | ||
367 | 344 | + if (child && child != window) | ||
368 | 345 | + { | ||
369 | 346 | + window = child; | ||
370 | 347 | + | ||
371 | 348 | + event->event.motion.pointer_count = MAX (event->event.motion.pointer_count, 1); | ||
372 | 349 | + event->event.motion.pointer_coordinates[0].x = x; | ||
373 | 350 | + event->event.motion.pointer_coordinates[0].y = y; | ||
374 | 351 | + } | ||
375 | 352 | + } | ||
376 | 353 | + | ||
377 | 354 | + if (source->log_events) | ||
378 | 355 | + _gdk_mir_print_event (&event->event); | ||
379 | 356 | + | ||
380 | 357 | + gdk_mir_event_source_queue_event (source->display, window, &event->event); | ||
381 | 358 | + } | ||
382 | 359 | else | ||
383 | 360 | g_warning ("window was destroyed before event arrived..."); | ||
384 | 361 | |||
385 | 362 | @@ -554,6 +596,7 @@ _gdk_mir_event_source_new (GdkDisplay *display) | ||
386 | 363 | source = (GdkMirEventSource *) g_source; | ||
387 | 364 | g_mutex_init (&source->mir_event_lock); | ||
388 | 365 | source->display = display; | ||
389 | 366 | + source->log_events = (g_getenv ("GDK_MIR_LOG_EVENTS") != NULL); | ||
390 | 367 | |||
391 | 368 | return source; | ||
392 | 369 | } | ||
393 | 370 | diff --git a/gdk/mir/gdkmirkeymap.c b/gdk/mir/gdkmirkeymap.c | ||
394 | 371 | index 3e8c829..82f0d2c 100644 | ||
395 | 372 | --- a/gdk/mir/gdkmirkeymap.c | ||
396 | 373 | +++ b/gdk/mir/gdkmirkeymap.c | ||
397 | 374 | @@ -31,6 +31,12 @@ typedef struct GdkMirKeymapClass GdkMirKeymapClass; | ||
398 | 375 | #define GDK_IS_MIR_KEYMAP_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_MIR_KEYMAP)) | ||
399 | 376 | #define GDK_MIR_KEYMAP_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_MIR_KEYMAP, GdkMirKeymapClass)) | ||
400 | 377 | |||
401 | 378 | +#define IsModifierKey(keysym) \ | ||
402 | 379 | + (((keysym) >= XKB_KEY_Shift_L && (keysym) <= XKB_KEY_Hyper_R) || \ | ||
403 | 380 | + ((keysym) >= XKB_KEY_ISO_Lock && (keysym) <= XKB_KEY_ISO_Last_Group_Lock) || \ | ||
404 | 381 | + ((keysym) == XKB_KEY_Mode_switch) || \ | ||
405 | 382 | + ((keysym) == XKB_KEY_Num_Lock)) | ||
406 | 383 | + | ||
407 | 384 | struct GdkMirKeymap | ||
408 | 385 | { | ||
409 | 386 | GdkKeymap parent_instance; | ||
410 | 387 | @@ -342,6 +348,14 @@ gdk_mir_keymap_get_modifier_state (GdkKeymap *keymap) | ||
411 | 388 | return get_gdk_modifiers (mir_keymap->xkb_keymap, mods); | ||
412 | 389 | } | ||
413 | 390 | |||
414 | 391 | +gboolean | ||
415 | 392 | +_gdk_mir_keymap_key_is_modifier (GdkKeymap *keymap, | ||
416 | 393 | + guint keycode) | ||
417 | 394 | +{ | ||
418 | 395 | + // FIXME: use xkb_state | ||
419 | 396 | + return IsModifierKey (keycode); | ||
420 | 397 | +} | ||
421 | 398 | + | ||
422 | 399 | static void | ||
423 | 400 | update_direction (GdkMirKeymap *keymap) | ||
424 | 401 | { | ||
425 | 402 | diff --git a/gdk/mir/gdkmirpointer.c b/gdk/mir/gdkmirpointer.c | ||
426 | 403 | index 96c7e74..3937361 100644 | ||
427 | 404 | --- a/gdk/mir/gdkmirpointer.c | ||
428 | 405 | +++ b/gdk/mir/gdkmirpointer.c | ||
429 | 406 | @@ -17,6 +17,7 @@ | ||
430 | 407 | |||
431 | 408 | #include "config.h" | ||
432 | 409 | |||
433 | 410 | +#include "gdkdisplayprivate.h" | ||
434 | 411 | #include "gdkdeviceprivate.h" | ||
435 | 412 | #include "gdkscreen.h" | ||
436 | 413 | #include "gdkwindow.h" | ||
437 | 414 | @@ -183,6 +184,11 @@ gdk_mir_pointer_ungrab (GdkDevice *device, | ||
438 | 415 | { | ||
439 | 416 | //g_printerr ("gdk_mir_pointer_ungrab\n"); | ||
440 | 417 | /* Mir doesn't do grabs */ | ||
441 | 418 | + | ||
442 | 419 | + GdkDeviceGrabInfo *grab = _gdk_display_get_last_device_grab (gdk_device_get_display (device), device); | ||
443 | 420 | + | ||
444 | 421 | + if (grab) | ||
445 | 422 | + grab->serial_end = grab->serial_start; | ||
446 | 423 | } | ||
447 | 424 | |||
448 | 425 | static GdkWindow * | ||
449 | 426 | diff --git a/gdk/mir/gdkmirscreen.c b/gdk/mir/gdkmirscreen.c | ||
450 | 427 | index 2b53cef..e29ddb3 100644 | ||
451 | 428 | --- a/gdk/mir/gdkmirscreen.c | ||
452 | 429 | +++ b/gdk/mir/gdkmirscreen.c | ||
453 | 430 | @@ -327,35 +327,31 @@ gdk_mir_screen_get_monitor_plug_name (GdkScreen *screen, | ||
454 | 431 | switch (output->type) | ||
455 | 432 | { | ||
456 | 433 | case mir_display_output_type_unknown: | ||
457 | 434 | - return g_strdup_printf ("UNKNOWN-%u", output->output_id); | ||
458 | 435 | + return g_strdup_printf ("None-%u", output->output_id); | ||
459 | 436 | case mir_display_output_type_vga: | ||
460 | 437 | return g_strdup_printf ("VGA-%u", output->output_id); | ||
461 | 438 | case mir_display_output_type_dvii: | ||
462 | 439 | - return g_strdup_printf ("DVII-%u", output->output_id); | ||
463 | 440 | case mir_display_output_type_dvid: | ||
464 | 441 | - return g_strdup_printf ("DVID-%u", output->output_id); | ||
465 | 442 | case mir_display_output_type_dvia: | ||
466 | 443 | - return g_strdup_printf ("DVIA-%u", output->output_id); | ||
467 | 444 | + return g_strdup_printf ("DVI-%u", output->output_id); | ||
468 | 445 | case mir_display_output_type_composite: | ||
469 | 446 | - return g_strdup_printf ("COMPOSITE-%u", output->output_id); | ||
470 | 447 | - case mir_display_output_type_svideo: | ||
471 | 448 | - return g_strdup_printf ("SVIDEO-%u", output->output_id); | ||
472 | 449 | + return g_strdup_printf ("Composite-%u", output->output_id); | ||
473 | 450 | case mir_display_output_type_lvds: | ||
474 | 451 | return g_strdup_printf ("LVDS-%u", output->output_id); | ||
475 | 452 | case mir_display_output_type_component: | ||
476 | 453 | - return g_strdup_printf ("COMPONENT-%u", output->output_id); | ||
477 | 454 | + return g_strdup_printf ("CTV-%u", output->output_id); | ||
478 | 455 | case mir_display_output_type_ninepindin: | ||
479 | 456 | - return g_strdup_printf ("NINEPINDIN-%u", output->output_id); | ||
480 | 457 | + return g_strdup_printf ("DIN-%u", output->output_id); | ||
481 | 458 | case mir_display_output_type_displayport: | ||
482 | 459 | - return g_strdup_printf ("DISPLAYPORT-%u", output->output_id); | ||
483 | 460 | + return g_strdup_printf ("DP-%u", output->output_id); | ||
484 | 461 | case mir_display_output_type_hdmia: | ||
485 | 462 | - return g_strdup_printf ("HDMIA-%u", output->output_id); | ||
486 | 463 | case mir_display_output_type_hdmib: | ||
487 | 464 | - return g_strdup_printf ("HDMIB-%u", output->output_id); | ||
488 | 465 | + return g_strdup_printf ("HDMI-%u", output->output_id); | ||
489 | 466 | + case mir_display_output_type_svideo: | ||
490 | 467 | case mir_display_output_type_tv: | ||
491 | 468 | return g_strdup_printf ("TV-%u", output->output_id); | ||
492 | 469 | case mir_display_output_type_edp: | ||
493 | 470 | - return g_strdup_printf ("EDP-%u", output->output_id); | ||
494 | 471 | + return g_strdup_printf ("eDP-%u", output->output_id); | ||
495 | 472 | } | ||
496 | 473 | } | ||
497 | 474 | |||
498 | 475 | diff --git a/gdk/mir/gdkmirwindowimpl.c b/gdk/mir/gdkmirwindowimpl.c | ||
499 | 476 | index 418724b..92521c9 100644 | ||
500 | 477 | --- a/gdk/mir/gdkmirwindowimpl.c | ||
501 | 478 | +++ b/gdk/mir/gdkmirwindowimpl.c | ||
502 | 479 | @@ -259,13 +259,22 @@ redraw_transient (GdkWindow *window) | ||
503 | 480 | gdk_window_invalidate_rect (GDK_MIR_WINDOW_IMPL (window->impl)->transient_for, &r, FALSE); | ||
504 | 481 | } | ||
505 | 482 | |||
506 | 483 | +/* Remove once we have proper transient window support. */ | ||
507 | 484 | +static gboolean | ||
508 | 485 | +should_render_in_parent (GdkWindow *window) | ||
509 | 486 | +{ | ||
510 | 487 | + GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (window->impl); | ||
511 | 488 | + | ||
512 | 489 | + return impl->transient_for && gdk_window_get_window_type (window) != GDK_WINDOW_TOPLEVEL; | ||
513 | 490 | +} | ||
514 | 491 | + | ||
515 | 492 | static void | ||
516 | 493 | send_buffer (GdkWindow *window) | ||
517 | 494 | { | ||
518 | 495 | GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (window->impl); | ||
519 | 496 | |||
520 | 497 | /* Transient windows draw onto parent instead */ | ||
521 | 498 | - if (impl->transient_for) | ||
522 | 499 | + if (should_render_in_parent (window)) | ||
523 | 500 | { | ||
524 | 501 | redraw_transient (window); | ||
525 | 502 | return; | ||
526 | 503 | @@ -327,7 +336,7 @@ gdk_mir_window_impl_ref_cairo_surface (GdkWindow *window) | ||
527 | 504 | } | ||
528 | 505 | |||
529 | 506 | /* Transient windows get rendered into a buffer and copied onto their parent */ | ||
530 | 507 | - if (impl->transient_for) | ||
531 | 508 | + if (should_render_in_parent (window)) | ||
532 | 509 | { | ||
533 | 510 | cairo_surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, window->width, window->height); | ||
534 | 511 | } | ||
535 | 512 | @@ -363,13 +372,13 @@ gdk_mir_window_impl_ref_cairo_surface (GdkWindow *window) | ||
536 | 513 | impl->cairo_surface = cairo_surface_reference (cairo_surface); | ||
537 | 514 | |||
538 | 515 | /* Draw background */ | ||
539 | 516 | - c = cairo_create (impl->cairo_surface); | ||
540 | 517 | if (impl->background) | ||
541 | 518 | - cairo_set_source (c, impl->background); | ||
542 | 519 | - else | ||
543 | 520 | - cairo_set_source_rgb (c, 1.0, 0.0, 0.0); | ||
544 | 521 | - cairo_paint (c); | ||
545 | 522 | - cairo_destroy (c); | ||
546 | 523 | + { | ||
547 | 524 | + c = cairo_create (impl->cairo_surface); | ||
548 | 525 | + cairo_set_source (c, impl->background); | ||
549 | 526 | + cairo_paint (c); | ||
550 | 527 | + cairo_destroy (c); | ||
551 | 528 | + } | ||
552 | 529 | |||
553 | 530 | return cairo_surface; | ||
554 | 531 | } | ||
555 | 532 | @@ -433,10 +442,11 @@ gdk_mir_window_impl_hide (GdkWindow *window) | ||
556 | 533 | //g_printerr ("gdk_mir_window_impl_hide window=%p\n", window); | ||
557 | 534 | GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (window->impl); | ||
558 | 535 | |||
559 | 536 | + impl->cursor_inside = FALSE; | ||
560 | 537 | impl->visible = FALSE; | ||
561 | 538 | ensure_no_surface (window); | ||
562 | 539 | |||
563 | 540 | - if (impl->transient_for) | ||
564 | 541 | + if (should_render_in_parent (window)) | ||
565 | 542 | redraw_transient (window); | ||
566 | 543 | } | ||
567 | 544 | |||
568 | 545 | @@ -446,10 +456,11 @@ gdk_mir_window_impl_withdraw (GdkWindow *window) | ||
569 | 546 | //g_printerr ("gdk_mir_window_impl_withdraw window=%p\n", window); | ||
570 | 547 | GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (window->impl); | ||
571 | 548 | |||
572 | 549 | + impl->cursor_inside = FALSE; | ||
573 | 550 | impl->visible = FALSE; | ||
574 | 551 | ensure_no_surface (window); | ||
575 | 552 | |||
576 | 553 | - if (impl->transient_for) | ||
577 | 554 | + if (should_render_in_parent (window)) | ||
578 | 555 | redraw_transient (window); | ||
579 | 556 | } | ||
580 | 557 | |||
581 | 558 | @@ -492,6 +503,7 @@ gdk_mir_window_impl_move_resize (GdkWindow *window, | ||
582 | 559 | gint width, | ||
583 | 560 | gint height) | ||
584 | 561 | { | ||
585 | 562 | + /* | ||
586 | 563 | g_printerr ("gdk_mir_window_impl_move_resize"); | ||
587 | 564 | g_printerr (" window=%p", window); | ||
588 | 565 | if (with_move) | ||
589 | 566 | @@ -499,16 +511,17 @@ gdk_mir_window_impl_move_resize (GdkWindow *window, | ||
590 | 567 | if (width > 0) | ||
591 | 568 | g_printerr (" size=%dx%dpx", width, height); | ||
592 | 569 | g_printerr ("\n"); | ||
593 | 570 | + */ | ||
594 | 571 | GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (window->impl); | ||
595 | 572 | |||
596 | 573 | /* Redraw parent where we moved from */ | ||
597 | 574 | - if (impl->transient_for) | ||
598 | 575 | + if (should_render_in_parent (window)) | ||
599 | 576 | redraw_transient (window); | ||
600 | 577 | |||
601 | 578 | /* Transient windows can move wherever they want */ | ||
602 | 579 | if (with_move) | ||
603 | 580 | { | ||
604 | 581 | - if (impl->transient_for) | ||
605 | 582 | + if (should_render_in_parent (window)) | ||
606 | 583 | { | ||
607 | 584 | window->x = x; | ||
608 | 585 | window->y = y; | ||
609 | 586 | @@ -535,7 +548,7 @@ gdk_mir_window_impl_move_resize (GdkWindow *window, | ||
610 | 587 | } | ||
611 | 588 | |||
612 | 589 | /* Redraw parent where we moved to */ | ||
613 | 590 | - if (impl->transient_for) | ||
614 | 591 | + if (should_render_in_parent (window)) | ||
615 | 592 | redraw_transient (window); | ||
616 | 593 | } | ||
617 | 594 | |||
618 | 595 | @@ -699,7 +712,7 @@ gdk_mir_window_impl_input_shape_combine_region (GdkWindow *window, | ||
619 | 596 | gint offset_x, | ||
620 | 597 | gint offset_y) | ||
621 | 598 | { | ||
622 | 599 | - g_printerr ("gdk_mir_window_impl_input_shape_combine_region window=%p\n", window); | ||
623 | 600 | + // g_printerr ("gdk_mir_window_impl_input_shape_combine_region window=%p\n", window); | ||
624 | 601 | } | ||
625 | 602 | |||
626 | 603 | static void | ||
627 | 604 | @@ -713,7 +726,7 @@ gdk_mir_window_impl_destroy (GdkWindow *window, | ||
628 | 605 | impl->visible = FALSE; | ||
629 | 606 | ensure_no_surface (window); | ||
630 | 607 | |||
631 | 608 | - if (impl->transient_for) | ||
632 | 609 | + if (should_render_in_parent (window)) | ||
633 | 610 | { | ||
634 | 611 | /* Redraw parent */ | ||
635 | 612 | redraw_transient (window); | ||
636 | 613 | @@ -850,7 +863,7 @@ static void | ||
637 | 614 | gdk_mir_window_impl_set_title (GdkWindow *window, | ||
638 | 615 | const gchar *title) | ||
639 | 616 | { | ||
640 | 617 | - g_printerr ("gdk_mir_window_impl_set_title window=%p\n", window); | ||
641 | 618 | + // g_printerr ("gdk_mir_window_impl_set_title window=%p\n", window); | ||
642 | 619 | } | ||
643 | 620 | |||
644 | 621 | static void | ||
645 | 622 | @@ -881,7 +894,7 @@ gdk_mir_window_impl_set_transient_for (GdkWindow *window, | ||
646 | 623 | |||
647 | 624 | /* Link this window to the parent */ | ||
648 | 625 | impl->transient_for = parent; | ||
649 | 626 | - if (parent) | ||
650 | 627 | + if (should_render_in_parent (window)) | ||
651 | 628 | { | ||
652 | 629 | GdkMirWindowImpl *parent_impl = GDK_MIR_WINDOW_IMPL (parent->impl); | ||
653 | 630 | parent_impl->transient_children = g_list_append (parent_impl->transient_children, window); | ||
654 | 631 | @@ -895,7 +908,42 @@ gdk_mir_window_impl_set_transient_for (GdkWindow *window, | ||
655 | 632 | } | ||
656 | 633 | |||
657 | 634 | /* Remove surface if we had made one before this was set */ | ||
658 | 635 | - ensure_no_surface (window); | ||
659 | 636 | + if (should_render_in_parent (window)) | ||
660 | 637 | + ensure_no_surface (window); | ||
661 | 638 | +} | ||
662 | 639 | + | ||
663 | 640 | +/* TODO: Remove once we have proper transient window support. */ | ||
664 | 641 | +GdkWindow * | ||
665 | 642 | +_gdk_mir_window_get_visible_transient_child (GdkWindow *window, | ||
666 | 643 | + gint x, | ||
667 | 644 | + gint y, | ||
668 | 645 | + gint *out_x, | ||
669 | 646 | + gint *out_y) | ||
670 | 647 | +{ | ||
671 | 648 | + GdkMirWindowImpl *impl = GDK_MIR_WINDOW_IMPL (window->impl); | ||
672 | 649 | + GdkWindow *child = NULL; | ||
673 | 650 | + GList *i; | ||
674 | 651 | + | ||
675 | 652 | + if (x < window->x || x >= window->x + window->width || | ||
676 | 653 | + y < window->y || y >= window->y + window->height) | ||
677 | 654 | + return NULL; | ||
678 | 655 | + | ||
679 | 656 | + x -= window->x; | ||
680 | 657 | + y -= window->y; | ||
681 | 658 | + | ||
682 | 659 | + for (i = impl->transient_children; i && !child; i = i->next) | ||
683 | 660 | + { | ||
684 | 661 | + if (GDK_MIR_WINDOW_IMPL (GDK_WINDOW (i->data)->impl)->visible) | ||
685 | 662 | + child = _gdk_mir_window_get_visible_transient_child (i->data, x, y, out_x, out_y); | ||
686 | 663 | + } | ||
687 | 664 | + | ||
688 | 665 | + if (child) | ||
689 | 666 | + return child; | ||
690 | 667 | + | ||
691 | 668 | + *out_x = x; | ||
692 | 669 | + *out_y = y; | ||
693 | 670 | + | ||
694 | 671 | + return window; | ||
695 | 672 | } | ||
696 | 673 | |||
697 | 674 | static void | ||
698 | 675 | @@ -1242,7 +1290,7 @@ gdk_mir_window_impl_set_shadow_width (GdkWindow *window, | ||
699 | 676 | gint top, | ||
700 | 677 | gint bottom) | ||
701 | 678 | { | ||
702 | 679 | - g_printerr ("gdk_mir_window_impl_set_shadow_width window=%p\n", window); | ||
703 | 680 | + // g_printerr ("gdk_mir_window_impl_set_shadow_width window=%p\n", window); | ||
704 | 681 | } | ||
705 | 682 | |||
706 | 683 | static void | ||
707 | 684 | -- | ||
708 | 685 | 2.1.3 | ||
709 | 686 | |||
710 | 0 | 687 | ||
711 | === modified file 'debian/patches/mir-backend.patch' | |||
712 | --- debian/patches/mir-backend.patch 2014-12-12 10:51:15 +0000 | |||
713 | +++ debian/patches/mir-backend.patch 2014-12-13 16:59:39 +0000 | |||
714 | @@ -1,13 +1,15 @@ | |||
716 | 1 | From 5808594aaff557dfc9ddef82246ddd4ed902a8c5 Mon Sep 17 00:00:00 2001 | 1 | From 122076d4b6f37fa427ea592194f6fe5bacaa9e70 Mon Sep 17 00:00:00 2001 |
717 | 2 | From: Robert Ancell <robert.ancell@canonical.com> | 2 | From: Robert Ancell <robert.ancell@canonical.com> |
718 | 3 | Date: Tue, 20 May 2014 10:03:30 +1200 | 3 | Date: Tue, 20 May 2014 10:03:30 +1200 |
720 | 4 | Subject: [PATCH] Gdk: add an experimental backend for mir | 4 | Subject: [PATCH 1/2] Gdk: add an experimental backend for mir |
721 | 5 | 5 | ||
722 | 6 | Backported from: | 6 | Backported from: |
723 | 7 | 0f26b26f1d93f002ccd5fe6b6fd636172bfbb24b | 7 | 0f26b26f1d93f002ccd5fe6b6fd636172bfbb24b |
724 | 8 | 887b7356c369e58a959b99d88246df8303e34531 | ||
725 | 8 | c41231cc0fdc791a7a69cdd77af51c8162f44aa4 | 9 | c41231cc0fdc791a7a69cdd77af51c8162f44aa4 |
726 | 9 | 053b65a21af312b8b9361367939a221aa7f474a7 | 10 | 053b65a21af312b8b9361367939a221aa7f474a7 |
727 | 10 | 2fdb266c0d0f038a74decda7440ebbb7bdb02e68 | 11 | 2fdb266c0d0f038a74decda7440ebbb7bdb02e68 |
728 | 12 | 063f79b5946198eb5efec0133627a12a75d154a7 | ||
729 | 11 | ec729d06491a2a5bb9ba3f287fbc102b5036bc8f | 13 | ec729d06491a2a5bb9ba3f287fbc102b5036bc8f |
730 | 12 | 92c2e99ddac668d729f42bff501f70fb56fbb76c | 14 | 92c2e99ddac668d729f42bff501f70fb56fbb76c |
731 | 13 | c6de20496c4075a0f1daf8be450d8522aaaea82f | 15 | c6de20496c4075a0f1daf8be450d8522aaaea82f |
732 | @@ -18,32 +20,46 @@ | |||
733 | 18 | 4e4ccb76cd8b5b7dc4342f35fcf64ace30019641 | 20 | 4e4ccb76cd8b5b7dc4342f35fcf64ace30019641 |
734 | 19 | c7e7e350839b19732a2eea7a2151c0c3a76c2544 | 21 | c7e7e350839b19732a2eea7a2151c0c3a76c2544 |
735 | 20 | c42146d88c324189a3a70189f1a60156697ad9ab | 22 | c42146d88c324189a3a70189f1a60156697ad9ab |
736 | 23 | 8bc523ef5915d4ab7ced843929c8e3f1bf754016 | ||
737 | 24 | f5c5e9385e960a74ce38bc58a30fa36474d0cd6a | ||
738 | 25 | 5ff39b207b373754007a99be6286bb7b93ecb49d | ||
739 | 26 | acfc4f891030d7339c221bdb57df9af8994fd6e0 | ||
740 | 27 | da8fdab87b4cc96b9614ccb6abb0682def324f30 | ||
741 | 28 | e0e46a4f6bf852d5ead8b8c015aa8eaf4e80599e | ||
742 | 29 | 60e185e496180dad0be322a970e4aa17be1c8809 | ||
743 | 30 | b8925253b66a63594f5d373dc10c564f0d184eb4 | ||
744 | 21 | --- | 31 | --- |
770 | 22 | Makefile.am | 6 +- | 32 | Makefile.am | 6 +- |
771 | 23 | configure.ac | 34 +- | 33 | configure.ac | 35 +- |
772 | 24 | docs/reference/gtk/Makefile.am | 1 + | 34 | docs/reference/gtk/Makefile.am | 1 + |
773 | 25 | docs/reference/gtk/building.sgml | 11 +- | 35 | docs/reference/gtk/building.sgml | 11 +- |
774 | 26 | docs/reference/gtk/gtk-docs.sgml | 1 + | 36 | docs/reference/gtk/gtk-docs.sgml | 1 + |
775 | 27 | docs/reference/gtk/mir.xml | 35 + | 37 | docs/reference/gtk/mir.xml | 35 + |
776 | 28 | docs/reference/gtk/running.sgml | 5 + | 38 | docs/reference/gtk/running.sgml | 5 + |
777 | 29 | gdk/Makefile.am | 6 +- | 39 | gdk/Makefile.am | 6 +- |
778 | 30 | gdk/gdkdisplaymanager.c | 7 + | 40 | gdk/broadway/gdkdisplay-broadway.c | 15 - |
779 | 31 | gdk/mir/Makefile.am | 39 ++ | 41 | gdk/gdkdisplay.c | 15 + |
780 | 32 | gdk/mir/gdkmir-debug.c | 293 +++++++++ | 42 | gdk/gdkdisplaymanager.c | 7 + |
781 | 33 | gdk/mir/gdkmir-private.h | 90 +++ | 43 | gdk/mir/Makefile.am | 39 ++ |
782 | 34 | gdk/mir/gdkmir.h | 39 ++ | 44 | gdk/mir/gdkmir-debug.c | 293 ++++++++ |
783 | 35 | gdk/mir/gdkmircursor.c | 177 +++++ | 45 | gdk/mir/gdkmir-private.h | 92 +++ |
784 | 36 | gdk/mir/gdkmirdevicemanager.c | 120 ++++ | 46 | gdk/mir/gdkmir.h | 39 ++ |
785 | 37 | gdk/mir/gdkmirdisplay.c | 565 ++++++++++++++++ | 47 | gdk/mir/gdkmircursor.c | 177 +++++ |
786 | 38 | gdk/mir/gdkmireventsource.c | 630 ++++++++++++++++++ | 48 | gdk/mir/gdkmirdevicemanager.c | 120 ++++ |
787 | 39 | gdk/mir/gdkmirkeyboard.c | 173 +++++ | 49 | gdk/mir/gdkmirdisplay.c | 549 +++++++++++++++ |
788 | 40 | gdk/mir/gdkmirkeymap.c | 466 ++++++++++++++ | 50 | gdk/mir/gdkmireventsource.c | 631 +++++++++++++++++ |
789 | 41 | gdk/mir/gdkmirpointer.c | 250 ++++++++ | 51 | gdk/mir/gdkmirkeyboard.c | 173 +++++ |
790 | 42 | gdk/mir/gdkmirscreen.c | 801 +++++++++++++++++++++++ | 52 | gdk/mir/gdkmirkeymap.c | 466 +++++++++++++ |
791 | 43 | gdk/mir/gdkmirwindow.c | 52 ++ | 53 | gdk/mir/gdkmirpointer.c | 250 +++++++ |
792 | 44 | gdk/mir/gdkmirwindowimpl.c | 1320 ++++++++++++++++++++++++++++++++++++++ | 54 | gdk/mir/gdkmirscreen.c | 804 ++++++++++++++++++++++ |
793 | 45 | gtk/gtktooltip.c | 16 + | 55 | gdk/mir/gdkmirwindow.c | 52 ++ |
794 | 46 | 24 files changed, 5130 insertions(+), 7 deletions(-) | 56 | gdk/mir/gdkmirwindowimpl.c | 1336 ++++++++++++++++++++++++++++++++++++ |
795 | 57 | gdk/wayland/gdkdisplay-wayland.c | 15 - | ||
796 | 58 | gdk/win32/gdkdisplay-win32.c | 15 - | ||
797 | 59 | gdk/x11/gdkdisplay-x11.c | 15 - | ||
798 | 60 | gtk/gtktooltip.c | 16 + | ||
799 | 61 | gtk/gtkwindow.c | 9 + | ||
800 | 62 | 30 files changed, 5161 insertions(+), 67 deletions(-) | ||
801 | 47 | create mode 100644 docs/reference/gtk/mir.xml | 63 | create mode 100644 docs/reference/gtk/mir.xml |
802 | 48 | create mode 100644 gdk/mir/Makefile.am | 64 | create mode 100644 gdk/mir/Makefile.am |
803 | 49 | create mode 100644 gdk/mir/gdkmir-debug.c | 65 | create mode 100644 gdk/mir/gdkmir-debug.c |
804 | @@ -60,11 +76,11 @@ | |||
805 | 60 | create mode 100644 gdk/mir/gdkmirwindow.c | 76 | create mode 100644 gdk/mir/gdkmirwindow.c |
806 | 61 | create mode 100644 gdk/mir/gdkmirwindowimpl.c | 77 | create mode 100644 gdk/mir/gdkmirwindowimpl.c |
807 | 62 | 78 | ||
810 | 63 | Index: b/Makefile.am | 79 | diff --git a/Makefile.am b/Makefile.am |
811 | 64 | =================================================================== | 80 | index 2cb7769..37bc9ff 100644 |
812 | 65 | --- a/Makefile.am | 81 | --- a/Makefile.am |
813 | 66 | +++ b/Makefile.am | 82 | +++ b/Makefile.am |
815 | 67 | @@ -33,11 +33,11 @@ | 83 | @@ -33,11 +33,11 @@ MAINTAINERCLEANFILES = \ |
816 | 68 | 84 | ||
817 | 69 | 85 | ||
818 | 70 | ## Copy .pc files to target-specific names | 86 | ## Copy .pc files to target-specific names |
819 | @@ -78,7 +94,7 @@ | |||
820 | 78 | rm -f $@ && \ | 94 | rm -f $@ && \ |
821 | 79 | cp gdk-3.0.pc $@ | 95 | cp gdk-3.0.pc $@ |
822 | 80 | 96 | ||
824 | 81 | @@ -59,12 +59,14 @@ | 97 | @@ -59,12 +59,14 @@ DISTCLEANFILES = \ |
825 | 82 | gtk+-quartz-3.0.pc \ | 98 | gtk+-quartz-3.0.pc \ |
826 | 83 | gtk+-broadway-3.0.pc \ | 99 | gtk+-broadway-3.0.pc \ |
827 | 84 | gtk+-wayland-3.0.pc \ | 100 | gtk+-wayland-3.0.pc \ |
828 | @@ -93,11 +109,19 @@ | |||
829 | 93 | gail-3.0.pc \ | 109 | gail-3.0.pc \ |
830 | 94 | config.lt | 110 | config.lt |
831 | 95 | 111 | ||
834 | 96 | Index: b/configure.ac | 112 | diff --git a/configure.ac b/configure.ac |
835 | 97 | =================================================================== | 113 | index cccdae9..43e6245 100644 |
836 | 98 | --- a/configure.ac | 114 | --- a/configure.ac |
837 | 99 | +++ b/configure.ac | 115 | +++ b/configure.ac |
839 | 100 | @@ -329,6 +329,10 @@ | 116 | @@ -48,6 +48,7 @@ m4_define([cairo_required_version], [1.12.0]) |
840 | 117 | m4_define([gdk_pixbuf_required_version], [2.30.0]) | ||
841 | 118 | m4_define([introspection_required_version], [1.39.0]) | ||
842 | 119 | m4_define([wayland_required_version], [1.5.91]) | ||
843 | 120 | +m4_define([mirclient_required_version], [0.9.0]) | ||
844 | 121 | GLIB_REQUIRED_VERSION=glib_required_version | ||
845 | 122 | PANGO_REQUIRED_VERSION=pango_required_version | ||
846 | 123 | ATK_REQUIRED_VERSION=atk_required_version | ||
847 | 124 | @@ -329,6 +330,10 @@ AC_ARG_ENABLE(wayland-backend, | ||
848 | 101 | [AS_HELP_STRING([--enable-wayland-backend], | 125 | [AS_HELP_STRING([--enable-wayland-backend], |
849 | 102 | [enable the wayland gdk backend])], | 126 | [enable the wayland gdk backend])], |
850 | 103 | [backend_set=yes]) | 127 | [backend_set=yes]) |
851 | @@ -108,7 +132,7 @@ | |||
852 | 108 | 132 | ||
853 | 109 | if test -z "$backend_set"; then | 133 | if test -z "$backend_set"; then |
854 | 110 | if test "$platform_win32" = yes; then | 134 | if test "$platform_win32" = yes; then |
856 | 111 | @@ -336,6 +340,7 @@ | 135 | @@ -336,6 +341,7 @@ if test -z "$backend_set"; then |
857 | 112 | else | 136 | else |
858 | 113 | enable_x11_backend=yes | 137 | enable_x11_backend=yes |
859 | 114 | enable_wayland_backend=maybe | 138 | enable_wayland_backend=maybe |
860 | @@ -116,11 +140,11 @@ | |||
861 | 116 | fi | 140 | fi |
862 | 117 | fi | 141 | fi |
863 | 118 | 142 | ||
865 | 119 | @@ -457,6 +462,30 @@ | 143 | @@ -457,6 +463,30 @@ else |
866 | 120 | AM_CONDITIONAL(USE_WAYLAND, false) | 144 | AM_CONDITIONAL(USE_WAYLAND, false) |
867 | 121 | fi | 145 | fi |
868 | 122 | 146 | ||
870 | 123 | +MIR_DEPENDENCIES="mirclient" | 147 | +MIR_DEPENDENCIES="mirclient >= mirclient_required_version" |
871 | 124 | +if test "$enable_mir_backend" = "maybe" ; then | 148 | +if test "$enable_mir_backend" = "maybe" ; then |
872 | 125 | + PKG_CHECK_EXISTS($MIR_DEPENDENCIES, [have_mir_deps=yes], [have_mir_deps=no]) | 149 | + PKG_CHECK_EXISTS($MIR_DEPENDENCIES, [have_mir_deps=yes], [have_mir_deps=no]) |
873 | 126 | + AC_MSG_CHECKING([for MIR_DEPENDENCIES]) | 150 | + AC_MSG_CHECKING([for MIR_DEPENDENCIES]) |
874 | @@ -147,7 +171,7 @@ | |||
875 | 147 | # strip leading space | 171 | # strip leading space |
876 | 148 | GDK_BACKENDS=${GDK_BACKENDS#* } | 172 | GDK_BACKENDS=${GDK_BACKENDS#* } |
877 | 149 | 173 | ||
879 | 150 | @@ -1326,7 +1355,7 @@ | 174 | @@ -1326,7 +1356,7 @@ CFLAGS="$saved_cflags" |
880 | 151 | LDFLAGS="$saved_ldflags" | 175 | LDFLAGS="$saved_ldflags" |
881 | 152 | 176 | ||
882 | 153 | GDK_PACKAGES="$PANGO_PACKAGES gdk-pixbuf-2.0 >= gdk_pixbuf_required_version cairo >= cairo_required_version cairo-gobject >= cairo_required_version" | 177 | GDK_PACKAGES="$PANGO_PACKAGES gdk-pixbuf-2.0 >= gdk_pixbuf_required_version cairo >= cairo_required_version cairo-gobject >= cairo_required_version" |
883 | @@ -156,7 +180,7 @@ | |||
884 | 156 | if test "x$enable_x11_backend" = xyes; then | 180 | if test "x$enable_x11_backend" = xyes; then |
885 | 157 | GDK_PRIVATE_PACKAGES="$GDK_PRIVATE_PACKAGES pangoft2" | 181 | GDK_PRIVATE_PACKAGES="$GDK_PRIVATE_PACKAGES pangoft2" |
886 | 158 | fi | 182 | fi |
888 | 159 | @@ -1363,7 +1392,7 @@ | 183 | @@ -1363,7 +1393,7 @@ fi |
889 | 160 | PKG_CHECK_MODULES(ATK, $ATK_PACKAGES) | 184 | PKG_CHECK_MODULES(ATK, $ATK_PACKAGES) |
890 | 161 | 185 | ||
891 | 162 | GTK_PACKAGES="atk >= atk_required_version cairo >= cairo_required_version cairo-gobject >= cairo_required_version gdk-pixbuf-2.0 >= gdk_pixbuf_required_version gio-2.0 >= glib_required_version" | 186 | GTK_PACKAGES="atk >= atk_required_version cairo >= cairo_required_version cairo-gobject >= cairo_required_version gdk-pixbuf-2.0 >= gdk_pixbuf_required_version gio-2.0 >= glib_required_version" |
892 | @@ -165,7 +189,7 @@ | |||
893 | 165 | if test "x$enable_x11_backend" = xyes; then | 189 | if test "x$enable_x11_backend" = xyes; then |
894 | 166 | GTK_PRIVATE_PACKAGES="$GTK_PRIVATE_PACKAGES pangoft2" | 190 | GTK_PRIVATE_PACKAGES="$GTK_PRIVATE_PACKAGES pangoft2" |
895 | 167 | fi | 191 | fi |
897 | 168 | @@ -1903,6 +1932,7 @@ | 192 | @@ -1903,6 +1933,7 @@ gdk/win32/rc/Makefile |
898 | 169 | gdk/win32/rc/gdk.rc | 193 | gdk/win32/rc/gdk.rc |
899 | 170 | gdk/quartz/Makefile | 194 | gdk/quartz/Makefile |
900 | 171 | gdk/wayland/Makefile | 195 | gdk/wayland/Makefile |
901 | @@ -173,11 +197,11 @@ | |||
902 | 173 | gdk/gdkversionmacros.h | 197 | gdk/gdkversionmacros.h |
903 | 174 | gtk/Makefile | 198 | gtk/Makefile |
904 | 175 | gtk/makefile.msc | 199 | gtk/makefile.msc |
907 | 176 | Index: b/docs/reference/gtk/Makefile.am | 200 | diff --git a/docs/reference/gtk/Makefile.am b/docs/reference/gtk/Makefile.am |
908 | 177 | =================================================================== | 201 | index 968384c..74ef369 100644 |
909 | 178 | --- a/docs/reference/gtk/Makefile.am | 202 | --- a/docs/reference/gtk/Makefile.am |
910 | 179 | +++ b/docs/reference/gtk/Makefile.am | 203 | +++ b/docs/reference/gtk/Makefile.am |
912 | 180 | @@ -145,6 +145,7 @@ | 204 | @@ -145,6 +145,7 @@ content_files = \ |
913 | 181 | osx.sgml \ | 205 | osx.sgml \ |
914 | 182 | broadway.xml \ | 206 | broadway.xml \ |
915 | 183 | wayland.xml \ | 207 | wayland.xml \ |
916 | @@ -185,11 +209,11 @@ | |||
917 | 185 | question_index.sgml \ | 209 | question_index.sgml \ |
918 | 186 | resources.sgml \ | 210 | resources.sgml \ |
919 | 187 | text_widget.sgml \ | 211 | text_widget.sgml \ |
922 | 188 | Index: b/docs/reference/gtk/building.sgml | 212 | diff --git a/docs/reference/gtk/building.sgml b/docs/reference/gtk/building.sgml |
923 | 189 | =================================================================== | 213 | index b7479e7..445e1fd 100644 |
924 | 190 | --- a/docs/reference/gtk/building.sgml | 214 | --- a/docs/reference/gtk/building.sgml |
925 | 191 | +++ b/docs/reference/gtk/building.sgml | 215 | +++ b/docs/reference/gtk/building.sgml |
927 | 192 | @@ -395,6 +395,11 @@ | 216 | @@ -395,6 +395,11 @@ How to compile GTK+ itself |
928 | 193 | </group> | 217 | </group> |
929 | 194 | <sbr/> | 218 | <sbr/> |
930 | 195 | <group> | 219 | <group> |
931 | @@ -201,7 +225,7 @@ | |||
932 | 201 | <arg choice="plain">--enable-introspection=[no/auto/yes]</arg> | 225 | <arg choice="plain">--enable-introspection=[no/auto/yes]</arg> |
933 | 202 | </group> | 226 | </group> |
934 | 203 | <sbr/> | 227 | <sbr/> |
936 | 204 | @@ -595,8 +600,10 @@ | 228 | @@ -595,8 +600,10 @@ How to compile GTK+ itself |
937 | 205 | <systemitem>--disable-quartz-backend</systemitem>, | 229 | <systemitem>--disable-quartz-backend</systemitem>, |
938 | 206 | <systemitem>--enable-broadway-backend</systemitem>, | 230 | <systemitem>--enable-broadway-backend</systemitem>, |
939 | 207 | <systemitem>--disable-broadway-backend</systemitem>, | 231 | <systemitem>--disable-broadway-backend</systemitem>, |
940 | @@ -214,8 +238,8 @@ | |||
941 | 214 | 238 | ||
942 | 215 | <para> | 239 | <para> |
943 | 216 | Enables specific backends for GDK. If none of these options | 240 | Enables specific backends for GDK. If none of these options |
946 | 217 | Index: b/docs/reference/gtk/gtk-docs.sgml | 241 | diff --git a/docs/reference/gtk/gtk-docs.sgml b/docs/reference/gtk/gtk-docs.sgml |
947 | 218 | =================================================================== | 242 | index 2e00bae..8f4a8d1 100644 |
948 | 219 | --- a/docs/reference/gtk/gtk-docs.sgml | 243 | --- a/docs/reference/gtk/gtk-docs.sgml |
949 | 220 | +++ b/docs/reference/gtk/gtk-docs.sgml | 244 | +++ b/docs/reference/gtk/gtk-docs.sgml |
950 | 221 | @@ -413,6 +413,7 @@ | 245 | @@ -413,6 +413,7 @@ |
951 | @@ -226,8 +250,9 @@ | |||
952 | 226 | </part> | 250 | </part> |
953 | 227 | 251 | ||
954 | 228 | <xi:include href="glossary.xml" /> | 252 | <xi:include href="glossary.xml" /> |
957 | 229 | Index: b/docs/reference/gtk/mir.xml | 253 | diff --git a/docs/reference/gtk/mir.xml b/docs/reference/gtk/mir.xml |
958 | 230 | =================================================================== | 254 | new file mode 100644 |
959 | 255 | index 0000000..3a0a52e | ||
960 | 231 | --- /dev/null | 256 | --- /dev/null |
961 | 232 | +++ b/docs/reference/gtk/mir.xml | 257 | +++ b/docs/reference/gtk/mir.xml |
962 | 233 | @@ -0,0 +1,35 @@ | 258 | @@ -0,0 +1,35 @@ |
963 | @@ -266,11 +291,11 @@ | |||
964 | 266 | +</refsect1> | 291 | +</refsect1> |
965 | 267 | + | 292 | + |
966 | 268 | +</refentry> | 293 | +</refentry> |
969 | 269 | Index: b/docs/reference/gtk/running.sgml | 294 | diff --git a/docs/reference/gtk/running.sgml b/docs/reference/gtk/running.sgml |
970 | 270 | =================================================================== | 295 | index 321593a..1aa2291 100644 |
971 | 271 | --- a/docs/reference/gtk/running.sgml | 296 | --- a/docs/reference/gtk/running.sgml |
972 | 272 | +++ b/docs/reference/gtk/running.sgml | 297 | +++ b/docs/reference/gtk/running.sgml |
974 | 273 | @@ -487,6 +487,11 @@ | 298 | @@ -487,6 +487,11 @@ nevertheless. |
975 | 274 | <listitem><para>Selects the Wayland backend for connecting to Wayland display servers</para></listitem> | 299 | <listitem><para>Selects the Wayland backend for connecting to Wayland display servers</para></listitem> |
976 | 275 | </varlistentry> | 300 | </varlistentry> |
977 | 276 | 301 | ||
978 | @@ -282,11 +307,11 @@ | |||
979 | 282 | </variablelist> | 307 | </variablelist> |
980 | 283 | Since 3.10, this environment variable can contain a comma-separated list | 308 | Since 3.10, this environment variable can contain a comma-separated list |
981 | 284 | of backend names, which are tried in order. The list may also contain | 309 | of backend names, which are tried in order. The list may also contain |
984 | 285 | Index: b/gdk/Makefile.am | 310 | diff --git a/gdk/Makefile.am b/gdk/Makefile.am |
985 | 286 | =================================================================== | 311 | index 5f0c1e5..1e24b6e 100644 |
986 | 287 | --- a/gdk/Makefile.am | 312 | --- a/gdk/Makefile.am |
987 | 288 | +++ b/gdk/Makefile.am | 313 | +++ b/gdk/Makefile.am |
989 | 289 | @@ -13,7 +13,7 @@ | 314 | @@ -13,7 +13,7 @@ INTROSPECTION_COMPILER_ARGS = \ |
990 | 290 | 315 | ||
991 | 291 | SUBDIRS = $(GDK_BACKENDS) . | 316 | SUBDIRS = $(GDK_BACKENDS) . |
992 | 292 | 317 | ||
993 | @@ -295,7 +320,7 @@ | |||
994 | 295 | 320 | ||
995 | 296 | CLEANFILES = | 321 | CLEANFILES = |
996 | 297 | 322 | ||
998 | 298 | @@ -201,6 +201,10 @@ | 323 | @@ -201,6 +201,10 @@ if USE_WAYLAND |
999 | 299 | libgdk_3_la_LIBADD += wayland/libgdk-wayland.la | 324 | libgdk_3_la_LIBADD += wayland/libgdk-wayland.la |
1000 | 300 | endif | 325 | endif |
1001 | 301 | 326 | ||
1002 | @@ -306,8 +331,74 @@ | |||
1003 | 306 | if HAVE_INTROSPECTION | 331 | if HAVE_INTROSPECTION |
1004 | 307 | 332 | ||
1005 | 308 | introspection_files = \ | 333 | introspection_files = \ |
1008 | 309 | Index: b/gdk/gdkdisplaymanager.c | 334 | diff --git a/gdk/broadway/gdkdisplay-broadway.c b/gdk/broadway/gdkdisplay-broadway.c |
1009 | 310 | =================================================================== | 335 | index 53c675d..307728f 100644 |
1010 | 336 | --- a/gdk/broadway/gdkdisplay-broadway.c | ||
1011 | 337 | +++ b/gdk/broadway/gdkdisplay-broadway.c | ||
1012 | 338 | @@ -330,19 +330,6 @@ gdk_broadway_display_get_next_serial (GdkDisplay *display) | ||
1013 | 339 | return _gdk_broadway_server_get_next_serial (broadway_display->server); | ||
1014 | 340 | } | ||
1015 | 341 | |||
1016 | 342 | -static void | ||
1017 | 343 | -gdk_broadway_display_event_data_copy (GdkDisplay *display, | ||
1018 | 344 | - const GdkEvent *src, | ||
1019 | 345 | - GdkEvent *dst) | ||
1020 | 346 | -{ | ||
1021 | 347 | -} | ||
1022 | 348 | - | ||
1023 | 349 | -static void | ||
1024 | 350 | -gdk_broadway_display_event_data_free (GdkDisplay *display, | ||
1025 | 351 | - GdkEvent *event) | ||
1026 | 352 | -{ | ||
1027 | 353 | -} | ||
1028 | 354 | - | ||
1029 | 355 | void | ||
1030 | 356 | gdk_broadway_display_show_keyboard (GdkBroadwayDisplay *display) | ||
1031 | 357 | { | ||
1032 | 358 | @@ -398,8 +385,6 @@ gdk_broadway_display_class_init (GdkBroadwayDisplayClass * class) | ||
1033 | 359 | display_class->after_process_all_updates = _gdk_broadway_display_after_process_all_updates; | ||
1034 | 360 | display_class->get_next_serial = gdk_broadway_display_get_next_serial; | ||
1035 | 361 | display_class->notify_startup_complete = gdk_broadway_display_notify_startup_complete; | ||
1036 | 362 | - display_class->event_data_copy = gdk_broadway_display_event_data_copy; | ||
1037 | 363 | - display_class->event_data_free = gdk_broadway_display_event_data_free; | ||
1038 | 364 | display_class->create_window_impl = _gdk_broadway_display_create_window_impl; | ||
1039 | 365 | display_class->get_keymap = _gdk_broadway_display_get_keymap; | ||
1040 | 366 | display_class->get_selection_owner = _gdk_broadway_display_get_selection_owner; | ||
1041 | 367 | diff --git a/gdk/gdkdisplay.c b/gdk/gdkdisplay.c | ||
1042 | 368 | index 34b6cab..5ccfe01 100644 | ||
1043 | 369 | --- a/gdk/gdkdisplay.c | ||
1044 | 370 | +++ b/gdk/gdkdisplay.c | ||
1045 | 371 | @@ -111,6 +111,19 @@ gdk_display_real_opened (GdkDisplay *display) | ||
1046 | 372 | } | ||
1047 | 373 | |||
1048 | 374 | static void | ||
1049 | 375 | +gdk_display_real_event_data_copy (GdkDisplay *display, | ||
1050 | 376 | + const GdkEvent *src, | ||
1051 | 377 | + GdkEvent *dst) | ||
1052 | 378 | +{ | ||
1053 | 379 | +} | ||
1054 | 380 | + | ||
1055 | 381 | +static void | ||
1056 | 382 | +gdk_display_real_event_data_free (GdkDisplay *display, | ||
1057 | 383 | + GdkEvent *dst) | ||
1058 | 384 | +{ | ||
1059 | 385 | +} | ||
1060 | 386 | + | ||
1061 | 387 | +static void | ||
1062 | 388 | gdk_display_class_init (GdkDisplayClass *class) | ||
1063 | 389 | { | ||
1064 | 390 | GObjectClass *object_class = G_OBJECT_CLASS (class); | ||
1065 | 391 | @@ -123,6 +136,8 @@ gdk_display_class_init (GdkDisplayClass *class) | ||
1066 | 392 | |||
1067 | 393 | class->opened = gdk_display_real_opened; | ||
1068 | 394 | class->make_default = gdk_display_real_make_default; | ||
1069 | 395 | + class->event_data_copy = gdk_display_real_event_data_copy; | ||
1070 | 396 | + class->event_data_free = gdk_display_real_event_data_free; | ||
1071 | 397 | |||
1072 | 398 | /** | ||
1073 | 399 | * GdkDisplay::opened: | ||
1074 | 400 | diff --git a/gdk/gdkdisplaymanager.c b/gdk/gdkdisplaymanager.c | ||
1075 | 401 | index c6813d0..c9afbca 100644 | ||
1076 | 311 | --- a/gdk/gdkdisplaymanager.c | 402 | --- a/gdk/gdkdisplaymanager.c |
1077 | 312 | +++ b/gdk/gdkdisplaymanager.c | 403 | +++ b/gdk/gdkdisplaymanager.c |
1078 | 313 | @@ -60,6 +60,10 @@ | 404 | @@ -60,6 +60,10 @@ |
1079 | @@ -321,7 +412,7 @@ | |||
1080 | 321 | /** | 412 | /** |
1081 | 322 | * SECTION:gdkdisplaymanager | 413 | * SECTION:gdkdisplaymanager |
1082 | 323 | * @Short_description: Maintains a list of all open GdkDisplays | 414 | * @Short_description: Maintains a list of all open GdkDisplays |
1084 | 324 | @@ -272,6 +276,9 @@ | 415 | @@ -272,6 +276,9 @@ static GdkBackend gdk_backends[] = { |
1085 | 325 | #ifdef GDK_WINDOWING_WAYLAND | 416 | #ifdef GDK_WINDOWING_WAYLAND |
1086 | 326 | { "wayland", _gdk_wayland_display_open }, | 417 | { "wayland", _gdk_wayland_display_open }, |
1087 | 327 | #endif | 418 | #endif |
1088 | @@ -331,8 +422,9 @@ | |||
1089 | 331 | #ifdef GDK_WINDOWING_BROADWAY | 422 | #ifdef GDK_WINDOWING_BROADWAY |
1090 | 332 | { "broadway", _gdk_broadway_display_open }, | 423 | { "broadway", _gdk_broadway_display_open }, |
1091 | 333 | #endif | 424 | #endif |
1094 | 334 | Index: b/gdk/mir/Makefile.am | 425 | diff --git a/gdk/mir/Makefile.am b/gdk/mir/Makefile.am |
1095 | 335 | =================================================================== | 426 | new file mode 100644 |
1096 | 427 | index 0000000..026ce79 | ||
1097 | 336 | --- /dev/null | 428 | --- /dev/null |
1098 | 337 | +++ b/gdk/mir/Makefile.am | 429 | +++ b/gdk/mir/Makefile.am |
1099 | 338 | @@ -0,0 +1,39 @@ | 430 | @@ -0,0 +1,39 @@ |
1100 | @@ -375,8 +467,9 @@ | |||
1101 | 375 | + gdkmir.h | 467 | + gdkmir.h |
1102 | 376 | + | 468 | + |
1103 | 377 | +-include $(top_srcdir)/git.mk | 469 | +-include $(top_srcdir)/git.mk |
1106 | 378 | Index: b/gdk/mir/gdkmir-debug.c | 470 | diff --git a/gdk/mir/gdkmir-debug.c b/gdk/mir/gdkmir-debug.c |
1107 | 379 | =================================================================== | 471 | new file mode 100644 |
1108 | 472 | index 0000000..ef57eff | ||
1109 | 380 | --- /dev/null | 473 | --- /dev/null |
1110 | 381 | +++ b/gdk/mir/gdkmir-debug.c | 474 | +++ b/gdk/mir/gdkmir-debug.c |
1111 | 382 | @@ -0,0 +1,293 @@ | 475 | @@ -0,0 +1,293 @@ |
1112 | @@ -673,8 +766,9 @@ | |||
1113 | 673 | + break; | 766 | + break; |
1114 | 674 | + } | 767 | + } |
1115 | 675 | +} | 768 | +} |
1118 | 676 | Index: b/gdk/mir/gdkmir-private.h | 769 | diff --git a/gdk/mir/gdkmir-private.h b/gdk/mir/gdkmir-private.h |
1119 | 677 | =================================================================== | 770 | new file mode 100644 |
1120 | 771 | index 0000000..8305096 | ||
1121 | 678 | --- /dev/null | 772 | --- /dev/null |
1122 | 679 | +++ b/gdk/mir/gdkmir-private.h | 773 | +++ b/gdk/mir/gdkmir-private.h |
1123 | 680 | @@ -0,0 +1,92 @@ | 774 | @@ -0,0 +1,92 @@ |
1124 | @@ -770,8 +864,9 @@ | |||
1125 | 770 | +void _gdk_mir_print_event (const MirEvent *event); | 864 | +void _gdk_mir_print_event (const MirEvent *event); |
1126 | 771 | + | 865 | + |
1127 | 772 | +#endif /* __GDK_PRIVATE_MIR_H__ */ | 866 | +#endif /* __GDK_PRIVATE_MIR_H__ */ |
1130 | 773 | Index: b/gdk/mir/gdkmir.h | 867 | diff --git a/gdk/mir/gdkmir.h b/gdk/mir/gdkmir.h |
1131 | 774 | =================================================================== | 868 | new file mode 100644 |
1132 | 869 | index 0000000..00bbda1 | ||
1133 | 775 | --- /dev/null | 870 | --- /dev/null |
1134 | 776 | +++ b/gdk/mir/gdkmir.h | 871 | +++ b/gdk/mir/gdkmir.h |
1135 | 777 | @@ -0,0 +1,39 @@ | 872 | @@ -0,0 +1,39 @@ |
1136 | @@ -802,20 +897,21 @@ | |||
1137 | 802 | +#define GDK_IS_MIR_DISPLAY(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_MIR_DISPLAY)) | 897 | +#define GDK_IS_MIR_DISPLAY(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_MIR_DISPLAY)) |
1138 | 803 | + | 898 | + |
1139 | 804 | +#define GDK_TYPE_MIR_WINDOW (gdk_mir_window_get_type ()) | 899 | +#define GDK_TYPE_MIR_WINDOW (gdk_mir_window_get_type ()) |
1141 | 805 | +#define GDK_IS_WINDOW_MIR(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_WINDOW_MIR)) | 900 | +#define GDK_IS_WINDOW_MIR(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_MIR_WINDOW)) |
1142 | 806 | + | 901 | + |
1143 | 807 | +GDK_AVAILABLE_IN_3_10 | 902 | +GDK_AVAILABLE_IN_3_10 |
1144 | 808 | +GType gdk_mir_display_get_type (void); | 903 | +GType gdk_mir_display_get_type (void); |
1145 | 809 | + | 904 | + |
1146 | 810 | +GDK_AVAILABLE_IN_3_10 | 905 | +GDK_AVAILABLE_IN_3_10 |
1148 | 811 | +struct MirConnection *gdk_mir_display_get_mir_connection (GdkDisplay *display); | 906 | +MirConnection *gdk_mir_display_get_mir_connection (GdkDisplay *display); |
1149 | 812 | + | 907 | + |
1150 | 813 | +GDK_AVAILABLE_IN_3_10 | 908 | +GDK_AVAILABLE_IN_3_10 |
1151 | 814 | +GType gdk_mir_window_get_type (void); | 909 | +GType gdk_mir_window_get_type (void); |
1152 | 815 | + | 910 | + |
1153 | 816 | +#endif /* __GDK_MIR_H__ */ | 911 | +#endif /* __GDK_MIR_H__ */ |
1156 | 817 | Index: b/gdk/mir/gdkmircursor.c | 912 | diff --git a/gdk/mir/gdkmircursor.c b/gdk/mir/gdkmircursor.c |
1157 | 818 | =================================================================== | 913 | new file mode 100644 |
1158 | 914 | index 0000000..7ce158a | ||
1159 | 819 | --- /dev/null | 915 | --- /dev/null |
1160 | 820 | +++ b/gdk/mir/gdkmircursor.c | 916 | +++ b/gdk/mir/gdkmircursor.c |
1161 | 821 | @@ -0,0 +1,177 @@ | 917 | @@ -0,0 +1,177 @@ |
1162 | @@ -996,8 +1092,9 @@ | |||
1163 | 996 | + cursor_class->get_surface = gdk_mir_cursor_get_surface; | 1092 | + cursor_class->get_surface = gdk_mir_cursor_get_surface; |
1164 | 997 | + object_class->finalize = gdk_mir_cursor_finalize; | 1093 | + object_class->finalize = gdk_mir_cursor_finalize; |
1165 | 998 | +} | 1094 | +} |
1168 | 999 | Index: b/gdk/mir/gdkmirdevicemanager.c | 1095 | diff --git a/gdk/mir/gdkmirdevicemanager.c b/gdk/mir/gdkmirdevicemanager.c |
1169 | 1000 | =================================================================== | 1096 | new file mode 100644 |
1170 | 1097 | index 0000000..c94f8a3 | ||
1171 | 1001 | --- /dev/null | 1098 | --- /dev/null |
1172 | 1002 | +++ b/gdk/mir/gdkmirdevicemanager.c | 1099 | +++ b/gdk/mir/gdkmirdevicemanager.c |
1173 | 1003 | @@ -0,0 +1,120 @@ | 1100 | @@ -0,0 +1,120 @@ |
1174 | @@ -1121,11 +1218,12 @@ | |||
1175 | 1121 | + device_manager_class->get_client_pointer = gdk_mir_device_manager_get_client_pointer; | 1218 | + device_manager_class->get_client_pointer = gdk_mir_device_manager_get_client_pointer; |
1176 | 1122 | + object_class->constructed = gdk_mir_device_manager_constructed; | 1219 | + object_class->constructed = gdk_mir_device_manager_constructed; |
1177 | 1123 | +} | 1220 | +} |
1180 | 1124 | Index: b/gdk/mir/gdkmirdisplay.c | 1221 | diff --git a/gdk/mir/gdkmirdisplay.c b/gdk/mir/gdkmirdisplay.c |
1181 | 1125 | =================================================================== | 1222 | new file mode 100644 |
1182 | 1223 | index 0000000..207342c | ||
1183 | 1126 | --- /dev/null | 1224 | --- /dev/null |
1184 | 1127 | +++ b/gdk/mir/gdkmirdisplay.c | 1225 | +++ b/gdk/mir/gdkmirdisplay.c |
1186 | 1128 | @@ -0,0 +1,565 @@ | 1226 | @@ -0,0 +1,549 @@ |
1187 | 1129 | +/* | 1227 | +/* |
1188 | 1130 | + * Copyright © 2014 Canonical Ltd | 1228 | + * Copyright © 2014 Canonical Ltd |
1189 | 1131 | + * | 1229 | + * |
1190 | @@ -1276,8 +1374,9 @@ | |||
1191 | 1276 | +{ | 1374 | +{ |
1192 | 1277 | + GdkMirDisplay *display = GDK_MIR_DISPLAY (object); | 1375 | + GdkMirDisplay *display = GDK_MIR_DISPLAY (object); |
1193 | 1278 | + | 1376 | + |
1196 | 1279 | + g_object_unref (display->screen); | 1377 | + g_clear_object (&display->screen); |
1197 | 1280 | + display->screen = NULL; | 1378 | + g_clear_object (&display->keymap); |
1198 | 1379 | + g_clear_pointer (&display->event_source, g_source_unref); | ||
1199 | 1281 | + | 1380 | + |
1200 | 1282 | + G_OBJECT_CLASS (gdk_mir_display_parent_class)->dispose (object); | 1381 | + G_OBJECT_CLASS (gdk_mir_display_parent_class)->dispose (object); |
1201 | 1283 | +} | 1382 | +} |
1202 | @@ -1505,21 +1604,6 @@ | |||
1203 | 1505 | +} | 1604 | +} |
1204 | 1506 | + | 1605 | + |
1205 | 1507 | +static void | 1606 | +static void |
1206 | 1508 | +gdk_mir_display_event_data_copy (GdkDisplay *display, | ||
1207 | 1509 | + const GdkEvent *src, | ||
1208 | 1510 | + GdkEvent *dst) | ||
1209 | 1511 | +{ | ||
1210 | 1512 | + //g_printerr ("gdk_mir_display_event_data_copy\n"); | ||
1211 | 1513 | +} | ||
1212 | 1514 | + | ||
1213 | 1515 | +static void | ||
1214 | 1516 | +gdk_mir_display_event_data_free (GdkDisplay *display, | ||
1215 | 1517 | + GdkEvent *event) | ||
1216 | 1518 | +{ | ||
1217 | 1519 | + //g_printerr ("gdk_mir_display_event_data_free\n"); | ||
1218 | 1520 | +} | ||
1219 | 1521 | + | ||
1220 | 1522 | +static void | ||
1221 | 1523 | +gdk_mir_display_create_window_impl (GdkDisplay *display, | 1607 | +gdk_mir_display_create_window_impl (GdkDisplay *display, |
1222 | 1524 | + GdkWindow *window, | 1608 | + GdkWindow *window, |
1223 | 1525 | + GdkWindow *real_parent, | 1609 | + GdkWindow *real_parent, |
1224 | @@ -1677,8 +1761,6 @@ | |||
1225 | 1677 | + display_class->after_process_all_updates = gdk_mir_display_after_process_all_updates; | 1761 | + display_class->after_process_all_updates = gdk_mir_display_after_process_all_updates; |
1226 | 1678 | + display_class->get_next_serial = gdk_mir_display_get_next_serial; | 1762 | + display_class->get_next_serial = gdk_mir_display_get_next_serial; |
1227 | 1679 | + display_class->notify_startup_complete = gdk_mir_display_notify_startup_complete; | 1763 | + display_class->notify_startup_complete = gdk_mir_display_notify_startup_complete; |
1228 | 1680 | + display_class->event_data_copy = gdk_mir_display_event_data_copy; | ||
1229 | 1681 | + display_class->event_data_free = gdk_mir_display_event_data_free; | ||
1230 | 1682 | + display_class->create_window_impl = gdk_mir_display_create_window_impl; | 1764 | + display_class->create_window_impl = gdk_mir_display_create_window_impl; |
1231 | 1683 | + display_class->get_keymap = gdk_mir_display_get_keymap; | 1765 | + display_class->get_keymap = gdk_mir_display_get_keymap; |
1232 | 1684 | + display_class->push_error_trap = gdk_mir_display_push_error_trap; | 1766 | + display_class->push_error_trap = gdk_mir_display_push_error_trap; |
1233 | @@ -1691,8 +1773,9 @@ | |||
1234 | 1691 | + display_class->text_property_to_utf8_list = gdk_mir_display_text_property_to_utf8_list; | 1773 | + display_class->text_property_to_utf8_list = gdk_mir_display_text_property_to_utf8_list; |
1235 | 1692 | + display_class->utf8_to_string_target = gdk_mir_display_utf8_to_string_target; | 1774 | + display_class->utf8_to_string_target = gdk_mir_display_utf8_to_string_target; |
1236 | 1693 | +} | 1775 | +} |
1239 | 1694 | Index: b/gdk/mir/gdkmireventsource.c | 1776 | diff --git a/gdk/mir/gdkmireventsource.c b/gdk/mir/gdkmireventsource.c |
1240 | 1695 | =================================================================== | 1777 | new file mode 100644 |
1241 | 1778 | index 0000000..cfe36e8 | ||
1242 | 1696 | --- /dev/null | 1779 | --- /dev/null |
1243 | 1697 | +++ b/gdk/mir/gdkmireventsource.c | 1780 | +++ b/gdk/mir/gdkmireventsource.c |
1244 | 1698 | @@ -0,0 +1,631 @@ | 1781 | @@ -0,0 +1,631 @@ |
1245 | @@ -1860,8 +1943,8 @@ | |||
1246 | 1860 | + event->scroll.y = y; | 1943 | + event->scroll.y = y; |
1247 | 1861 | + event->scroll.state = state; | 1944 | + event->scroll.state = state; |
1248 | 1862 | + event->scroll.direction = GDK_SCROLL_SMOOTH; | 1945 | + event->scroll.direction = GDK_SCROLL_SMOOTH; |
1251 | 1863 | + event->scroll.delta_x = delta_x; | 1946 | + event->scroll.delta_x = -delta_x; |
1252 | 1864 | + event->scroll.delta_y = delta_y; | 1947 | + event->scroll.delta_y = -delta_y; |
1253 | 1865 | + | 1948 | + |
1254 | 1866 | + send_event (window, get_pointer (window), event); | 1949 | + send_event (window, get_pointer (window), event); |
1255 | 1867 | +} | 1950 | +} |
1256 | @@ -2327,8 +2410,9 @@ | |||
1257 | 2327 | + | 2410 | + |
1258 | 2328 | + g_main_context_wakeup (NULL); | 2411 | + g_main_context_wakeup (NULL); |
1259 | 2329 | +} | 2412 | +} |
1262 | 2330 | Index: b/gdk/mir/gdkmirkeyboard.c | 2413 | diff --git a/gdk/mir/gdkmirkeyboard.c b/gdk/mir/gdkmirkeyboard.c |
1263 | 2331 | =================================================================== | 2414 | new file mode 100644 |
1264 | 2415 | index 0000000..86c0d9f | ||
1265 | 2332 | --- /dev/null | 2416 | --- /dev/null |
1266 | 2333 | +++ b/gdk/mir/gdkmirkeyboard.c | 2417 | +++ b/gdk/mir/gdkmirkeyboard.c |
1267 | 2334 | @@ -0,0 +1,173 @@ | 2418 | @@ -0,0 +1,173 @@ |
1268 | @@ -2505,8 +2589,9 @@ | |||
1269 | 2505 | + device_class->window_at_position = gdk_mir_keyboard_window_at_position; | 2589 | + device_class->window_at_position = gdk_mir_keyboard_window_at_position; |
1270 | 2506 | + device_class->select_window_events = gdk_mir_keyboard_select_window_events; | 2590 | + device_class->select_window_events = gdk_mir_keyboard_select_window_events; |
1271 | 2507 | +} | 2591 | +} |
1274 | 2508 | Index: b/gdk/mir/gdkmirkeymap.c | 2592 | diff --git a/gdk/mir/gdkmirkeymap.c b/gdk/mir/gdkmirkeymap.c |
1275 | 2509 | =================================================================== | 2593 | new file mode 100644 |
1276 | 2594 | index 0000000..3e8c829 | ||
1277 | 2510 | --- /dev/null | 2595 | --- /dev/null |
1278 | 2511 | +++ b/gdk/mir/gdkmirkeymap.c | 2596 | +++ b/gdk/mir/gdkmirkeymap.c |
1279 | 2512 | @@ -0,0 +1,466 @@ | 2597 | @@ -0,0 +1,466 @@ |
1280 | @@ -2976,8 +3061,9 @@ | |||
1281 | 2976 | + keymap_class->map_virtual_modifiers = gdk_mir_keymap_map_virtual_modifiers; | 3061 | + keymap_class->map_virtual_modifiers = gdk_mir_keymap_map_virtual_modifiers; |
1282 | 2977 | + keymap_class->get_modifier_state = gdk_mir_keymap_get_modifier_state; | 3062 | + keymap_class->get_modifier_state = gdk_mir_keymap_get_modifier_state; |
1283 | 2978 | +} | 3063 | +} |
1286 | 2979 | Index: b/gdk/mir/gdkmirpointer.c | 3064 | diff --git a/gdk/mir/gdkmirpointer.c b/gdk/mir/gdkmirpointer.c |
1287 | 2980 | =================================================================== | 3065 | new file mode 100644 |
1288 | 3066 | index 0000000..96c7e74 | ||
1289 | 2981 | --- /dev/null | 3067 | --- /dev/null |
1290 | 2982 | +++ b/gdk/mir/gdkmirpointer.c | 3068 | +++ b/gdk/mir/gdkmirpointer.c |
1291 | 2983 | @@ -0,0 +1,250 @@ | 3069 | @@ -0,0 +1,250 @@ |
1292 | @@ -3231,8 +3317,9 @@ | |||
1293 | 3231 | + device_class->window_at_position = gdk_mir_pointer_window_at_position; | 3317 | + device_class->window_at_position = gdk_mir_pointer_window_at_position; |
1294 | 3232 | + device_class->select_window_events = gdk_mir_pointer_select_window_events; | 3318 | + device_class->select_window_events = gdk_mir_pointer_select_window_events; |
1295 | 3233 | +} | 3319 | +} |
1298 | 3234 | Index: b/gdk/mir/gdkmirscreen.c | 3320 | diff --git a/gdk/mir/gdkmirscreen.c b/gdk/mir/gdkmirscreen.c |
1299 | 3235 | =================================================================== | 3321 | new file mode 100644 |
1300 | 3322 | index 0000000..2b53cef | ||
1301 | 3236 | --- /dev/null | 3323 | --- /dev/null |
1302 | 3237 | +++ b/gdk/mir/gdkmirscreen.c | 3324 | +++ b/gdk/mir/gdkmirscreen.c |
1303 | 3238 | @@ -0,0 +1,804 @@ | 3325 | @@ -0,0 +1,804 @@ |
1304 | @@ -4040,8 +4127,9 @@ | |||
1305 | 4040 | + screen_class->query_visual_types = gdk_mir_screen_query_visual_types; | 4127 | + screen_class->query_visual_types = gdk_mir_screen_query_visual_types; |
1306 | 4041 | + screen_class->get_monitor_scale_factor = gdk_mir_screen_get_monitor_scale_factor; | 4128 | + screen_class->get_monitor_scale_factor = gdk_mir_screen_get_monitor_scale_factor; |
1307 | 4042 | +} | 4129 | +} |
1310 | 4043 | Index: b/gdk/mir/gdkmirwindow.c | 4130 | diff --git a/gdk/mir/gdkmirwindow.c b/gdk/mir/gdkmirwindow.c |
1311 | 4044 | =================================================================== | 4131 | new file mode 100644 |
1312 | 4132 | index 0000000..03da7e0 | ||
1313 | 4045 | --- /dev/null | 4133 | --- /dev/null |
1314 | 4046 | +++ b/gdk/mir/gdkmirwindow.c | 4134 | +++ b/gdk/mir/gdkmirwindow.c |
1315 | 4047 | @@ -0,0 +1,52 @@ | 4135 | @@ -0,0 +1,52 @@ |
1316 | @@ -4097,8 +4185,9 @@ | |||
1317 | 4097 | +gdk_mir_window_class_init (GdkMirWindowClass *klass) | 4185 | +gdk_mir_window_class_init (GdkMirWindowClass *klass) |
1318 | 4098 | +{ | 4186 | +{ |
1319 | 4099 | +} | 4187 | +} |
1322 | 4100 | Index: b/gdk/mir/gdkmirwindowimpl.c | 4188 | diff --git a/gdk/mir/gdkmirwindowimpl.c b/gdk/mir/gdkmirwindowimpl.c |
1323 | 4101 | =================================================================== | 4189 | new file mode 100644 |
1324 | 4190 | index 0000000..418724b | ||
1325 | 4102 | --- /dev/null | 4191 | --- /dev/null |
1326 | 4103 | +++ b/gdk/mir/gdkmirwindowimpl.c | 4192 | +++ b/gdk/mir/gdkmirwindowimpl.c |
1327 | 4104 | @@ -0,0 +1,1336 @@ | 4193 | @@ -0,0 +1,1336 @@ |
1328 | @@ -5438,8 +5527,107 @@ | |||
1329 | 5438 | + impl_class->set_opaque_region = gdk_mir_window_impl_set_opaque_region; | 5527 | + impl_class->set_opaque_region = gdk_mir_window_impl_set_opaque_region; |
1330 | 5439 | + impl_class->set_shadow_width = gdk_mir_window_impl_set_shadow_width; | 5528 | + impl_class->set_shadow_width = gdk_mir_window_impl_set_shadow_width; |
1331 | 5440 | +} | 5529 | +} |
1334 | 5441 | Index: b/gtk/gtktooltip.c | 5530 | diff --git a/gdk/wayland/gdkdisplay-wayland.c b/gdk/wayland/gdkdisplay-wayland.c |
1335 | 5442 | =================================================================== | 5531 | index 5438a51..82c6ee1 100644 |
1336 | 5532 | --- a/gdk/wayland/gdkdisplay-wayland.c | ||
1337 | 5533 | +++ b/gdk/wayland/gdkdisplay-wayland.c | ||
1338 | 5534 | @@ -431,19 +431,6 @@ gdk_wayland_display_notify_startup_complete (GdkDisplay *display, | ||
1339 | 5535 | { | ||
1340 | 5536 | } | ||
1341 | 5537 | |||
1342 | 5538 | -static void | ||
1343 | 5539 | -gdk_wayland_display_event_data_copy (GdkDisplay *display, | ||
1344 | 5540 | - const GdkEvent *src, | ||
1345 | 5541 | - GdkEvent *dst) | ||
1346 | 5542 | -{ | ||
1347 | 5543 | -} | ||
1348 | 5544 | - | ||
1349 | 5545 | -static void | ||
1350 | 5546 | -gdk_wayland_display_event_data_free (GdkDisplay *display, | ||
1351 | 5547 | - GdkEvent *event) | ||
1352 | 5548 | -{ | ||
1353 | 5549 | -} | ||
1354 | 5550 | - | ||
1355 | 5551 | static GdkKeymap * | ||
1356 | 5552 | _gdk_wayland_display_get_keymap (GdkDisplay *display) | ||
1357 | 5553 | { | ||
1358 | 5554 | @@ -534,8 +521,6 @@ gdk_wayland_display_class_init (GdkWaylandDisplayClass * class) | ||
1359 | 5555 | display_class->after_process_all_updates = gdk_wayland_display_after_process_all_updates; | ||
1360 | 5556 | display_class->get_next_serial = gdk_wayland_display_get_next_serial; | ||
1361 | 5557 | display_class->notify_startup_complete = gdk_wayland_display_notify_startup_complete; | ||
1362 | 5558 | - display_class->event_data_copy = gdk_wayland_display_event_data_copy; | ||
1363 | 5559 | - display_class->event_data_free = gdk_wayland_display_event_data_free; | ||
1364 | 5560 | display_class->create_window_impl = _gdk_wayland_display_create_window_impl; | ||
1365 | 5561 | display_class->get_keymap = _gdk_wayland_display_get_keymap; | ||
1366 | 5562 | display_class->push_error_trap = gdk_wayland_display_push_error_trap; | ||
1367 | 5563 | diff --git a/gdk/win32/gdkdisplay-win32.c b/gdk/win32/gdkdisplay-win32.c | ||
1368 | 5564 | index 2d73c30..97d0e3e 100644 | ||
1369 | 5565 | --- a/gdk/win32/gdkdisplay-win32.c | ||
1370 | 5566 | +++ b/gdk/win32/gdkdisplay-win32.c | ||
1371 | 5567 | @@ -600,19 +600,6 @@ gdk_win32_display_notify_startup_complete (GdkDisplay *display, | ||
1372 | 5568 | /* nothing */ | ||
1373 | 5569 | } | ||
1374 | 5570 | static void | ||
1375 | 5571 | -gdk_win32_display_event_data_copy (GdkDisplay *display, | ||
1376 | 5572 | - const GdkEvent *src, | ||
1377 | 5573 | - GdkEvent *dst) | ||
1378 | 5574 | -{ | ||
1379 | 5575 | - /* nothing */ | ||
1380 | 5576 | -} | ||
1381 | 5577 | -static void | ||
1382 | 5578 | -gdk_win32_display_event_data_free (GdkDisplay *display, | ||
1383 | 5579 | - GdkEvent *event) | ||
1384 | 5580 | -{ | ||
1385 | 5581 | - /* nothing */ | ||
1386 | 5582 | -} | ||
1387 | 5583 | -static void | ||
1388 | 5584 | gdk_win32_display_push_error_trap (GdkDisplay *display) | ||
1389 | 5585 | { | ||
1390 | 5586 | /* nothing */ | ||
1391 | 5587 | @@ -665,8 +652,6 @@ gdk_win32_display_class_init (GdkWin32DisplayClass *klass) | ||
1392 | 5588 | display_class->after_process_all_updates = gdk_win32_display_after_process_all_updates; | ||
1393 | 5589 | display_class->get_next_serial = gdk_win32_display_get_next_serial; | ||
1394 | 5590 | display_class->notify_startup_complete = gdk_win32_display_notify_startup_complete; | ||
1395 | 5591 | - display_class->event_data_copy = gdk_win32_display_event_data_copy; | ||
1396 | 5592 | - display_class->event_data_free = gdk_win32_display_event_data_free; | ||
1397 | 5593 | display_class->create_window_impl = _gdk_win32_display_create_window_impl; | ||
1398 | 5594 | |||
1399 | 5595 | display_class->get_keymap = _gdk_win32_display_get_keymap; | ||
1400 | 5596 | diff --git a/gdk/x11/gdkdisplay-x11.c b/gdk/x11/gdkdisplay-x11.c | ||
1401 | 5597 | index 1db4742..ca9eb33 100644 | ||
1402 | 5598 | --- a/gdk/x11/gdkdisplay-x11.c | ||
1403 | 5599 | +++ b/gdk/x11/gdkdisplay-x11.c | ||
1404 | 5600 | @@ -2805,19 +2805,6 @@ gdk_x11_set_sm_client_id (const gchar *sm_client_id) | ||
1405 | 5601 | g_slist_free (displays); | ||
1406 | 5602 | } | ||
1407 | 5603 | |||
1408 | 5604 | -static void | ||
1409 | 5605 | -gdk_x11_display_event_data_copy (GdkDisplay *display, | ||
1410 | 5606 | - const GdkEvent *src, | ||
1411 | 5607 | - GdkEvent *dst) | ||
1412 | 5608 | -{ | ||
1413 | 5609 | -} | ||
1414 | 5610 | - | ||
1415 | 5611 | -static void | ||
1416 | 5612 | -gdk_x11_display_event_data_free (GdkDisplay *display, | ||
1417 | 5613 | - GdkEvent *event) | ||
1418 | 5614 | -{ | ||
1419 | 5615 | -} | ||
1420 | 5616 | - | ||
1421 | 5617 | static gint | ||
1422 | 5618 | pop_error_trap (GdkDisplay *display, | ||
1423 | 5619 | gboolean ignored) | ||
1424 | 5620 | @@ -2889,8 +2876,6 @@ gdk_x11_display_class_init (GdkX11DisplayClass * class) | ||
1425 | 5621 | display_class->after_process_all_updates = _gdk_x11_display_after_process_all_updates; | ||
1426 | 5622 | display_class->get_next_serial = gdk_x11_display_get_next_serial; | ||
1427 | 5623 | display_class->notify_startup_complete = gdk_x11_display_notify_startup_complete; | ||
1428 | 5624 | - display_class->event_data_copy = gdk_x11_display_event_data_copy; | ||
1429 | 5625 | - display_class->event_data_free = gdk_x11_display_event_data_free; | ||
1430 | 5626 | display_class->create_window_impl = _gdk_x11_display_create_window_impl; | ||
1431 | 5627 | display_class->get_keymap = gdk_x11_display_get_keymap; | ||
1432 | 5628 | display_class->push_error_trap = gdk_x11_display_error_trap_push; | ||
1433 | 5629 | diff --git a/gtk/gtktooltip.c b/gtk/gtktooltip.c | ||
1434 | 5630 | index 103944f..cedddaa 100644 | ||
1435 | 5443 | --- a/gtk/gtktooltip.c | 5631 | --- a/gtk/gtktooltip.c |
1436 | 5444 | +++ b/gtk/gtktooltip.c | 5632 | +++ b/gtk/gtktooltip.c |
1437 | 5445 | @@ -39,6 +39,9 @@ | 5633 | @@ -39,6 +39,9 @@ |
1438 | @@ -5452,23 +5640,53 @@ | |||
1439 | 5452 | 5640 | ||
1440 | 5453 | 5641 | ||
1441 | 5454 | /** | 5642 | /** |
1446 | 5455 | @@ -1162,6 +1165,19 @@ | 5643 | @@ -1168,6 +1171,19 @@ found: |
1447 | 5456 | { | 5644 | GTK_WINDOW (toplevel)); |
1448 | 5457 | GtkWidget *toplevel; | 5645 | } |
1449 | 5458 | 5646 | #endif | |
1450 | 5647 | +#ifdef GDK_WINDOWING_MIR | ||
1451 | 5648 | + /* Set the transient parent on the tooltip when running with the Mir | ||
1452 | 5649 | + * backend to allow correct positioning of the tooltip windows */ | ||
1453 | 5650 | + if (GDK_IS_MIR_DISPLAY (display)) | ||
1454 | 5651 | + { | ||
1455 | 5652 | + GtkWidget *toplevel; | ||
1456 | 5653 | + | ||
1457 | 5459 | + toplevel = gtk_widget_get_toplevel (tooltip->tooltip_widget); | 5654 | + toplevel = gtk_widget_get_toplevel (tooltip->tooltip_widget); |
1458 | 5460 | + if (GTK_IS_WINDOW (toplevel)) | 5655 | + if (GTK_IS_WINDOW (toplevel)) |
1459 | 5461 | + gtk_window_set_transient_for (GTK_WINDOW (tooltip->current_window), | 5656 | + gtk_window_set_transient_for (GTK_WINDOW (tooltip->current_window), |
1460 | 5462 | + GTK_WINDOW (toplevel)); | 5657 | + GTK_WINDOW (toplevel)); |
1461 | 5463 | + } | 5658 | + } |
1462 | 5464 | +#endif | 5659 | +#endif |
1473 | 5465 | +#ifdef GDK_WINDOWING_MIR | 5660 | |
1474 | 5466 | + /* Set the transient parent on the tooltip when running with the Mir | 5661 | x -= border.left; |
1475 | 5467 | + * backend to allow correct positioning of the tooltip windows */ | 5662 | y -= border.top; |
1476 | 5468 | + if (GDK_IS_MIR_DISPLAY (display)) | 5663 | diff --git a/gtk/gtkwindow.c b/gtk/gtkwindow.c |
1477 | 5469 | + { | 5664 | index e846c41..be5ae38 100644 |
1478 | 5470 | + GtkWidget *toplevel; | 5665 | --- a/gtk/gtkwindow.c |
1479 | 5471 | + | 5666 | +++ b/gtk/gtkwindow.c |
1480 | 5472 | toplevel = gtk_widget_get_toplevel (tooltip->tooltip_widget); | 5667 | @@ -79,6 +79,10 @@ |
1481 | 5473 | if (GTK_IS_WINDOW (toplevel)) | 5668 | #include "broadway/gdkbroadway.h" |
1482 | 5474 | gtk_window_set_transient_for (GTK_WINDOW (tooltip->current_window), | 5669 | #endif |
1483 | 5670 | |||
1484 | 5671 | +#ifdef GDK_WINDOWING_MIR | ||
1485 | 5672 | +#include "mir/gdkmir.h" | ||
1486 | 5673 | +#endif | ||
1487 | 5674 | + | ||
1488 | 5675 | /** | ||
1489 | 5676 | * SECTION:gtkwindow | ||
1490 | 5677 | * @title: GtkWindow | ||
1491 | 5678 | @@ -5683,6 +5687,11 @@ gtk_window_should_use_csd (GtkWindow *window) | ||
1492 | 5679 | return TRUE; | ||
1493 | 5680 | #endif | ||
1494 | 5681 | |||
1495 | 5682 | +#ifdef GDK_WINDOWING_MIR | ||
1496 | 5683 | + if (GDK_IS_MIR_DISPLAY (gtk_widget_get_display (GTK_WIDGET (window)))) | ||
1497 | 5684 | + return TRUE; | ||
1498 | 5685 | +#endif | ||
1499 | 5686 | + | ||
1500 | 5687 | csd_env = g_getenv ("GTK_CSD"); | ||
1501 | 5688 | |||
1502 | 5689 | return (g_strcmp0 (csd_env, "1") == 0); | ||
1503 | 5690 | -- | ||
1504 | 5691 | 2.1.3 | ||
1505 | 5692 | |||
1506 | 5475 | 5693 | ||
1507 | === modified file 'debian/patches/series' | |||
1508 | --- debian/patches/series 2014-12-11 09:57:23 +0000 | |||
1509 | +++ debian/patches/series 2014-12-13 16:59:39 +0000 | |||
1510 | @@ -19,5 +19,6 @@ | |||
1511 | 19 | x-canonical-accel.patch | 19 | x-canonical-accel.patch |
1512 | 20 | message-dialog-restore-traditional-look-on-unity.patch | 20 | message-dialog-restore-traditional-look-on-unity.patch |
1513 | 21 | mir-backend.patch | 21 | mir-backend.patch |
1514 | 22 | mir-backend-unmerged.patch | ||
1515 | 22 | 0001-gtkmodelmenuitem-force-icon-scaling.patch | 23 | 0001-gtkmodelmenuitem-force-icon-scaling.patch |
1516 | 23 | 0002-gtkimagemenuitem-force-icon-scaling.patch | 24 | 0002-gtkimagemenuitem-force-icon-scaling.patch |