Merge pull request #2749 from ianyfan/swaybar

swaybar: add leading comma to click event JSON
This commit is contained in:
Drew DeVault 2018-10-02 17:00:33 +02:00 committed by GitHub
commit 4e4d0c5191
Failed to generate hash of commit
2 changed files with 4 additions and 2 deletions

View file

@ -23,6 +23,7 @@ struct status_line {
struct wl_list blocks; // i3bar_block::link struct wl_list blocks; // i3bar_block::link
bool click_events; bool click_events;
bool clicked;
char *buffer; char *buffer;
size_t buffer_size; size_t buffer_size;
size_t buffer_index; size_t buffer_index;

View file

@ -260,7 +260,7 @@ bool i3bar_handle_readable(struct status_line *status) {
enum hotspot_event_handling i3bar_block_send_click(struct status_line *status, enum hotspot_event_handling i3bar_block_send_click(struct status_line *status,
struct i3bar_block *block, int x, int y, enum x11_button button) { struct i3bar_block *block, int x, int y, enum x11_button button) {
wlr_log(WLR_DEBUG, "block %s clicked", block->name ? block->name : "(nil)"); wlr_log(WLR_DEBUG, "block %s clicked", block->name);
if (!block->name || !status->click_events) { if (!block->name || !status->click_events) {
return HOTSPOT_PROCESS; return HOTSPOT_PROCESS;
} }
@ -276,10 +276,11 @@ enum hotspot_event_handling i3bar_block_send_click(struct status_line *status,
json_object_object_add(event_json, "button", json_object_new_int(button)); json_object_object_add(event_json, "button", json_object_new_int(button));
json_object_object_add(event_json, "x", json_object_new_int(x)); json_object_object_add(event_json, "x", json_object_new_int(x));
json_object_object_add(event_json, "y", json_object_new_int(y)); json_object_object_add(event_json, "y", json_object_new_int(y));
if (dprintf(status->write_fd, "%s,\n", if (dprintf(status->write_fd, "%s%s\n", status->clicked ? "," : "",
json_object_to_json_string(event_json)) < 0) { json_object_to_json_string(event_json)) < 0) {
status_error(status, "[failed to write click event]"); status_error(status, "[failed to write click event]");
} }
status->clicked = true;
json_object_put(event_json); json_object_put(event_json);
return HOTSPOT_IGNORE; return HOTSPOT_IGNORE;
} }