summaryrefslogtreecommitdiff
path: root/usr.bin/mg/display.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin/mg/display.c')
-rw-r--r--usr.bin/mg/display.c136
1 files changed, 74 insertions, 62 deletions
diff --git a/usr.bin/mg/display.c b/usr.bin/mg/display.c
index aafc830fecf..e00c7f6a5ab 100644
--- a/usr.bin/mg/display.c
+++ b/usr.bin/mg/display.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: display.c,v 1.7 2002/01/18 08:37:08 art Exp $ */
+/* $OpenBSD: display.c,v 1.8 2002/02/14 00:11:46 vincent Exp $ */
/*
* The functions in this file handle redisplay. The
@@ -291,6 +291,8 @@ vtputc(c)
{
VIDEO *vp;
+ c &= 0xff;
+
vp = vscreen[vtrow];
if (vtcol >= ncol)
vp->v_text[ncol - 1] = '$';
@@ -320,8 +322,9 @@ vtpute(c)
{
VIDEO *vp;
+ c &= 0xff;
+
vp = vscreen[vtrow];
-
if (vtcol >= ncol)
vp->v_text[ncol - 1] = '$';
else if (c == '\t'
@@ -331,8 +334,7 @@ vtpute(c)
) {
do {
vtpute(' ');
- }
- while (((vtcol + lbound) & 0x07) != 0 && vtcol < ncol);
+ } while (((vtcol + lbound) & 0x07) != 0 && vtcol < ncol);
} else if (ISCTRL(c) != FALSE) {
vtpute('^');
vtpute(CCHR(c));
@@ -392,72 +394,82 @@ update()
}
}
hflag = FALSE; /* Not hard. */
- wp = wheadp;
- while (wp != NULL) {
- if (wp->w_flag != 0) { /* Need update. */
- if ((wp->w_flag & WFFORCE) == 0) {
- lp = wp->w_linep;
- for (i = 0; i < wp->w_ntrows; ++i) {
- if (lp == wp->w_dotp)
- goto out;
- if (lp == wp->w_bufp->b_linep)
- break;
- lp = lforw(lp);
- }
- }
- i = wp->w_force; /* Reframe this one. */
- if (i > 0) {
- --i;
- if (i >= wp->w_ntrows)
- i = wp->w_ntrows - 1;
- } else if (i < 0) {
- i += wp->w_ntrows;
- if (i < 0)
- i = 0;
- } else
- i = wp->w_ntrows / 2;
- lp = wp->w_dotp;
- while (i != 0 && lback(lp) != wp->w_bufp->b_linep) {
- --i;
- lp = lback(lp);
+ for (wp = wheadp; wp != NULL; wp = wp->w_wndp) {
+ /*
+ * Nothing to be done.
+ */
+ if (wp->w_flag == 0)
+ continue;
+
+ if ((wp->w_flag & WFFORCE) == 0) {
+ lp = wp->w_linep;
+ for (i = 0; i < wp->w_ntrows; ++i) {
+ if (lp == wp->w_dotp)
+ goto out;
+ if (lp == wp->w_bufp->b_linep)
+ break;
+ lp = lforw(lp);
}
- wp->w_linep = lp;
- wp->w_flag |= WFHARD; /* Force full. */
+ }
+ /*
+ * Put the middle-line in place.
+ */
+ i = wp->w_force;
+ if (i > 0) {
+ --i;
+ if (i >= wp->w_ntrows)
+ i = wp->w_ntrows - 1;
+ } else if (i < 0) {
+ i += wp->w_ntrows;
+ if (i < 0)
+ i = 0;
+ } else
+ i = wp->w_ntrows / 2; /* current center,
+ * no change */
+
+ /*
+ * Find the line
+ */
+ lp = wp->w_dotp;
+ while (i != 0 && lback(lp) != wp->w_bufp->b_linep) {
+ --i;
+ lp = lback(lp);
+ }
+ wp->w_linep = lp;
+ wp->w_flag |= WFHARD; /* Force full. */
out:
- lp = wp->w_linep; /* Try reduced update. */
- i = wp->w_toprow;
- if ((wp->w_flag & ~WFMODE) == WFEDIT) {
- while (lp != wp->w_dotp) {
- ++i;
- lp = lforw(lp);
- }
+ lp = wp->w_linep; /* Try reduced update. */
+ i = wp->w_toprow;
+ if ((wp->w_flag & ~WFMODE) == WFEDIT) {
+ while (lp != wp->w_dotp) {
+ ++i;
+ lp = lforw(lp);
+ }
+ vscreen[i]->v_color = CTEXT;
+ vscreen[i]->v_flag |= (VFCHG | VFHBAD);
+ vtmove(i, 0);
+ for (j = 0; j < llength(lp); ++j)
+ vtputc(lgetc(lp, j));
+ vteeol();
+ } else if ((wp->w_flag & (WFEDIT | WFHARD)) != 0) {
+ hflag = TRUE;
+ while (i < wp->w_toprow + wp->w_ntrows) {
vscreen[i]->v_color = CTEXT;
vscreen[i]->v_flag |= (VFCHG | VFHBAD);
vtmove(i, 0);
- for (j = 0; j < llength(lp); ++j)
- vtputc(lgetc(lp, j));
- vteeol();
- } else if ((wp->w_flag & (WFEDIT | WFHARD)) != 0) {
- hflag = TRUE;
- while (i < wp->w_toprow + wp->w_ntrows) {
- vscreen[i]->v_color = CTEXT;
- vscreen[i]->v_flag |= (VFCHG | VFHBAD);
- vtmove(i, 0);
- if (lp != wp->w_bufp->b_linep) {
- for (j = 0; j < llength(lp); ++j)
- vtputc(lgetc(lp, j));
- lp = lforw(lp);
- }
- vteeol();
- ++i;
+ if (lp != wp->w_bufp->b_linep) {
+ for (j = 0; j < llength(lp); ++j)
+ vtputc(lgetc(lp, j));
+ lp = lforw(lp);
}
+ vteeol();
+ ++i;
}
- if ((wp->w_flag & WFMODE) != 0)
- modeline(wp);
- wp->w_flag = 0;
- wp->w_force = 0;
}
- wp = wp->w_wndp;
+ if ((wp->w_flag & WFMODE) != 0)
+ modeline(wp);
+ wp->w_flag = 0;
+ wp->w_force = 0;
}
lp = curwp->w_linep; /* Cursor location. */
currow = curwp->w_toprow;