aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/9term
diff options
context:
space:
mode:
Diffstat (limited to 'src/cmd/9term')
-rw-r--r--src/cmd/9term/9term.c67
-rw-r--r--src/cmd/9term/FreeBSD.c3
2 files changed, 49 insertions, 21 deletions
diff --git a/src/cmd/9term/9term.c b/src/cmd/9term/9term.c
index 1386c158..89b609e0 100644
--- a/src/cmd/9term/9term.c
+++ b/src/cmd/9term/9term.c
@@ -108,7 +108,6 @@ threadmain(int argc, char *argv[])
draw(screen, screen->r, cols[BACK], nil, ZP);
geom();
-
loop();
}
@@ -118,7 +117,7 @@ hangupnote(void *a, char *msg)
if(getpid() != mainpid)
noted(NDFLT);
if(strcmp(msg, "hangup") == 0 && rcpid != 0){
- postnote(PNPROC, rcpid, "hangup");
+ postnote(PNGROUP, rcpid, "hangup");
noted(NDFLT);
}
noted(NDFLT);
@@ -206,9 +205,13 @@ doreshape(void)
scrdraw();
}
+struct winsize ows;
+
void
geom(void)
{
+ struct winsize ws;
+ Point p;
Rectangle r;
r = screen->r;
@@ -223,6 +226,18 @@ geom(void)
t.f->maxtab = maxtab*stringwidth(font, "0");
fill();
updatesel();
+
+ p = stringsize(font, "0");
+ if(p.x == 0 || p.y == 0)
+ return;
+
+ ws.ws_row = Dy(r)/p.y;
+ ws.ws_col = Dx(r)/p.x;
+ ws.ws_xpixel = Dx(r);
+ ws.ws_ypixel = Dy(r);
+ if(ws.ws_row != ows.ws_row || ws.ws_col != ows.ws_col)
+ if(ioctl(rcfd[0], TIOCSWINSZ, &ws) < 0)
+ fprint(2, "ioctl: %r\n");
}
void
@@ -422,6 +437,7 @@ void
key(Rune r)
{
char buf[1];
+ uint sig;
if(r == 0)
return;
@@ -472,12 +488,9 @@ key(Rune r)
case 0x7F: /* DEL: send interrupt */
t.qh = t.q0 = t.q1 = t.nr;
show(t.q0);
- buf[0] = 0x7f;
- if(write(rcfd[1], buf, 1) < 0)
- exits(0);
- /* get rc to print prompt */
-// r = '\n';
-// paste(&r, 1, 1);
+ sig = 2; /* SIGINT */
+ if(ioctl(rcfd[0], TIOCSIG, &sig) < 0)
+ fprint(2, "sending interrupt: %r\n");
break;
case 0x08: /* ^H: erase character */
case 0x15: /* ^U: erase line */
@@ -543,7 +556,10 @@ consready(void)
for(i=t.qh; i<t.nr; i++){
c = t.r[i];
if(c=='\n' || c=='\004')
+{
+fprint(2, "ready %d\n", c);
return 1;
+}
}
return 0;
}
@@ -561,6 +577,7 @@ consread(void)
n = sizeof(buf);
p = buf;
+ c = 0;
while(n >= UTFmax && (t.qh<t.nr || t.nraw > 0)) {
if(t.qh == t.nr){
width = runetochar(p, &t.raw[0]);
@@ -571,18 +588,17 @@ consread(void)
c = *p;
p += width;
n -= width;
- if(!rawon && (c == '\n' || c == '\004')) {
- if(c == '\004')
- p--;
+ if(!rawon && (c == '\n' || c == '\004'))
break;
- }
}
- if(n < UTFmax && t.qh<t.nr && t.r[t.qh]=='\004')
- t.qh++;
- /* put in control-d when doing a zero length write */
- if(p == buf)
- *p++ = '\004';
- if(write(rcfd[1], buf, p-buf) < 0)
+ /* take out control-d when not doing a zero length write */
+ n = p-buf;
+ if(n > 1 && c == '\004')
+{
+fprint(2, "remove 004\n");
+ n--;
+}
+ if(write(rcfd[1], buf, n) < 0)
exits(0);
/* mallocstats(); */
}
@@ -1138,19 +1154,32 @@ rcstart(int fd[2])
argv[1] = "-i";
argv[2] = 0;
- getpts(fd, slave);
+ /*
+ * fd0 is slave (tty), fd1 is master (pty)
+ */
+ fd[0] = fd[1] = -1;
+ if(getpts(fd, slave) < 0)
+ fprint(2, "getpts: %r\n");
+
switch(pid = fork()) {
case 0:
putenv("TERM=9term");
close(fd[1]);
setsid();
+ // tcsetpgrp(0, pid);
sfd = open(slave, ORDWR);
+ fprint(2, "slave %s\n", slave);
+ if(sfd < 0)
+ fprint(2, "open %s: %r\n", slave);
+ if(ioctl(sfd, TIOCSCTTY, 0) < 0)
+ fprint(2, "ioctl TIOCSCTTY: %r\n");
// ioctl(sfd, I_PUSH, "ptem");
// ioctl(sfd, I_PUSH, "ldterm");
dup(sfd, 0);
dup(sfd, 1);
dup(sfd, 2);
execvp(argv[0], argv);
+ _exits("oops");
break;
case -1:
fatal("proc failed: %r");
diff --git a/src/cmd/9term/FreeBSD.c b/src/cmd/9term/FreeBSD.c
index f59977e1..e8b894dc 100644
--- a/src/cmd/9term/FreeBSD.c
+++ b/src/cmd/9term/FreeBSD.c
@@ -13,6 +13,5 @@ getchildwd(int pid, char *wdir, int bufn)
int
getpts(int fd[], char *slave)
{
- openpty(&fd[1], &fd[0], slave, 0, 0);
- return 0;
+ return openpty(&fd[1], &fd[0], slave, 0, 0);
}