aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/9term/9term.c
diff options
context:
space:
mode:
authorrsc <devnull@localhost>2005-11-11 00:37:14 +0000
committerrsc <devnull@localhost>2005-11-11 00:37:14 +0000
commitc21d0ab45b22db49ab83936a3bab4007f33187ee (patch)
treed0460b950d52218f8a0130948a5b5a8015255c00 /src/cmd/9term/9term.c
parentc935adc6a2b4bcaa1729edf50ed91bfce9c0df91 (diff)
downloadplan9port-c21d0ab45b22db49ab83936a3bab4007f33187ee.tar.gz
plan9port-c21d0ab45b22db49ab83936a3bab4007f33187ee.tar.bz2
plan9port-c21d0ab45b22db49ab83936a3bab4007f33187ee.zip
fixes
Diffstat (limited to 'src/cmd/9term/9term.c')
-rw-r--r--src/cmd/9term/9term.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/cmd/9term/9term.c b/src/cmd/9term/9term.c
index 61ac1faa..cc85e95e 100644
--- a/src/cmd/9term/9term.c
+++ b/src/cmd/9term/9term.c
@@ -103,13 +103,13 @@ threadmain(int argc, char *argv[])
deletechan = chancreate(sizeof(char*), 0);
timerinit();
+ servedevtext();
rcpid = rcstart(argc, argv, &rcfd, &sfd);
w = new(screen, FALSE, scrolling, rcpid, ".", nil, nil);
threadcreate(keyboardthread, nil, STACK);
threadcreate(mousethread, nil, STACK);
threadcreate(resizethread, nil, STACK);
- servedevtext();
proccreate(rcoutputproc, nil, STACK);
proccreate(rcinputproc, nil, STACK);
@@ -606,6 +606,10 @@ textproc(void *arg)
fd = (int)arg;
p = buf;
ep = buf+sizeof buf;
+ if(w == nil){
+ close(fd);
+ return;
+ }
end = w->org+w->nr; /* avoid possible output loop */
for(i=w->org;; i++){
if(i >= end || ep-p < UTFmax){