aboutsummaryrefslogtreecommitdiff
path: root/sway/ipc-server.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2018-05-12 09:00:32 -0400
committerGitHub <noreply@github.com>2018-05-12 09:00:32 -0400
commit51b0b25587d69593eb77e3337e3fa459c1024f5c (patch)
tree77c93c14fbbe1e4df15c957c63baefcfe6473669 /sway/ipc-server.c
parent32a572cecfd0f6072a78ce0a381a2f8365f9010a (diff)
parent28eb97299e564daee96d3af1f9130d6439f170f6 (diff)
downloadsway-51b0b25587d69593eb77e3337e3fa459c1024f5c.tar.xz
Merge pull request #1959 from RyanDwyer/ipc-get-seats
Implement IPC get_seats command
Diffstat (limited to 'sway/ipc-server.c')
-rw-r--r--sway/ipc-server.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/sway/ipc-server.c b/sway/ipc-server.c
index 39d1d0a7..8734e8f8 100644
--- a/sway/ipc-server.c
+++ b/sway/ipc-server.c
@@ -546,6 +546,19 @@ void ipc_client_handle_command(struct ipc_client *client) {
goto exit_cleanup;
}
+ case IPC_GET_SEATS:
+ {
+ json_object *seats = json_object_new_array();
+ struct sway_seat *seat = NULL;
+ wl_list_for_each(seat, &input_manager->seats, link) {
+ json_object_array_add(seats, ipc_json_describe_seat(seat));
+ }
+ const char *json_string = json_object_to_json_string(seats);
+ ipc_send_reply(client, json_string, (uint32_t)strlen(json_string));
+ json_object_put(seats); // free
+ goto exit_cleanup;
+ }
+
case IPC_GET_TREE:
{
json_object *tree =