X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcrt.c;h=b3d13f5a885a43fef598d289a662fd2187ece7c4;hb=3684640e6bdec97cb1b60a34d03e8cde63149215;hp=8b7f9d58ee961c812dd7e0c234fe1b6000b4a075;hpb=51d34367859892cb87c8727d93a02ed9f82fe958;p=sympathy.git diff --git a/src/crt.c b/src/crt.c index 8b7f9d5..b3d13f5 100644 --- a/src/crt.c +++ b/src/crt.c @@ -10,6 +10,21 @@ static char rcsid[] = "$Id$"; /* * $Log$ + * Revision 1.7 2008/02/07 12:41:06 james + * *** empty log message *** + * + * Revision 1.6 2008/02/07 12:16:04 james + * *** empty log message *** + * + * Revision 1.5 2008/02/06 11:30:37 james + * *** empty log message *** + * + * Revision 1.4 2008/02/05 01:11:46 james + * *** empty log message *** + * + * Revision 1.3 2008/02/04 20:23:55 james + * *** empty log message *** + * * Revision 1.2 2008/02/04 02:05:06 james * *** empty log message *** * @@ -20,16 +35,100 @@ static char rcsid[] = "$Id$"; #include "project.h" +void +crt_erase (CRT * c, CRT_Pos s, CRT_Pos e, int ea) +{ + CRT_CA *ps = &c->screen[CRT_ADDR_POS (&s)]; + CRT_CA *pe = &c->screen[CRT_ADDR_POS (&e)]; + + while (ps <= pe) + { + ps->chr = ' '; + if (ea){ + ps->attr = CRT_ATTR_NORMAL; + ps->color = CRT_COLOR_NORMAL; + } + ps++; + } + +} + void crt_cls (CRT * c) { + CRT_Pos s = { 0, 0 }; + CRT_Pos e = { CRT_COLS - 1, CRT_ROWS - 1 }; int i; - for (i = 0; i < CRT_CELS; ++i) + crt_erase (c, s, e, 1); + c->sh.dir=0; +} + +void +crt_scroll_up (CRT * c, CRT_Pos s, CRT_Pos e, int ea) +{ + int l, n; + int p; + + c->sh.s=s; + c->sh.e=e; + c->sh.dir=-1; + + s.x = 0; + e.x = CRT_COLS - 1; + + l = e.x - s.x; + l++; + l *= sizeof (CRT_CA); + + n = e.y - s.y; + + + p = CRT_ADDR_POS (&s); + + while (n--) + { + memcpy (&c->screen[p], &c->screen[p + CRT_COLS], l); + p += CRT_COLS; + } + + s.y = e.y; + crt_erase (c, s, e, ea); + +} + +void +crt_scroll_down (CRT * c, CRT_Pos s, CRT_Pos e, int ea) +{ + int l, n; + int p; + + c->sh.s=s; + c->sh.e=e; + c->sh.dir=1; + + + s.x = 0; + e.x = CRT_COLS - 1; + + l = e.x - s.x; + l++; + l *= sizeof (CRT_CA); + + n = e.y - s.y; + n++; + + p = CRT_ADDR_POS (&e); + + while (n--) { - c->screen[i].chr = ' '; - c->screen[i].chr = CRT_ATTR_NORMAL; + memcpy (&c->screen[p], &c->screen[p - CRT_COLS], l); + p -= CRT_COLS; } + + e.y = s.y; + crt_erase (c, s, e, ea); + } void @@ -40,6 +139,7 @@ crt_reset (CRT * c) c->pos.x = 0; c->pos.y = 0; c->hide_cursor = 1; + c->sh.dir=0; } void @@ -56,6 +156,5 @@ crt_insert (CRT * c, CRT_CA ca) c->screen[CRT_ADDR (c->pos.y, c->pos.x)] = ca; - - + c->sh.dir=0; }