Merge pull request #1840 from ascent12/swaybar_scroll

Fix swaybar axis event logic
master
Drew DeVault 7 years ago committed by GitHub
commit 2d5fea1e80
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -156,31 +156,56 @@ static void wl_pointer_axis(void *data, struct wl_pointer *wl_pointer,
if (!sway_assert(output, "axis with no active output")) { if (!sway_assert(output, "axis with no active output")) {
return; return;
} }
double amt = wl_fixed_to_double(value); double amt = wl_fixed_to_double(value);
if (!bar->config->wrap_scroll) { if (amt == 0.0) {
int i = 0; return;
struct swaybar_workspace *ws = NULL; }
wl_list_for_each(ws, &output->workspaces, link) {
if (ws->focused) { struct swaybar_workspace *first = NULL;
break; struct swaybar_workspace *active = NULL;
} struct swaybar_workspace *last;
++i;
struct swaybar_workspace *iter;
wl_list_for_each(iter, &output->workspaces, link) {
if (!first) {
first = iter;
} }
int len = wl_list_length(&output->workspaces);
if (!sway_assert(i != len, "axis with null workspace")) { if (iter->visible) {
return; active = iter;
} }
if (i == 0 && amt > 0) {
return; // Do not wrap last = iter;
}
if (!sway_assert(active, "axis with null workspace")) {
return;
}
struct swaybar_workspace *new;
if (amt > 0.0) {
if (active == first) {
if (!bar->config->wrap_scroll) {
return;
}
new = last;
} }
if (i == len - 1 && amt < 0) {
return; // Do not wrap new = wl_container_of(active->link.prev, new, link);
} else {
if (active == last) {
if (!bar->config->wrap_scroll) {
return;
}
new = first;
} }
new = wl_container_of(active->link.next, new, link);
} }
const char *workspace_name = ipc_send_workspace_command(bar, new->name);
amt < 0 ? "prev_on_output" : "next_on_output";
ipc_send_workspace_command(bar, workspace_name);
} }
static void wl_pointer_frame(void *data, struct wl_pointer *wl_pointer) { static void wl_pointer_frame(void *data, struct wl_pointer *wl_pointer) {

Loading…
Cancel
Save