diff options
author | Drew DeVault <[email protected]> | 2017-12-18 09:21:14 -0500 |
---|---|---|
committer | GitHub <[email protected]> | 2017-12-18 09:21:14 -0500 |
commit | 4fea223aba96c743726d509fee58ec8d8ff4a3d3 (patch) | |
tree | 85979d4c2b75698b919176884a35a1f129a92e7f /sway/ipc-server.c | |
parent | 1aab9ae3e74d15e2c346acbab2ef2def59db72eb (diff) | |
parent | 4e2ab531195f97370f417c6852a05be99eec2876 (diff) |
Merge pull request #1525 from emersion/ipc-get-outputs
Add IPC get_outputs
Diffstat (limited to 'sway/ipc-server.c')
-rw-r--r-- | sway/ipc-server.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/sway/ipc-server.c b/sway/ipc-server.c index 71f8dddd..b7cd2d76 100644 --- a/sway/ipc-server.c +++ b/sway/ipc-server.c @@ -343,6 +343,22 @@ void ipc_client_handle_command(struct ipc_client *client) { goto exit_cleanup; } + case IPC_GET_OUTPUTS: + { + json_object *outputs = json_object_new_array(); + for (int i = 0; i < root_container.children->length; ++i) { + swayc_t *container = root_container.children->items[i]; + if (container->type == C_OUTPUT) { + json_object_array_add(outputs, + ipc_json_describe_container(container)); + } + } + const char *json_string = json_object_to_json_string(outputs); + ipc_send_reply(client, json_string, (uint32_t) strlen(json_string)); + json_object_put(outputs); // free + goto exit_cleanup; + } + case IPC_GET_TREE: { json_object *tree = |