aboutsummaryrefslogtreecommitdiff
path: root/src/cmd
diff options
context:
space:
mode:
Diffstat (limited to 'src/cmd')
-rw-r--r--src/cmd/9term/9term.c11
-rw-r--r--src/cmd/9term/win.c28
2 files changed, 23 insertions, 16 deletions
diff --git a/src/cmd/9term/9term.c b/src/cmd/9term/9term.c
index 344a7b55..ed68ed19 100644
--- a/src/cmd/9term/9term.c
+++ b/src/cmd/9term/9term.c
@@ -468,9 +468,14 @@ label(Rune *sr, int n)
dir = smprint("%.*S", (el-1)-(sl+3), sl+3);
if(dir){
- drawsetlabel(dir);
- free(w->dir);
- w->dir = dir;
+ if(strcmp(dir, "*9term-hold+") == 0) {
+ w->holding = 1;
+ wrepaint(w);
+ } else {
+ drawsetlabel(dir);
+ free(w->dir);
+ w->dir = dir;
+ }
}
/* remove trailing /-sysname if present */
diff --git a/src/cmd/9term/win.c b/src/cmd/9term/win.c
index e5d21416..e08e032c 100644
--- a/src/cmd/9term/win.c
+++ b/src/cmd/9term/win.c
@@ -598,20 +598,22 @@ label(char *sr, int n)
return n;
*r = 0;
- /*
- * add /-sysname if not present
- */
- snprint(wdir, sizeof wdir, "name %s", sl+3);
- p = strrchr(wdir, '/');
- if(p==nil || *(p+1) != '-'){
- p = wdir+strlen(wdir);
- if(*(p-1) != '/')
- *p++ = '/';
- *p++ = '-';
- strcpy(p, name);
+ if(strcmp(sl+3, "*9term-hold+") != 0) {
+ /*
+ * add /-sysname if not present
+ */
+ snprint(wdir, sizeof wdir, "name %s", sl+3);
+ p = strrchr(wdir, '/');
+ if(p==nil || *(p+1) != '-'){
+ p = wdir+strlen(wdir);
+ if(*(p-1) != '/')
+ *p++ = '/';
+ *p++ = '-';
+ strcpy(p, name);
+ }
+ strcat(wdir, "\n0\n");
+ fswrite(ctlfd, wdir, strlen(wdir));
}
- strcat(wdir, "\n0\n");
- fswrite(ctlfd, wdir, strlen(wdir));
memmove(sl, el, er-el);
n -= (el-sl);