diff options
author | rsc <devnull@localhost> | 2005-11-10 23:21:06 +0000 |
---|---|---|
committer | rsc <devnull@localhost> | 2005-11-10 23:21:06 +0000 |
commit | c935adc6a2b4bcaa1729edf50ed91bfce9c0df91 (patch) | |
tree | 5a8564929b442466963ba8000ea307a371e631f9 | |
parent | f535642f304ebfec5182ab97be53e1fbf23056dc (diff) | |
download | plan9port-c935adc6a2b4bcaa1729edf50ed91bfce9c0df91.tar.gz plan9port-c935adc6a2b4bcaa1729edf50ed91bfce9c0df91.tar.bz2 plan9port-c935adc6a2b4bcaa1729edf50ed91bfce9c0df91.zip |
more
-rw-r--r-- | src/cmd/9term/9term.c | 103 |
1 files changed, 101 insertions, 2 deletions
diff --git a/src/cmd/9term/9term.c b/src/cmd/9term/9term.c index 26e13f39..61ac1faa 100644 --- a/src/cmd/9term/9term.c +++ b/src/cmd/9term/9term.c @@ -34,6 +34,7 @@ void rcoutputproc(void*); void rcinputproc(void*); void hangupnote(void*, char*); void resizethread(void*); +void servedevtext(void); int errorshouldabort = 0; @@ -89,7 +90,6 @@ threadmain(int argc, char *argv[]) initdraw(derror, nil, "9term"); notify(hangupnote); noteenable("sys: child"); -// servedevtext(); mousectl = initmouse(nil, screen); if(mousectl == nil) @@ -109,7 +109,8 @@ threadmain(int argc, char *argv[]) threadcreate(keyboardthread, nil, STACK); threadcreate(mousethread, nil, STACK); threadcreate(resizethread, nil, STACK); - + servedevtext(); + proccreate(rcoutputproc, nil, STACK); proccreate(rcinputproc, nil, STACK); } @@ -169,12 +170,18 @@ keyboardthread(void *v) void resizethread(void *v) { + Point p; + USED(v); while(recv(mousectl->resizec, nil) == 1){ if(getwindow(display, Refnone) < 0) sysfatal("can't reattach to window"); wresize(w, screen, 0); + p = stringsize(display->defaultfont, "0"); + if(p.x && p.y) + updatewinsize(Dy(screen->r)/p.y, Dx(screen->r)/p.x, + Dx(screen->r), Dy(screen->r)); } } @@ -503,6 +510,9 @@ rcinputproc(void *arg) } } +/* + * Snarf buffer - rio uses runes internally + */ void rioputsnarf(void) { @@ -530,3 +540,92 @@ riogetsnarf(void) cvttorunes(s, n, snarf, &nb, &nsnarf, &nulls); free(s); } + +/* + * Clumsy hack to make " and "" work. + * Then again, what's not a clumsy hack here in Unix land? + */ + +char adir[100]; +char thesocket[100]; +int afd; + +void listenproc(void*); +void textproc(void*); + +void +removethesocket(void) +{ + if(thesocket[0]) + if(remove(thesocket) < 0) + fprint(2, "remove %s: %r\n", thesocket); +} + +void +servedevtext(void) +{ + char buf[100]; + + snprint(buf, sizeof buf, "unix!/tmp/9term-text.%d", getpid()); + + if((afd = announce(buf, adir)) < 0){ + putenv("text9term", ""); + return; + } + + putenv("text9term", buf); + proccreate(listenproc, nil, STACK); + strcpy(thesocket, buf+5); + atexit(removethesocket); +} + +void +listenproc(void *arg) +{ + int fd; + char dir[100]; + + USED(arg); + for(;;){ + fd = listen(adir, dir); + if(fd < 0){ + close(afd); + return; + } + proccreate(textproc, (void*)fd, STACK); + } +} + +void +textproc(void *arg) +{ + int fd, i, x, n, end; + Rune r; + char buf[4096], *p, *ep; + + fd = (int)arg; + p = buf; + ep = buf+sizeof buf; + end = w->org+w->nr; /* avoid possible output loop */ + for(i=w->org;; i++){ + if(i >= end || ep-p < UTFmax){ + for(x=0; x<p-buf; x+=n) + if((n = write(fd, buf+x, (p-x)-buf)) <= 0) + goto break2; + + if(i >= end) + break; + p = buf; + } + if(i < w->org) + i = w->org; + r = w->r[i-w->org]; + if(r < Runeself) + *p++ = r; + else + p += runetochar(p, &r); + } +break2: + close(fd); +} + |