| @ -0,0 +1,90 @@ | |||||
| From 9726b1e58352126252412e101432e64d46fc51ca Mon Sep 17 00:00:00 2001 | |||||
| From: Dennis Lee <dennis@dennislee.xyz> | |||||
| Date: Sun, 28 Jun 2020 23:01:03 -0700 | |||||
| Subject: [PATCH] universcroll: mouse wheel only scroll in all modes | |||||
| Scroll normally via scroll(1), without Shift, when outside of | |||||
| `MODE_ALTSCREEN`. Inside an alt screen, continue to scroll normally | |||||
| without Shift; in this mode, your scrolling is automatically translated | |||||
| into ^Y and ^E. It just werks! | |||||
| Based on the existing mouse-altscreen patch | |||||
| https://st.suckless.org/patches/scrollback/ | |||||
| adapted for st(1) 0.8.4 and scroll(1). | |||||
| --- | |||||
| config.def.h | 10 +++++----- | |||||
| st.c | 5 +++++ | |||||
| st.h | 1 + | |||||
| x.c | 2 ++ | |||||
| 4 files changed, 13 insertions(+), 5 deletions(-) | |||||
| diff --git a/config.def.h b/config.def.h | |||||
| index 6f05dce..62e87da 100644 | |||||
| --- a/config.def.h | |||||
| +++ b/config.def.h | |||||
| @@ -173,11 +173,11 @@ static uint forcemousemod = ShiftMask; | |||||
| * Beware that overloading Button1 will disable the selection. | |||||
| */ | |||||
| static MouseShortcut mshortcuts[] = { | |||||
| - /* mask button function argument release */ | |||||
| - { XK_ANY_MOD, Button2, selpaste, {.i = 0}, 1 }, | |||||
| - { ShiftMask, Button4, ttysend, {.s = "\033[5;2~"} }, | |||||
| + /* mask button function argument release alt */ | |||||
| + { XK_ANY_MOD, Button2, selpaste, {.i = 0}, 1 }, | |||||
| + { XK_ANY_MOD, Button4, ttysend, {.s = "\033[5;2~"}, 0, -1 }, | |||||
| { XK_ANY_MOD, Button4, ttysend, {.s = "\031"} }, | |||||
| - { ShiftMask, Button5, ttysend, {.s = "\033[6;2~"} }, | |||||
| + { XK_ANY_MOD, Button5, ttysend, {.s = "\033[6;2~"}, 0, -1 }, | |||||
| { XK_ANY_MOD, Button5, ttysend, {.s = "\005"} }, | |||||
| }; | |||||
| diff --git a/st.c b/st.c | |||||
| index 76b7e0d..1f65453 100644 | |||||
| --- a/st.c | |||||
| +++ b/st.c | |||||
| @@ -1047,6 +1047,11 @@ tnew(int col, int row) | |||||
| treset(); | |||||
| } | |||||
| +int tisaltscr(void) | |||||
| +{ | |||||
| + return IS_SET(MODE_ALTSCREEN); | |||||
| +} | |||||
| + | |||||
| void | |||||
| tswapscreen(void) | |||||
| { | |||||
| diff --git a/st.h b/st.h | |||||
| index 3d351b6..39cc054 100644 | |||||
| --- a/st.h | |||||
| +++ b/st.h | |||||
| @@ -87,6 +87,7 @@ void sendbreak(const Arg *); | |||||
| void toggleprinter(const Arg *); | |||||
| int tattrset(int); | |||||
| +int tisaltscr(void); | |||||
| void tnew(int, int); | |||||
| void tresize(int, int); | |||||
| void tsetdirtattr(int); | |||||
| diff --git a/x.c b/x.c | |||||
| index 210f184..210dde9 100644 | |||||
| --- a/x.c | |||||
| +++ b/x.c | |||||
| @@ -34,6 +34,7 @@ typedef struct { | |||||
| void (*func)(const Arg *); | |||||
| const Arg arg; | |||||
| uint release; | |||||
| + int altscrn; /* 0: don't care, -1: not alt screen, 1: alt screen */ | |||||
| } MouseShortcut; | |||||
| typedef struct { | |||||
| @@ -446,6 +447,7 @@ mouseaction(XEvent *e, uint release) | |||||
| for (ms = mshortcuts; ms < mshortcuts + LEN(mshortcuts); ms++) { | |||||
| if (ms->release == release && | |||||
| ms->button == e->xbutton.button && | |||||
| + (!ms->altscrn || (ms->altscrn == (tisaltscr() ? 1 : -1))) && | |||||
| (match(ms->mod, state) || /* exact or forced */ | |||||
| match(ms->mod, state & ~forcemousemod))) { | |||||
| ms->func(&(ms->arg)); | |||||
| -- | |||||
| 2.27.0 | |||||