aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2016-07-23 11:03:21 -0400
committerGitHub <noreply@github.com>2016-07-23 11:03:21 -0400
commit4637462a6860cebcbf0ff196f84363a452db651d (patch)
tree244e42bdff3616734f34a9ab4314eb272f12dd78
parent643bd8f15816d0443f3e8d2a32ef6b20547cd389 (diff)
parent80858c1f5784c65548c96b8f4d4bd02e90f7dd88 (diff)
downloadsway-4637462a6860cebcbf0ff196f84363a452db651d.tar.xz
Merge pull request #785 from thejan2009/floating-scroll-event-passthrough
don't passthrough a floating_scroll event to focused window
-rw-r--r--sway/handlers.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/sway/handlers.c b/sway/handlers.c
index abed8cd7..05da5700 100644
--- a/sway/handlers.c
+++ b/sway/handlers.c
@@ -876,15 +876,21 @@ bool handle_pointer_scroll(wlc_handle view, uint32_t time, const struct wlc_modi
if (!(modifiers->mods ^ config->floating_mod)) {
int x_amount = (int)_amount[0];
int y_amount = (int)_amount[1];
- if (x_amount > 0) {
+
+ if (x_amount > 0 && strcmp(config->floating_scroll_up_cmd, "")) {
handle_command(config->floating_scroll_up_cmd);
- } else if (x_amount < 0) {
+ return EVENT_HANDLED;
+ } else if (x_amount < 0 && strcmp(config->floating_scroll_down_cmd, "")) {
handle_command(config->floating_scroll_down_cmd);
+ return EVENT_HANDLED;
}
- if (y_amount > 0) {
+
+ if (y_amount > 0 && strcmp(config->floating_scroll_right_cmd, "")) {
handle_command(config->floating_scroll_right_cmd);
- } else if (y_amount < 0) {
+ return EVENT_HANDLED;
+ } else if (y_amount < 0 && strcmp(config->floating_scroll_left_cmd, "")) {
handle_command(config->floating_scroll_left_cmd);
+ return EVENT_HANDLED;
}
}
return EVENT_PASSTHROUGH;