mirror of
https://github.com/9fans/plan9port.git
synced 2025-01-24 11:41:58 +00:00
acme: correct writes of runes on auspicious byte boundaries
R=rsc, r CC=plan9port.codebot http://codereview.appspot.com/6586067
This commit is contained in:
parent
ca9ae08876
commit
5b6028903d
2 changed files with 35 additions and 23 deletions
|
@ -17,6 +17,7 @@ David Jeannot <djeannot24@gmail.com>
|
||||||
David Swasey <david.swasey@gmail.com>
|
David Swasey <david.swasey@gmail.com>
|
||||||
Enrique Soriano <enrique.soriano@gmail.com>
|
Enrique Soriano <enrique.soriano@gmail.com>
|
||||||
Eoghan Sherry <ejsherry@gmail.com>
|
Eoghan Sherry <ejsherry@gmail.com>
|
||||||
|
Erik Quanstrom <quanstro@quanstro.net>
|
||||||
Fazlul Shahriar <fshahriar@gmail.com>
|
Fazlul Shahriar <fshahriar@gmail.com>
|
||||||
Ingo Dreilich <yngoto@gmail.com>
|
Ingo Dreilich <yngoto@gmail.com>
|
||||||
Justin Davis <jrcd83@gmail.com>
|
Justin Davis <jrcd83@gmail.com>
|
||||||
|
|
|
@ -403,11 +403,42 @@ shouldscroll(Text *t, uint q0, int qid)
|
||||||
return t->org <= q0 && q0 <= t->org+t->fr.nchars;
|
return t->org <= q0 && q0 <= t->org+t->fr.nchars;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static Rune*
|
||||||
|
fullrunewrite(Xfid *x, int *inr)
|
||||||
|
{
|
||||||
|
int q, cnt, c, nb, nr;
|
||||||
|
Rune *r;
|
||||||
|
|
||||||
|
q = x->f->nrpart;
|
||||||
|
cnt = x->fcall.count;
|
||||||
|
if(q > 0){
|
||||||
|
memmove(x->fcall.data+q, x->fcall.data, cnt); /* there's room; see fsysproc */
|
||||||
|
memmove(x->fcall.data, x->f->rpart, q);
|
||||||
|
cnt += q;
|
||||||
|
x->f->nrpart = 0;
|
||||||
|
}
|
||||||
|
r = runemalloc(cnt);
|
||||||
|
cvttorunes(x->fcall.data, cnt-UTFmax, r, &nb, &nr, nil);
|
||||||
|
/* approach end of buffer */
|
||||||
|
while(fullrune(x->fcall.data+nb, cnt-nb)){
|
||||||
|
c = nb;
|
||||||
|
nb += chartorune(&r[nr], x->fcall.data+c);
|
||||||
|
if(r[nr])
|
||||||
|
nr++;
|
||||||
|
}
|
||||||
|
if(nb < cnt){
|
||||||
|
memmove(x->f->rpart, x->fcall.data+nb, cnt-nb);
|
||||||
|
x->f->nrpart = cnt-nb;
|
||||||
|
}
|
||||||
|
*inr = nr;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
xfidwrite(Xfid *x)
|
xfidwrite(Xfid *x)
|
||||||
{
|
{
|
||||||
Fcall fc;
|
Fcall fc;
|
||||||
int c, cnt, qid, q, nb, nr, eval;
|
int c, qid, nb, nr, eval;
|
||||||
char buf[64], *err;
|
char buf[64], *err;
|
||||||
Window *w;
|
Window *w;
|
||||||
Rune *r;
|
Rune *r;
|
||||||
|
@ -463,7 +494,7 @@ xfidwrite(Xfid *x)
|
||||||
|
|
||||||
case Qeditout:
|
case Qeditout:
|
||||||
case QWeditout:
|
case QWeditout:
|
||||||
r = bytetorune(x->fcall.data, &nr);
|
r = fullrunewrite(x, &nr);
|
||||||
if(w)
|
if(w)
|
||||||
err = edittext(w, w->wrselrange.q1, r, nr);
|
err = edittext(w, w->wrselrange.q1, r, nr);
|
||||||
else
|
else
|
||||||
|
@ -538,27 +569,7 @@ xfidwrite(Xfid *x)
|
||||||
goto BodyTag;
|
goto BodyTag;
|
||||||
|
|
||||||
BodyTag:
|
BodyTag:
|
||||||
q = x->f->nrpart;
|
r = fullrunewrite(x, &nr);
|
||||||
cnt = x->fcall.count;
|
|
||||||
if(q > 0){
|
|
||||||
memmove(x->fcall.data+q, x->fcall.data, cnt); /* there's room; see fsysproc */
|
|
||||||
memmove(x->fcall.data, x->f->rpart, q);
|
|
||||||
cnt += q;
|
|
||||||
x->f->nrpart = 0;
|
|
||||||
}
|
|
||||||
r = runemalloc(cnt);
|
|
||||||
cvttorunes(x->fcall.data, cnt-UTFmax, r, &nb, &nr, nil);
|
|
||||||
/* approach end of buffer */
|
|
||||||
while(fullrune(x->fcall.data+nb, cnt-nb)){
|
|
||||||
c = nb;
|
|
||||||
nb += chartorune(&r[nr], x->fcall.data+c);
|
|
||||||
if(r[nr])
|
|
||||||
nr++;
|
|
||||||
}
|
|
||||||
if(nb < cnt){
|
|
||||||
memmove(x->f->rpart, x->fcall.data+nb, cnt-nb);
|
|
||||||
x->f->nrpart = cnt-nb;
|
|
||||||
}
|
|
||||||
if(nr > 0){
|
if(nr > 0){
|
||||||
wincommit(w, t);
|
wincommit(w, t);
|
||||||
if(qid == QWwrsel){
|
if(qid == QWwrsel){
|
||||||
|
|
Loading…
Reference in a new issue