aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/9term
diff options
context:
space:
mode:
Diffstat (limited to 'src/cmd/9term')
-rw-r--r--src/cmd/9term/wind.c69
1 files changed, 40 insertions, 29 deletions
diff --git a/src/cmd/9term/wind.c b/src/cmd/9term/wind.c
index 69dec8a7..c59f08ec 100644
--- a/src/cmd/9term/wind.c
+++ b/src/cmd/9term/wind.c
@@ -190,7 +190,7 @@ wclose(Window *w)
void
winctl(void *arg)
{
- Rune *rp, *bp, *tp, *up, *kbdr;
+ Rune *rp, *bp, *up, *kbdr;
uint qh;
int nr, nb, c, wid, i, npart, initial, lastb;
char *s, *t, part[3];
@@ -328,37 +328,48 @@ winctl(void *arg)
recv(cwm.cw, &pair);
rp = pair.s;
nr = pair.ns;
- bp = rp;
- for(i=0; i<nr; i++)
- if(*bp++ == '\b'){
- --bp;
- initial = 0;
- tp = runemalloc(nr);
- runemove(tp, rp, i);
- up = tp+i;
- for(; i<nr; i++){
- *up = *bp++;
- if(*up == '\b')
- if(up == tp)
- initial++;
- else
- --up;
- else
- up++;
- }
- if(initial){
- if(initial > w->qh)
- initial = w->qh;
- qh = w->qh-initial;
- wdelete(w, qh, qh+initial);
- w->qh = qh;
+ up = bp = rp;
+ initial = 0;
+ for(i=0; i<nr; i++){
+ switch(*bp){
+ case 0:
+ break;
+ case '\b':
+ if(up == rp)
+ initial++;
+ else
+ --up;
+ break;
+/*
+ case '\r':
+ while(i<nr-1 && *(bp+1) == '\r'){
+ bp++;
+ i++;
}
- free(rp);
- rp = tp;
- nr = up-tp;
- rp[nr] = 0;
+ if(i<nr-1 && *(bp+1) != '\n'){
+ while(up > rp && *(up-1) != '\n')
+ up--;
+ if(up == rp)
+ initial = wbswidth(w, 0x15);
+ }else if(i == nr-1)
+ *up = '\n';
+ break;
+*/
+ default:
+ *up++ = *bp;
break;
}
+ bp++;
+ }
+ if(initial){
+ if(initial > w->qh)
+ initial = w->qh;
+ qh = w->qh - initial;
+ wdelete(w, qh, qh+initial);
+ w->qh = qh;
+ }
+ nr = rp - up;
+ rp[nr] = 0;
w->qh = winsert(w, rp, nr, w->qh)+nr;
if(w->scrolling || w->mouseopen)
wshow(w, w->qh);