shithub: riscv

Download patch

ref: b1da2bb10b9ea941aeee2dfcb5ac1540e9169770
parent: 93c6f8cb0dbd4386aea73773933d917848922a1b
author: Sigrid <[email protected]>
date: Tue Dec 8 09:32:28 EST 2020

vncv: do NOT map Kaltgr to meta, introduce Mod4 (Super) as an extra key to use instead

--- a/sys/src/cmd/vnc/kbdv.c
+++ b/sys/src/cmd/vnc/kbdv.c
@@ -6,7 +6,8 @@
 	Xshift = 0xFFE1,
 	Xctl = 0xFFE3,
 	Xmeta = 0xFFE7,
-	Xalt = 0xFFE9
+	Xalt = 0xFFE9,
+	Xsuper = 0xFFEB,
 };
 
 static struct {
@@ -41,10 +42,11 @@
 	{KF|10,	0xffc7},
 	{KF|11,	0xffc8},
 	{KF|12,	0xffc9},
+	{Kaltgr, 0xfe03},
 
 	{Kshift, Xshift},
 	{Kalt, Xalt},
-	{Kaltgr, Xmeta},
+	{Kmod4, Xsuper},
 	{Kctl, Xctl},
 };
 
@@ -95,7 +97,7 @@
 {
 	char buf[256], k[10];
 	ulong ks;
-	int ctlfd, fd, kr, kn, w, shift, ctl, alt;
+	int ctlfd, fd, kr, kn, w, shift, ctl, alt, mod4;
 	Rune r;
 
 	snprint(buf, sizeof buf, "%s/cons", display->devdir);
@@ -108,7 +110,7 @@
 	write(ctlfd, "rawon", 5);
 
 	kn = 0;
-	shift = alt = ctl = 0;
+	shift = alt = ctl = mod4 = 0;
 	for(;;){
 		while(!fullrune(k, kn)){
 			kr = read(fd, k+kn, sizeof k - kn);
@@ -134,6 +136,10 @@
 			shift = !shift;
 			keyevent(v, Xshift, shift);
 			break;
+		case Kmod4:
+			mod4 = !mod4;
+			keyevent(v, Xsuper, alt);
+			break;
 		default:
 			if(r == ks && r < 0x1A){	/* control key */
 				keyevent(v, Xctl, 1);
@@ -176,6 +182,10 @@
 				keyevent(v, Xshift, 0);
 				shift = 0;
 			}
+			if(mod4){
+				keyevent(v, Xsuper, 0);
+				shift = 0;
+			}
 			break;
 		}
 	}
@@ -228,7 +238,7 @@
 					if((r == Kshift) ||
 					   utfrune(buf+1, Kctl) || 
 					   utfrune(buf+1, Kalt) ||
-					   utfrune(buf+1, Kaltgr))
+					   utfrune(buf+1, Kmod4))
 						keyevent(v, runetovnc(r), 1);
 			}
 			break;
@@ -241,7 +251,7 @@
 			}
 			break;
 		case 'c':
-			if(utfrune(buf2+1, Kctl) || utfrune(buf2+1, Kalt) || utfrune(buf2+1, Kaltgr))
+			if(utfrune(buf2+1, Kctl) || utfrune(buf2+1, Kalt) || utfrune(buf2+1, Kmod4))
 				continue;
 			chartorune(&r, buf+1);
 			keyevent(v, runetovnc(r), 1);