all repos — st @ 2bd6afd1c9eb341d9e2c5d89bc16bb7758691e1f

st (suckless terminal) config

Implementing 8 bit mode for meta.
Christoph Lohmann 20h@r-36.net
commit

2bd6afd1c9eb341d9e2c5d89bc16bb7758691e1f

parent

b596d6ba3c50bc379adc298a4e2ba7c122b116ab

2 files changed, 22 insertions(+), 4 deletions(-)

jump to
M st.cst.c

@@ -114,6 +114,7 @@ MODE_HIDE = 512,

MODE_ECHO = 1024, MODE_APPCURSOR = 2048, MODE_MOUSESGR = 4096, + MODE_8BIT = 8192, }; enum escape_state {

@@ -1649,6 +1650,9 @@ MODBIT(term.mode, 0, MODE_MOUSEBTN);

break; case 1006: MODBIT(term.mode, set, MODE_MOUSESGR); + break; + case 1034: + MODBIT(term.mode, set, MODE_8BIT); break; case 1049: /* = 1047 and 1048 */ case 47:

@@ -3228,7 +3232,8 @@ kpress(XEvent *ev) {

XKeyEvent *e = &ev->xkey; KeySym ksym; char xstr[31], buf[32], *customkey, *cp = buf; - int len; + int len, ret; + long c; Status status; Shortcut *bp;

@@ -3249,13 +3254,23 @@ /* 2. custom keys from config.h */

if((customkey = kmap(ksym, e->state))) { len = strlen(customkey); memcpy(buf, customkey, len); - /* 2. hardcoded (overrides X lookup) */ + /* 3. hardcoded (overrides X lookup) */ } else { if(len == 0) return; - if(len == 1 && e->state & Mod1Mask) - *cp++ = '\033'; + if(len == 1 && e->state & Mod1Mask) { + if(IS_SET(MODE_8BIT)) { + if(*xstr < 0177) { + c = *xstr | B7; + ret = utf8encode(&c, cp); + cp += ret; + len = 0; + } + } else { + *cp++ = '\033'; + } + } memcpy(cp, xstr, len); len = cp - buf + len;
M st.infost.info

@@ -147,6 +147,7 @@ krmir=\E[2;2~,

kich1=\E[2~, knp=\E[6~, kmous=\E[M, + km, kpp=\E[5~, lines#24, mir,

@@ -162,6 +163,7 @@ rmacs=\E(B,

rmcup=\E[?1049l, rmir=\E[4l, rmkx=\E[?1l\E>, + rmm=\E[?1034l, rmso=\E[27m, rmul=\E[m, rs1=\Ec,

@@ -178,6 +180,7 @@ smacs=\E(0,

smcup=\E[?1049h, smir=\E[4h, smkx=\E[?1h\E=, + smm=\E[?1034h, smso=\E[7m, smul=\E[4m, tbc=\E[3g,