commit 0e881c054a76801032e640db3947e0602cfccbeb from: Russ Cox date: Tue Oct 11 13:34:25 2011 UTC 9term: hold mode back door R=rsc http://codereview.appspot.com/5248056 commit - f9c8cdb5a6b612f49ee544bba9024081852fdaf1 commit + 0e881c054a76801032e640db3947e0602cfccbeb blob - 344a7b553ed12a9e93986370d2a9515699e723ef blob + ed68ed19c1ef8c03eafc35a66d1979ed09a3976c --- src/cmd/9term/9term.c +++ 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 */ blob - e5d21416e7880abb2a606e14c19b369d95cbeb0b blob + e08e032c3999b90059ed5c79d00e70daf9008af6 --- src/cmd/9term/win.c +++ 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);