aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/9term/win.c
diff options
context:
space:
mode:
authorrsc <devnull@localhost>2005-01-30 16:27:45 +0000
committerrsc <devnull@localhost>2005-01-30 16:27:45 +0000
commitefe12411090ddcb45f524d6b0624ec4493d65175 (patch)
treed456ee063f7fe3625c7c5f5fc9a95ec1e931a790 /src/cmd/9term/win.c
parent0b22e9bd85861f6a3c8f0635bd4422daa84343eb (diff)
downloadplan9port-efe12411090ddcb45f524d6b0624ec4493d65175.tar.gz
plan9port-efe12411090ddcb45f524d6b0624ec4493d65175.tar.bz2
plan9port-efe12411090ddcb45f524d6b0624ec4493d65175.zip
handle sysnames in labels
Diffstat (limited to 'src/cmd/9term/win.c')
-rw-r--r--src/cmd/9term/win.c21
1 files changed, 16 insertions, 5 deletions
diff --git a/src/cmd/9term/win.c b/src/cmd/9term/win.c
index a6ef1414..37333fcc 100644
--- a/src/cmd/9term/win.c
+++ b/src/cmd/9term/win.c
@@ -489,11 +489,11 @@ stdoutproc(void *v)
}
}
-char wdir[256];
+char wdir[512];
int
label(char *sr, int n)
{
- char *sl, *el, *er, *r;
+ char *sl, *el, *er, *r, *p;
er = sr+n;
for(r=er-1; r>=sr; r--)
@@ -503,8 +503,8 @@ label(char *sr, int n)
return n;
el = r+1;
- if(el-sr > sizeof wdir)
- sr = el - sizeof wdir;
+ if(el-sr > sizeof wdir - strlen(name) - 20)
+ sr = el - sizeof wdir - strlen(name) - 20;
for(sl=el-3; sl>=sr; sl--)
if(sl[0]=='\033' && sl[1]==']' && sl[2]==';')
break;
@@ -512,7 +512,18 @@ label(char *sr, int n)
return n;
*r = 0;
- snprint(wdir, sizeof wdir, "name %s/-%s\n0\n", sl+3, name);
+ /*
+ * 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++ = '/';
+ strcpy(p, name);
+ }
+ strcat(wdir, "\n0\n");
fswrite(ctlfd, wdir, strlen(wdir));
memmove(sl, el, er-el);