summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/xwayland/window-manager.c81
-rw-r--r--src/xwayland/xwayland.h3
2 files changed, 24 insertions, 60 deletions
diff --git a/src/xwayland/window-manager.c b/src/xwayland/window-manager.c
index dbab20f..378daee 100644
--- a/src/xwayland/window-manager.c
+++ b/src/xwayland/window-manager.c
@@ -139,8 +139,8 @@ get_atom_name(xcb_connection_t *c, xcb_atom_t atom)
}
void
-dump_property(struct weston_wm *wm, xcb_atom_t property,
- xcb_get_property_reply_t *reply)
+dump_property(struct weston_wm *wm,
+ xcb_atom_t property, xcb_get_property_reply_t *reply)
{
int32_t *incr_value;
const char *text_value, *name;
@@ -148,14 +148,14 @@ dump_property(struct weston_wm *wm, xcb_atom_t property,
int width, len;
uint32_t i;
- width = fprintf(stderr, " %s: ", get_atom_name(wm->conn, property));
+ width = fprintf(stderr, "%s: ", get_atom_name(wm->conn, property));
if (reply == NULL) {
fprintf(stderr, "(no reply)\n");
return;
}
width += fprintf(stderr,
- "type %s, format %d, length %d (value_len %d): ",
+ "%s/%d, length %d (value_len %d): ",
get_atom_name(wm->conn, reply->type),
reply->format,
xcb_get_property_value_length(reply),
@@ -191,42 +191,20 @@ dump_property(struct weston_wm *wm, xcb_atom_t property,
}
}
-static void
-dump_window_properties(struct weston_wm *wm, xcb_window_t window)
+void
+read_and_dump_property(struct weston_wm *wm,
+ xcb_window_t window, xcb_atom_t property)
{
- xcb_list_properties_cookie_t list_cookie;
- xcb_list_properties_reply_t *list_reply;
- xcb_get_property_cookie_t property_cookie;
- xcb_get_property_reply_t *property_reply;
- xcb_atom_t *atoms;
- int i, length;
-
- list_cookie = xcb_list_properties(wm->conn, window);
- list_reply = xcb_list_properties_reply(wm->conn, list_cookie, NULL);
- if (!list_reply)
- /* Bad window, typically */
- return;
-
- length = xcb_list_properties_atoms_length(list_reply);
- atoms = xcb_list_properties_atoms(list_reply);
-
- for (i = 0; i < length; i++) {
- property_cookie =
- xcb_get_property(wm->conn,
- 0, /* delete */
- window,
- atoms[i],
- XCB_ATOM_ANY,
- 0, 2048);
+ xcb_get_property_reply_t *reply;
+ xcb_get_property_cookie_t cookie;
- property_reply = xcb_get_property_reply(wm->conn,
- property_cookie, NULL);
- dump_property(wm, atoms[i], property_reply);
+ cookie = xcb_get_property(wm->conn, 0, window,
+ property, XCB_ATOM_ANY, 0, 2048);
+ reply = xcb_get_property_reply(wm->conn, cookie, NULL);
- free(property_reply);
- }
+ dump_property(wm, property, reply);
- free(list_reply);
+ free(reply);
}
/* We reuse some predefined, but otherwise useles atoms */
@@ -266,8 +244,6 @@ weston_wm_window_read_properties(struct weston_wm_window *window)
return;
window->properties_dirty = 0;
- dump_window_properties(wm, window->id);
-
for (i = 0; i < ARRAY_LENGTH(props); i++)
cookie[i] = xcb_get_property(wm->conn,
0, /* delete */
@@ -648,29 +624,14 @@ weston_wm_handle_property_notify(struct weston_wm *wm, xcb_generic_event_t *even
if (window)
window->properties_dirty = 1;
- if (property_notify->atom == XCB_ATOM_WM_CLASS) {
- fprintf(stderr, "wm_class changed\n");
- } else if (property_notify->atom == XCB_ATOM_WM_TRANSIENT_FOR) {
- fprintf(stderr, "wm_transient_for changed\n");
- } else if (property_notify->atom == wm->atom.wm_protocols) {
- fprintf(stderr, "wm_protocols changed\n");
- } else if (property_notify->atom == wm->atom.net_wm_name) {
- fprintf(stderr, "_net_wm_name changed\n");
- weston_wm_window_schedule_repaint(window);
- } else if (property_notify->atom == wm->atom.net_wm_user_time) {
- fprintf(stderr, "_net_wm_user_time changed\n");
- } else if (property_notify->atom == wm->atom.net_wm_icon_name) {
- fprintf(stderr, "_net_wm_icon_name changed\n");
- } else if (property_notify->atom == XCB_ATOM_WM_NAME) {
- fprintf(stderr, "wm_name changed\n");
+ fprintf(stderr, "XCB_PROPERTY_NOTIFY: window %d, ",
+ property_notify->window);
+ read_and_dump_property(wm, property_notify->window,
+ property_notify->atom);
+
+ if (property_notify->atom == wm->atom.net_wm_name ||
+ property_notify->atom == XCB_ATOM_WM_NAME)
weston_wm_window_schedule_repaint(window);
- } else if (property_notify->atom == XCB_ATOM_WM_ICON_NAME) {
- fprintf(stderr, "wm_icon_name changed\n");
- } else {
- fprintf(stderr, "XCB_PROPERTY_NOTIFY: "
- "unhandled property change: %s\n",
- get_atom_name(wm->conn, property_notify->atom));
- }
}
static void
diff --git a/src/xwayland/xwayland.h b/src/xwayland/xwayland.h
index 72a25cc..26be7de 100644
--- a/src/xwayland/xwayland.h
+++ b/src/xwayland/xwayland.h
@@ -122,6 +122,9 @@ struct weston_wm {
void
dump_property(struct weston_wm *wm, xcb_atom_t property,
xcb_get_property_reply_t *reply);
+void
+read_and_dump_property(struct weston_wm *wm,
+ xcb_window_t window, xcb_atom_t property);
const char *
get_atom_name(xcb_connection_t *c, xcb_atom_t atom);