From 0d2dfbc84f42317fab5bc247355868d86613f3b0 Mon Sep 17 00:00:00 2001 From: Russ Cox Date: Tue, 10 Nov 2015 10:25:17 -0500 Subject: 9term, win: better \r handling (thanks, git) Change-Id: I75563b911b54d8957d2d004b9c27d0a2f8f043b3 Reviewed-on: https://plan9port-review.googlesource.com/1390 Reviewed-by: Russ Cox --- src/cmd/9term/win.c | 30 ++++++++++++++++++++++++++++++ src/cmd/9term/wind.c | 2 +- 2 files changed, 31 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/cmd/9term/win.c b/src/cmd/9term/win.c index decfece7..97ef6d87 100644 --- a/src/cmd/9term/win.c +++ b/src/cmd/9term/win.c @@ -479,6 +479,32 @@ stdinproc(void *v) } } +int +dropcr(char *p, int n) +{ + int i; + char *w, *r; + + r = p; + w = p; + for(i=0; i p) + w--; + break; + case '\r': + *w++ = '\n'; + break; + default: + *w++ = *r; + break; + } + r++; + } + return w-p; +} + void stdoutproc(void *v) { @@ -507,6 +533,10 @@ stdoutproc(void *v) n = dropcrnl(buf+npart, n); if(n == 0) continue; + + n = dropcr(buf+npart, n); + if(n == 0) + continue; /* squash NULs */ s = memchr(buf+npart, 0, n); diff --git a/src/cmd/9term/wind.c b/src/cmd/9term/wind.c index 28d45cbb..b03f15fc 100644 --- a/src/cmd/9term/wind.c +++ b/src/cmd/9term/wind.c @@ -361,7 +361,7 @@ winctl(void *arg) if(up == rp) initial = wbswidth(w, '\r'); }else if(i == nr-1) - *up = '\n'; + *up++ = '\n'; break; default: *up++ = *bp; -- cgit v1.2.3