diff options
-rw-r--r-- | src/cmd/acme/acme.c | 6 | ||||
-rw-r--r-- | src/cmd/acme/cols.c | 3 | ||||
-rw-r--r-- | src/cmd/acme/rows.c | 11 | ||||
-rw-r--r-- | src/cmd/acme/text.c | 53 | ||||
-rw-r--r-- | src/cmd/acme/wind.c | 25 |
5 files changed, 96 insertions, 2 deletions
diff --git a/src/cmd/acme/acme.c b/src/cmd/acme/acme.c index 913fadc3..6df7374f 100644 --- a/src/cmd/acme/acme.c +++ b/src/cmd/acme/acme.c @@ -591,7 +591,11 @@ mousethread(void *v) goto Continue; } /* scroll buttons, wheels, etc. */ - if(t->what==Body && w != nil && (m.buttons & (8|16))){ +/* + * TAG used to require t->what==Body but now allow + * scroll wheel in tag too. + */ + if(w != nil && (m.buttons & (8|16))){ if(m.buttons & 8) but = Kscrolloneup; else diff --git a/src/cmd/acme/cols.c b/src/cmd/acme/cols.c index 487931ec..66883499 100644 --- a/src/cmd/acme/cols.c +++ b/src/cmd/acme/cols.c @@ -467,6 +467,9 @@ coldragwin(Column *c, Window *w, int but) error("can't find window"); Found: +/* TAG - force recompute tag size (if in auto-expand mode) on mouse op. */ + w->taglines = 1; +/* END TAG */ p = mouse->xy; if(abs(p.x-op.x)<5 && abs(p.y-op.y)<5){ colgrow(c, w, but); diff --git a/src/cmd/acme/rows.c b/src/cmd/acme/rows.c index 1808bc4a..fc03c93c 100644 --- a/src/cmd/acme/rows.c +++ b/src/cmd/acme/rows.c @@ -282,6 +282,17 @@ rowtype(Row *row, Rune r, Point p) else{ winlock(w, 'K'); wintype(w, t, r); +/* + * TAG If we typed in the tag, might need to make it + * bigger to show text. \n causes tag to expand. + */ + if(t->what == Tag){ + t->w->tagsafe = FALSE; + if(r == '\n') + t->w->tagexpand = TRUE; + winresize(w, w->r, TRUE, TRUE); + } +/* END TAG */ winunlock(w); } } diff --git a/src/cmd/acme/text.c b/src/cmd/acme/text.c index a2ba0265..adde0dd7 100644 --- a/src/cmd/acme/text.c +++ b/src/cmd/acme/text.c @@ -646,11 +646,21 @@ texttype(Text *t, Rune r) uint q0, q1; int nnb, nb, n, i; int nr; + Point p; Rune *rp; Text *u; - if(t->what!=Body && r=='\n') +/* + * TAG + * Used to disallow \n in tag here. + * Also if typing in tag, mark that resize might be necessary. + */ + if(t->what!=Body && t->what!=Tag && r=='\n') return; + if(t->what == Tag) + t->w->tagsafe = FALSE; +/* END TAG */ + nr = 1; rp = &r; switch(r){ @@ -667,9 +677,17 @@ texttype(Text *t, Rune r) } return; case Kdown: +/* TAG */ + if(t->what == Tag) + goto Tagdown; +/* END TAG */ n = t->fr.maxlines/3; goto case_Down; case Kscrollonedown: +/* TAG */ + if(t->what == Tag) + goto Tagdown; +/* END TAG */ n = mousescrollsize(t->fr.maxlines); if(n <= 0) n = 1; @@ -681,9 +699,17 @@ texttype(Text *t, Rune r) textsetorigin(t, q0, TRUE); return; case Kup: +/* TAG */ + if(t->what == Tag) + goto Tagup; +/* END TAG */ n = t->fr.maxlines/3; goto case_Up; case Kscrolloneup: +/* TAG */ + if(t->what == Tag) + goto Tagup; +/* END TAG */ n = mousescrollsize(t->fr.maxlines); goto case_Up; case Kpgup: @@ -715,6 +741,31 @@ texttype(Text *t, Rune r) q0++; textshow(t, q0, q0, TRUE); return; +/* TAG policy here */ + Tagdown: + /* expand tag to show all text */ + if(!t->w->tagexpand){ + t->w->tagexpand = TRUE; + winresize(t->w, t->w->r, FALSE, TRUE); + } + return; + + Tagup: + /* shrink tag to single line */ + if(t->w->tagexpand){ + t->w->tagexpand = FALSE; + t->w->taglines = 1; + /* move mouse to stay in tag */ + p = mouse->xy; + if(ptinrect(p, t->w->tag.all) + && !ptinrect(p, t->w->tagtop)){ + p.y = t->w->tagtop.min.y + Dy(t->w->tagtop)/2; + moveto(mousectl, p); + } + winresize(t->w, t->w->r, FALSE, TRUE); + } + return; +/* END TAG */ } if(t->what == Body){ seq++; diff --git a/src/cmd/acme/wind.c b/src/cmd/acme/wind.c index 4fb03ef9..05384601 100644 --- a/src/cmd/acme/wind.c +++ b/src/cmd/acme/wind.c @@ -100,17 +100,28 @@ wintaglines(Window *w, Rectangle r) int n; Rune rune; +/* TAG policy here */ + if(!w->tagexpand) return 1; w->tag.fr.noredraw = 1; textresize(&w->tag, r, TRUE); w->tag.fr.noredraw = 0; + + /* can't use more than we have */ if(w->tag.fr.nlines >= w->tag.fr.maxlines) return w->tag.fr.maxlines; + + /* if tag ends with \n, include empty line at end for typing */ n = w->tag.fr.nlines; bufread(&w->tag.file->b, w->tag.file->b.nc-1, &rune, 1); if(rune == '\n') n++; + + /* cannot magically shrink tag - would lose focus */ + if(n < w->taglines) + n = w->taglines; + return n; } @@ -125,6 +136,19 @@ if(0) fprint(2, "winresize %d %R safe=%d keep=%d h=%d\n", w->id, r, safe, keepex w->tagtop = r; w->tagtop.max.y = r.min.y+font->height; +/* + * TAG If necessary, recompute the number of lines that should + * be in the tag. + */ + r1 = r; + r1.max.y = min(r.max.y, r1.min.y + w->taglines*font->height); + y = r1.max.y; + if(1 || !safe || !w->tagsafe || !eqrect(w->tag.all, r1)){ + w->taglines = wintaglines(w, r); + w->tagsafe = TRUE; + } +/* END TAG */ + r1 = r; r1.max.y = min(r.max.y, r1.min.y + w->taglines*font->height); y = r1.max.y; @@ -141,6 +165,7 @@ if(0) fprint(2, "=> %R (%R)\n", w->tag.all, w->tag.fr.r); br.max.y = br.min.y + Dy(b->r); draw(screen, br, b, nil, b->r.min); } + r1 = r; r1.min.y = y; |