aboutsummaryrefslogtreecommitdiff
path: root/sway
diff options
context:
space:
mode:
Diffstat (limited to 'sway')
-rw-r--r--sway/desktop/xwayland.c5
-rw-r--r--sway/ipc-json.c23
-rw-r--r--sway/tree/view.c7
3 files changed, 35 insertions, 0 deletions
diff --git a/sway/desktop/xwayland.c b/sway/desktop/xwayland.c
index 5305ce12..d1aec084 100644
--- a/sway/desktop/xwayland.c
+++ b/sway/desktop/xwayland.c
@@ -171,6 +171,11 @@ static uint32_t get_int_prop(struct sway_view *view, enum sway_view_prop prop) {
switch (prop) {
case VIEW_PROP_X11_WINDOW_ID:
return view->wlr_xwayland_surface->window_id;
+ case VIEW_PROP_X11_PARENT_ID:
+ if (view->wlr_xwayland_surface->parent) {
+ return view->wlr_xwayland_surface->parent->window_id;
+ }
+ return 0;
case VIEW_PROP_WINDOW_TYPE:
return *view->wlr_xwayland_surface->window_type;
default:
diff --git a/sway/ipc-json.c b/sway/ipc-json.c
index a29647ed..2cd0cb2d 100644
--- a/sway/ipc-json.c
+++ b/sway/ipc-json.c
@@ -266,6 +266,29 @@ static void ipc_json_describe_view(struct sway_container *c, json_object *object
if (c->view->type == SWAY_VIEW_XWAYLAND) {
json_object_object_add(object, "window",
json_object_new_int(view_get_x11_window_id(c->view)));
+
+ json_object *window_props = json_object_new_object();
+
+ json_object_object_add(window_props, "class",
+ class ? json_object_new_string(class) : NULL);
+ const char *instance = view_get_instance(c->view);
+ json_object_object_add(window_props, "instance",
+ instance ? json_object_new_string(instance) : NULL);
+ json_object_object_add(window_props, "title",
+ c->title ? json_object_new_string(c->title) : NULL);
+
+ // the transient_for key is always present in i3's output
+ uint32_t parent_id = view_get_x11_parent_id(c->view);
+ json_object_object_add(window_props, "transient_for",
+ parent_id ? json_object_new_int(parent_id) : NULL);
+
+ const char *role = view_get_window_role(c->view);
+ if (role) {
+ json_object_object_add(window_props, "window_role",
+ json_object_new_string(role));
+ }
+
+ json_object_object_add(object, "window_properties", window_props);
}
#endif
}
diff --git a/sway/tree/view.c b/sway/tree/view.c
index a8486dd7..20babf7b 100644
--- a/sway/tree/view.c
+++ b/sway/tree/view.c
@@ -116,6 +116,13 @@ uint32_t view_get_x11_window_id(struct sway_view *view) {
}
return 0;
}
+
+uint32_t view_get_x11_parent_id(struct sway_view *view) {
+ if (view->impl->get_int_prop) {
+ return view->impl->get_int_prop(view, VIEW_PROP_X11_PARENT_ID);
+ }
+ return 0;
+}
#endif
const char *view_get_window_role(struct sway_view *view) {
if (view->impl->get_string_prop) {