plan9port

fork of plan9port with libvec, libstr and libsdb
Log | Files | Refs | README | LICENSE

commit 0d2dfbc84f42317fab5bc247355868d86613f3b0
parent 8ee5da7cf764bf5685c137264cd4d6a03f12ba89
Author: Russ Cox <rsc@swtch.com>
Date:   Tue, 10 Nov 2015 10:25:17 -0500

9term, win: better \r handling (thanks, git)

Change-Id: I75563b911b54d8957d2d004b9c27d0a2f8f043b3
Reviewed-on: https://plan9port-review.googlesource.com/1390
Reviewed-by: Russ Cox <rsc@google.com>

Diffstat:
Msrc/cmd/9term/win.c | 30++++++++++++++++++++++++++++++
Msrc/cmd/9term/wind.c | 2+-
2 files changed, 31 insertions(+), 1 deletion(-)

diff --git 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<n; i++) { + switch(*r) { + case '\b': + if(w > 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 @@ -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;