aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrsc <devnull@localhost>2005-07-13 03:53:17 +0000
committerrsc <devnull@localhost>2005-07-13 03:53:17 +0000
commit55d360f653add52055c39d7989745bf72d6df27a (patch)
tree0bbf39852c7a489519531a57e5453bff102ecbbb
parent17cfc1dd5f1cf4a6f6752d4e94e76ccee020006c (diff)
downloadplan9port-55d360f653add52055c39d7989745bf72d6df27a.tar.gz
plan9port-55d360f653add52055c39d7989745bf72d6df27a.tar.bz2
plan9port-55d360f653add52055c39d7989745bf72d6df27a.zip
lets try hold mode in raw mode
-rw-r--r--src/cmd/9term/9term.c26
-rw-r--r--src/cmd/9term/rcstart.c8
2 files changed, 24 insertions, 10 deletions
diff --git a/src/cmd/9term/9term.c b/src/cmd/9term/9term.c
index a620410a..78d52ab1 100644
--- a/src/cmd/9term/9term.c
+++ b/src/cmd/9term/9term.c
@@ -922,6 +922,23 @@ key(Rune r)
return;
}
+ /*
+ * This if used to be below the if(rawon() && t.q0==t.nr),
+ * but let's try putting it here. This will allow ESC-processing
+ * to toggle hold mode even in remote SSH connections.
+ * The drawback is that vi-style processing gets harder.
+ * If you find yourself in some weird readline mode, good
+ * luck getting out without ESC. Let's see who complains.
+ */
+ if(r==ESC){ /* toggle hold */
+ holdon = !holdon;
+ drawhold(holdon);
+ /* replaceintegerproperty("_9WM_HOLD_MODE", 1, 32, holdon); */
+ if(!holdon)
+ consread();
+ return;
+ }
+
if(rawon() && t.q0 == t.nr){
addraw(&r, 1);
consread();
@@ -939,15 +956,6 @@ key(Rune r)
return;
}
- if(r==ESC){ /* toggle hold */
- holdon = !holdon;
- drawhold(holdon);
- /* replaceintegerproperty("_9WM_HOLD_MODE", 1, 32, holdon); */
- if(!holdon)
- consread();
- return;
- }
-
snarf();
switch(r) {
diff --git a/src/cmd/9term/rcstart.c b/src/cmd/9term/rcstart.c
index 1aa46dce..a598f420 100644
--- a/src/cmd/9term/rcstart.c
+++ b/src/cmd/9term/rcstart.c
@@ -52,7 +52,13 @@ rcstart(int argc, char **argv, int *pfd, int *tfd)
exit(3);
sysfatal("getpts: %r\n");
}
- notedisable("sys: window size change");
+ /*
+ * notedisable("sys: window size change");
+ *
+ * Can't disable because will be inherited by other programs
+ * like if you run an xterm from the prompt, and then xterm's
+ * resizes won't get handled right. Sigh.
+ */
pid = fork();
switch(pid){
case 0: