aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--man/man1/label.116
-rw-r--r--src/cmd/9term/9term.c11
-rw-r--r--src/cmd/9term/win.c21
3 files changed, 37 insertions, 11 deletions
diff --git a/man/man1/label.1 b/man/man1/label.1
index 20fd9007..5866ddbe 100644
--- a/man/man1/label.1
+++ b/man/man1/label.1
@@ -6,6 +6,9 @@ label, awd \- set window label
.I string
.br
.B awd
+[
+.I sysname
+]
.SH DESCRIPTION
.I Label
sets the label of the current
@@ -25,6 +28,14 @@ and
windows assume the label is a directory name.
When unrooted file names are plumbed in the window,
they are evaluated relative to the directory named in the label.
+.PP
+The label may have a suffix
+BI /- sysname \fR,
+which is not interpreted as part of the directory during plumbing.
+.I Awd
+sets the window name to the current directory with a
+.BI /- sysname
+suffix, using the name of the current system by default.
.SH EXAMPLE
One can use the following
.IR sh (1)
@@ -64,8 +75,3 @@ fn cd {
.I Awd
is also documented in
.IR acme (1).
-.PP
-.I Awd
-does not append the
-.BI - label
-suffix that it does on Plan 9.
diff --git a/src/cmd/9term/9term.c b/src/cmd/9term/9term.c
index 31c9f289..f22bebc5 100644
--- a/src/cmd/9term/9term.c
+++ b/src/cmd/9term/9term.c
@@ -1834,7 +1834,8 @@ int
label(Rune *sr, int n)
{
Rune *sl, *el, *er, *r;
-
+ char *p;
+
er = sr+n;
for(r=er-1; r>=sr; r--)
if(*r == '\007')
@@ -1854,6 +1855,14 @@ label(Rune *sr, int n)
snprint(wdir, sizeof wdir, "%.*S", (el-1)-(sl+3), sl+3);
drawsetlabel(wdir);
+ /* remove trailing /-sysname if present */
+ p = strrchr(wdir, '/');
+ if(p && *(p+1) == '-'){
+ if(p == wdir)
+ p++;
+ *p = 0;
+ }
+
runemove(sl, el, er-el);
n -= (el-sl);
return n;
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);