| st-universcroll-0.8.4.diff - sites - public wiki contents of suckless.org | |
| git clone git://git.suckless.org/sites | |
| Log | |
| Files | |
| Refs | |
| --- | |
| st-universcroll-0.8.4.diff (2954B) | |
| --- | |
| 1 From 9726b1e58352126252412e101432e64d46fc51ca Mon Sep 17 00:00:00 2001 | |
| 2 From: Dennis Lee <[email protected]> | |
| 3 Date: Sun, 28 Jun 2020 23:01:03 -0700 | |
| 4 Subject: [PATCH] universcroll: mouse wheel only scroll in all modes | |
| 5 | |
| 6 Scroll normally via scroll(1), without Shift, when outside of | |
| 7 `MODE_ALTSCREEN`. Inside an alt screen, continue to scroll normally | |
| 8 without Shift; in this mode, your scrolling is automatically translated | |
| 9 into ^Y and ^E. It just werks! | |
| 10 | |
| 11 Based on the existing mouse-altscreen patch | |
| 12 https://st.suckless.org/patches/scrollback/ | |
| 13 adapted for st(1) 0.8.4 and scroll(1). | |
| 14 --- | |
| 15 config.def.h | 10 +++++----- | |
| 16 st.c | 5 +++++ | |
| 17 st.h | 1 + | |
| 18 x.c | 2 ++ | |
| 19 4 files changed, 13 insertions(+), 5 deletions(-) | |
| 20 | |
| 21 diff --git a/config.def.h b/config.def.h | |
| 22 index 6f05dce..62e87da 100644 | |
| 23 --- a/config.def.h | |
| 24 +++ b/config.def.h | |
| 25 @@ -173,11 +173,11 @@ static uint forcemousemod = ShiftMask; | |
| 26 * Beware that overloading Button1 will disable the selection. | |
| 27 */ | |
| 28 static MouseShortcut mshortcuts[] = { | |
| 29 - /* mask button function argument … | |
| 30 - { XK_ANY_MOD, Button2, selpaste, {.i = 0}, … | |
| 31 - { ShiftMask, Button4, ttysend, {.s = "\033[5;… | |
| 32 + /* mask button function argument … | |
| 33 + { XK_ANY_MOD, Button2, selpaste, {.i = 0}, … | |
| 34 + { XK_ANY_MOD, Button4, ttysend, {.s = "\033[5;… | |
| 35 { XK_ANY_MOD, Button4, ttysend, {.s = "\031"} … | |
| 36 - { ShiftMask, Button5, ttysend, {.s = "\033[6;… | |
| 37 + { XK_ANY_MOD, Button5, ttysend, {.s = "\033[6;… | |
| 38 { XK_ANY_MOD, Button5, ttysend, {.s = "\005"} … | |
| 39 }; | |
| 40 | |
| 41 diff --git a/st.c b/st.c | |
| 42 index 76b7e0d..1f65453 100644 | |
| 43 --- a/st.c | |
| 44 +++ b/st.c | |
| 45 @@ -1047,6 +1047,11 @@ tnew(int col, int row) | |
| 46 treset(); | |
| 47 } | |
| 48 | |
| 49 +int tisaltscr(void) | |
| 50 +{ | |
| 51 + return IS_SET(MODE_ALTSCREEN); | |
| 52 +} | |
| 53 + | |
| 54 void | |
| 55 tswapscreen(void) | |
| 56 { | |
| 57 diff --git a/st.h b/st.h | |
| 58 index 3d351b6..39cc054 100644 | |
| 59 --- a/st.h | |
| 60 +++ b/st.h | |
| 61 @@ -87,6 +87,7 @@ void sendbreak(const Arg *); | |
| 62 void toggleprinter(const Arg *); | |
| 63 | |
| 64 int tattrset(int); | |
| 65 +int tisaltscr(void); | |
| 66 void tnew(int, int); | |
| 67 void tresize(int, int); | |
| 68 void tsetdirtattr(int); | |
| 69 diff --git a/x.c b/x.c | |
| 70 index 210f184..210dde9 100644 | |
| 71 --- a/x.c | |
| 72 +++ b/x.c | |
| 73 @@ -34,6 +34,7 @@ typedef struct { | |
| 74 void (*func)(const Arg *); | |
| 75 const Arg arg; | |
| 76 uint release; | |
| 77 + int altscrn; /* 0: don't care, -1: not alt screen, 1: alt scr… | |
| 78 } MouseShortcut; | |
| 79 | |
| 80 typedef struct { | |
| 81 @@ -446,6 +447,7 @@ mouseaction(XEvent *e, uint release) | |
| 82 for (ms = mshortcuts; ms < mshortcuts + LEN(mshortcuts); ms++) { | |
| 83 if (ms->release == release && | |
| 84 ms->button == e->xbutton.button && | |
| 85 + (!ms->altscrn || (ms->altscrn == (tisaltscr() ? 1 :… | |
| 86 (match(ms->mod, state) || /* exact or forced */ | |
| 87 match(ms->mod, state & ~forcemousemod))) { | |
| 88 ms->func(&(ms->arg)); | |
| 89 -- | |
| 90 2.27.0 |