xserver: Read window properties in map request handler
This commit is contained in:
+19
-17
@@ -577,25 +577,13 @@ weston_xserver_surface_activate(struct wl_listener *listener, void *data)
|
|||||||
XCB_TIME_CURRENT_TIME);
|
XCB_TIME_CURRENT_TIME);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
weston_wm_handle_map_request(struct weston_wm *wm, xcb_generic_event_t *event)
|
|
||||||
{
|
|
||||||
xcb_map_request_event_t *map_request =
|
|
||||||
(xcb_map_request_event_t *) event;
|
|
||||||
|
|
||||||
fprintf(stderr, "XCB_MAP_REQUEST (window %d)\n", map_request->window);
|
|
||||||
|
|
||||||
xcb_map_window(wm->conn, map_request->window);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* We reuse some predefined, but otherwise useles atoms */
|
/* We reuse some predefined, but otherwise useles atoms */
|
||||||
#define TYPE_WM_PROTOCOLS XCB_ATOM_CUT_BUFFER0
|
#define TYPE_WM_PROTOCOLS XCB_ATOM_CUT_BUFFER0
|
||||||
|
|
||||||
static void
|
static void
|
||||||
weston_wm_handle_map_notify(struct weston_wm *wm, xcb_generic_event_t *event)
|
weston_wm_handle_map_request(struct weston_wm *wm, xcb_generic_event_t *event)
|
||||||
{
|
{
|
||||||
#define F(field) offsetof(struct weston_wm_window, field)
|
#define F(field) offsetof(struct weston_wm_window, field)
|
||||||
|
|
||||||
const struct {
|
const struct {
|
||||||
xcb_atom_t atom;
|
xcb_atom_t atom;
|
||||||
xcb_atom_t type;
|
xcb_atom_t type;
|
||||||
@@ -609,7 +597,8 @@ weston_wm_handle_map_notify(struct weston_wm *wm, xcb_generic_event_t *event)
|
|||||||
};
|
};
|
||||||
#undef F
|
#undef F
|
||||||
|
|
||||||
xcb_map_notify_event_t *map_notify = (xcb_map_notify_event_t *) event;
|
xcb_map_request_event_t *map_request =
|
||||||
|
(xcb_map_request_event_t *) event;
|
||||||
xcb_get_property_cookie_t cookie[ARRAY_LENGTH(props)];
|
xcb_get_property_cookie_t cookie[ARRAY_LENGTH(props)];
|
||||||
xcb_get_property_reply_t *reply;
|
xcb_get_property_reply_t *reply;
|
||||||
struct weston_wm_window *window;
|
struct weston_wm_window *window;
|
||||||
@@ -618,11 +607,11 @@ weston_wm_handle_map_notify(struct weston_wm *wm, xcb_generic_event_t *event)
|
|||||||
xcb_atom_t *atom;
|
xcb_atom_t *atom;
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
|
|
||||||
fprintf(stderr, "XCB_MAP_NOTIFY (window %d)\n", map_notify->window);
|
fprintf(stderr, "XCB_MAP_REQUEST (window %d)\n", map_request->window);
|
||||||
|
|
||||||
dump_window_properties(wm, map_notify->window);
|
dump_window_properties(wm, map_request->window);
|
||||||
|
|
||||||
window = hash_table_lookup(wm->window_hash, map_notify->window);
|
window = hash_table_lookup(wm->window_hash, map_request->window);
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_LENGTH(props); i++)
|
for (i = 0; i < ARRAY_LENGTH(props); i++)
|
||||||
cookie[i] = xcb_get_property(wm->conn,
|
cookie[i] = xcb_get_property(wm->conn,
|
||||||
@@ -672,6 +661,19 @@ weston_wm_handle_map_notify(struct weston_wm *wm, xcb_generic_event_t *event)
|
|||||||
fprintf(stderr, "window %d: name %s, class %s, transient_for %d\n",
|
fprintf(stderr, "window %d: name %s, class %s, transient_for %d\n",
|
||||||
window->id, window->name, window->class,
|
window->id, window->name, window->class,
|
||||||
window->transient_for ? window->transient_for->id : 0);
|
window->transient_for ? window->transient_for->id : 0);
|
||||||
|
|
||||||
|
xcb_map_window(wm->conn, map_request->window);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
weston_wm_handle_map_notify(struct weston_wm *wm, xcb_generic_event_t *event)
|
||||||
|
{
|
||||||
|
xcb_map_notify_event_t *map_notify = (xcb_map_notify_event_t *) event;
|
||||||
|
struct weston_wm_window *window;
|
||||||
|
|
||||||
|
fprintf(stderr, "XCB_MAP_NOTIFY (window %d)\n", map_notify->window);
|
||||||
|
|
||||||
|
window = hash_table_lookup(wm->window_hash, map_notify->window);
|
||||||
weston_wm_activate(wm, window, XCB_TIME_CURRENT_TIME);
|
weston_wm_activate(wm, window, XCB_TIME_CURRENT_TIME);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user