commit 627bae9c76134c3db23162ce718b0c2725d26441 from: rsc date: Tue Jan 04 21:39:23 2005 UTC clean up mkfile; fix winctlprint bug reported by peter canning commit - f755d504015485c32e893b474ca42493a9f3dd67 commit + 627bae9c76134c3db23162ce718b0c2725d26441 blob - 476bbfd1a3b5f533cabdc1aba49894e780ce7c60 blob + 9db712869c54d633576011e120c20c1fbeb0a9ac --- src/cmd/acme/dat.h +++ src/cmd/acme/dat.h @@ -285,7 +285,7 @@ void winevent(Window*, char*, ...); void winmousebut(Window*); void winaddincl(Window*, Rune*, int); void wincleartag(Window*); -void winctlprint(Window*, char*, int); +char *winctlprint(Window*, char*, int); struct Column { blob - fbb34d1ad26c35cfd085dd6c029b09a76b2b2425 blob + 0b7a1827d09ceefb0ecc35b1a24bce6d72466532 --- src/cmd/acme/mkfile +++ src/cmd/acme/mkfile @@ -1,5 +1,3 @@ -# Acme is up-to-date w.r.t. sources as of 29 February 2004 - <$PLAN9/src/mkhdr TARG=acme @@ -30,14 +28,6 @@ HFILES=dat.h\ edit.h\ fns.h\ -UPDATE=\ - mkfile\ - $HFILES\ - ${OFILES:%.$O=%.c}\ - -SHORTLIB=complete plumb fs mux thread frame draw bio 9 <$PLAN9/src/mkone -LDFLAGS=$LDFLAGS -L$X11/lib -lX11 - edit.$O ecmd.$O elog.$O: edit.h blob - edb5d68e67b112eff7cbf80e9a945c8785053944 blob + 5b6171d73471d69c47fdab7fdd40e0103d674e24 --- src/cmd/acme/wind.c +++ src/cmd/acme/wind.c @@ -543,15 +543,15 @@ winclean(Window *w, int conservative) /* as it stands, return TRUE; } -void +char* winctlprint(Window *w, char *buf, int fonts) { - int n; - - n = sprint(buf, "%11d %11d %11d %11d %11d ", w->id, w->tag.file->b.nc, + sprint(buf, "%11d %11d %11d %11d %11d ", w->id, w->tag.file->b.nc, w->body.file->b.nc, w->isdir, w->dirty); if(fonts) - sprint(buf+n, "%11d %q %11d" , Dx(w->body.fr.r), w->body.reffont->f->name, w->body.fr.maxtab); + return smprint("%s%11d %q %11d ", buf, Dx(w->body.fr.r), + w->body.reffont->f->name, w->body.fr.maxtab); + return buf; } void blob - 5a2723a435c39423ed578013eff80032c951f32b blob + 13d72957c8000527578ee23ff736cf754c21eff4 --- src/cmd/acme/xfid.c +++ src/cmd/acme/xfid.c @@ -255,7 +255,7 @@ xfidread(Xfid *x) int n, q; uint off; char *b; - char buf[128]; + char buf[256]; Window *w; q = FILE(x->f->qid); @@ -295,18 +295,22 @@ xfidread(Xfid *x) break; case QWctl: - winctlprint(w, buf, 1); - goto Readbuf; + b = winctlprint(w, buf, 1); + goto Readb; Readbuf: - n = strlen(buf); + b = buf; + Readb: + n = strlen(b); if(off > n) off = n; if(off+x->fcall.count > n) x->fcall.count = n-off; fc.count = x->fcall.count; - fc.data = buf+off; + fc.data = b+off; respond(x, &fc, nil); + if(b != buf) + free(b); break; case QWevent: