diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/cmd/9term/9term.c | 11 | ||||
-rw-r--r-- | src/cmd/9term/win.c | 28 |
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); |