aboutsummaryrefslogtreecommitdiff
path: root/sway/ipc-json.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2018-05-12 09:01:16 -0400
committerDrew DeVault <sir@cmpwn.com>2018-05-12 09:01:16 -0400
commit2da685e913432716f55cd537fd3d64f3fb3cc09a (patch)
treec986cca12ecdb3e3ac4d94d38205028788315889 /sway/ipc-json.c
parenta2d7079b263290ccc7259a0d16749dbd0baae821 (diff)
parent51b0b25587d69593eb77e3337e3fa459c1024f5c (diff)
Merge remote-tracking branch 'origin/master' into scdoc
Diffstat (limited to 'sway/ipc-json.c')
-rw-r--r--sway/ipc-json.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/sway/ipc-json.c b/sway/ipc-json.c
index ea7fd9ad..ad37216f 100644
--- a/sway/ipc-json.c
+++ b/sway/ipc-json.c
@@ -267,6 +267,31 @@ json_object *ipc_json_describe_input(struct sway_input_device *device) {
return object;
}
+json_object *ipc_json_describe_seat(struct sway_seat *seat) {
+ if (!(sway_assert(seat, "Seat must not be null"))) {
+ return NULL;
+ }
+
+ json_object *object = json_object_new_object();
+ struct sway_container *focus = seat_get_focus(seat);
+
+ json_object_object_add(object, "name",
+ json_object_new_string(seat->wlr_seat->name));
+ json_object_object_add(object, "capabilities",
+ json_object_new_int(seat->wlr_seat->capabilities));
+ json_object_object_add(object, "focus",
+ json_object_new_int(focus ? focus->id : 0));
+
+ json_object *devices = json_object_new_array();
+ struct sway_seat_device *device = NULL;
+ wl_list_for_each(device, &seat->devices, link) {
+ json_object_array_add(devices, ipc_json_describe_input(device->input_device));
+ }
+ json_object_object_add(object, "devices", devices);
+
+ return object;
+}
+
json_object *ipc_json_describe_bar_config(struct bar_config *bar) {
if (!sway_assert(bar, "Bar must not be NULL")) {
return NULL;