aboutsummaryrefslogtreecommitdiffstats
path: root/sway/ipc-server.c
diff options
context:
space:
mode:
authorLibravatar Ian Fan <ianfan0@gmail.com>2018-10-12 21:14:52 +0100
committerLibravatar Ian Fan <ianfan0@gmail.com>2018-10-14 13:33:12 +0100
commit2f1fd8072673b1824f37759e14f5388d7a87fb5c (patch)
tree948b7912a2341c2d0b903258b444173b3fd4d1f3 /sway/ipc-server.c
parentswaybar: handle mode/hidden_state changes (diff)
downloadsway-2f1fd8072673b1824f37759e14f5388d7a87fb5c.tar.gz
sway-2f1fd8072673b1824f37759e14f5388d7a87fb5c.tar.zst
sway-2f1fd8072673b1824f37759e14f5388d7a87fb5c.zip
swaybar: show hidden bar on key event
Since wayland does not currently allow swaybar to create global keybinds, this is handled within sway and sent to the bar using a custom event, so as not to pollute existing events, called bar_state_update.
Diffstat (limited to 'sway/ipc-server.c')
-rw-r--r--sway/ipc-server.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/sway/ipc-server.c b/sway/ipc-server.c
index 2d915502..63c95503 100644
--- a/sway/ipc-server.c
+++ b/sway/ipc-server.c
@@ -349,6 +349,22 @@ void ipc_event_barconfig_update(struct bar_config *bar) {
349 json_object_put(json); 349 json_object_put(json);
350} 350}
351 351
352void ipc_event_bar_state_update(struct bar_config *bar) {
353 if (!ipc_has_event_listeners(IPC_EVENT_BAR_STATE_UPDATE)) {
354 return;
355 }
356 wlr_log(WLR_DEBUG, "Sending bar_state_update event");
357
358 json_object *json = json_object_new_object();
359 json_object_object_add(json, "id", json_object_new_string(bar->id));
360 json_object_object_add(json, "visible_by_modifier",
361 json_object_new_boolean(bar->visible_by_modifier));
362
363 const char *json_string = json_object_to_json_string(json);
364 ipc_send_event(json_string, IPC_EVENT_BAR_STATE_UPDATE);
365 json_object_put(json);
366}
367
352void ipc_event_mode(const char *mode, bool pango) { 368void ipc_event_mode(const char *mode, bool pango) {
353 if (!ipc_has_event_listeners(IPC_EVENT_MODE)) { 369 if (!ipc_has_event_listeners(IPC_EVENT_MODE)) {
354 return; 370 return;
@@ -651,6 +667,8 @@ void ipc_client_handle_command(struct ipc_client *client) {
651 client->subscribed_events |= event_mask(IPC_EVENT_WORKSPACE); 667 client->subscribed_events |= event_mask(IPC_EVENT_WORKSPACE);
652 } else if (strcmp(event_type, "barconfig_update") == 0) { 668 } else if (strcmp(event_type, "barconfig_update") == 0) {
653 client->subscribed_events |= event_mask(IPC_EVENT_BARCONFIG_UPDATE); 669 client->subscribed_events |= event_mask(IPC_EVENT_BARCONFIG_UPDATE);
670 } else if (strcmp(event_type, "bar_state_update") == 0) {
671 client->subscribed_events |= event_mask(IPC_EVENT_BAR_STATE_UPDATE);
654 } else if (strcmp(event_type, "mode") == 0) { 672 } else if (strcmp(event_type, "mode") == 0) {
655 client->subscribed_events |= event_mask(IPC_EVENT_MODE); 673 client->subscribed_events |= event_mask(IPC_EVENT_MODE);
656 } else if (strcmp(event_type, "shutdown") == 0) { 674 } else if (strcmp(event_type, "shutdown") == 0) {