aboutsummaryrefslogtreecommitdiffstats
path: root/swaybar/ipc.c
diff options
context:
space:
mode:
authorLibravatar Ian Fan <ianfan0@gmail.com>2018-09-24 18:42:25 +0100
committerLibravatar Ian Fan <ianfan0@gmail.com>2018-09-28 13:48:59 +0100
commit312d009f656e86401cda1c6198b929e4cbd85d2f (patch)
tree4ac796d0f654d29416a1906e70b05d79e1a0641a /swaybar/ipc.c
parentMerge pull request #2722 from RyanDwyer/workspace-configs (diff)
downloadsway-312d009f656e86401cda1c6198b929e4cbd85d2f.tar.gz
sway-312d009f656e86401cda1c6198b929e4cbd85d2f.tar.zst
sway-312d009f656e86401cda1c6198b929e4cbd85d2f.zip
swaybar: fail if bar id is invalid
Diffstat (limited to 'swaybar/ipc.c')
-rw-r--r--swaybar/ipc.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/swaybar/ipc.c b/swaybar/ipc.c
index 0e60c10c..2b50528d 100644
--- a/swaybar/ipc.c
+++ b/swaybar/ipc.c
@@ -141,9 +141,16 @@ static void ipc_parse_colors(
141 } 141 }
142} 142}
143 143
144static void ipc_parse_config( 144static bool ipc_parse_config(
145 struct swaybar_config *config, const char *payload) { 145 struct swaybar_config *config, const char *payload) {
146 json_object *bar_config = json_tokener_parse(payload); 146 json_object *bar_config = json_tokener_parse(payload);
147 json_object *success;
148 if (json_object_object_get_ex(bar_config, "success", &success)
149 && !json_object_get_boolean(success)) {
150 wlr_log(WLR_ERROR, "No bar with that ID. Use 'swaymsg -t get_bar_config to get the available bar configs.");
151 json_object_put(bar_config);
152 return false;
153 }
147 json_object *markup, *mode, *hidden_bar, *position, *status_command; 154 json_object *markup, *mode, *hidden_bar, *position, *status_command;
148 json_object *font, *bar_height, *wrap_scroll, *workspace_buttons, *strip_workspace_numbers; 155 json_object *font, *bar_height, *wrap_scroll, *workspace_buttons, *strip_workspace_numbers;
149 json_object *binding_mode_indicator, *verbose, *colors, *sep_symbol, *outputs; 156 json_object *binding_mode_indicator, *verbose, *colors, *sep_symbol, *outputs;
@@ -226,6 +233,7 @@ static void ipc_parse_config(
226 } 233 }
227 234
228 json_object_put(bar_config); 235 json_object_put(bar_config);
236 return true;
229} 237}
230 238
231void ipc_get_workspaces(struct swaybar *bar) { 239void ipc_get_workspaces(struct swaybar *bar) {
@@ -312,11 +320,14 @@ static void ipc_get_outputs(struct swaybar *bar) {
312 free(res); 320 free(res);
313} 321}
314 322
315void ipc_initialize(struct swaybar *bar, const char *bar_id) { 323bool ipc_initialize(struct swaybar *bar, const char *bar_id) {
316 uint32_t len = strlen(bar_id); 324 uint32_t len = strlen(bar_id);
317 char *res = ipc_single_command(bar->ipc_socketfd, 325 char *res = ipc_single_command(bar->ipc_socketfd,
318 IPC_GET_BAR_CONFIG, bar_id, &len); 326 IPC_GET_BAR_CONFIG, bar_id, &len);
319 ipc_parse_config(bar->config, res); 327 if (!ipc_parse_config(bar->config, res)) {
328 free(res);
329 return false;
330 }
320 free(res); 331 free(res);
321 ipc_get_outputs(bar); 332 ipc_get_outputs(bar);
322 333
@@ -324,6 +335,7 @@ void ipc_initialize(struct swaybar *bar, const char *bar_id) {
324 len = strlen(subscribe); 335 len = strlen(subscribe);
325 free(ipc_single_command(bar->ipc_event_socketfd, 336 free(ipc_single_command(bar->ipc_event_socketfd,
326 IPC_SUBSCRIBE, subscribe, &len)); 337 IPC_SUBSCRIBE, subscribe, &len));
338 return true;
327} 339}
328 340
329bool handle_ipc_readable(struct swaybar *bar) { 341bool handle_ipc_readable(struct swaybar *bar) {