chiark / gitweb /
*** empty log message ***
[sympathy.git] / src / crt.c
index a9e6e8637655fb0c273ce55ef8f3538fcd29c200..9d6606a15bcb148486987ee0353aa35ab59d0ca5 100644 (file)
--- a/src/crt.c
+++ b/src/crt.c
@@ -10,6 +10,21 @@ static char rcsid[] = "$Id$";
 
 /*
  * $Log$
+ * Revision 1.14  2008/02/27 00:27:21  james
+ * *** empty log message ***
+ *
+ * Revision 1.13  2008/02/26 23:56:12  james
+ * *** empty log message ***
+ *
+ * Revision 1.12  2008/02/26 23:23:17  james
+ * *** empty log message ***
+ *
+ * Revision 1.11  2008/02/23 11:48:37  james
+ * *** empty log message ***
+ *
+ * Revision 1.10  2008/02/22 17:07:00  james
+ * *** empty log message ***
+ *
  * Revision 1.9  2008/02/07 13:22:51  james
  * *** empty log message ***
  *
@@ -42,7 +57,7 @@ static char rcsid[] = "$Id$";
 #include "project.h"
 
 void
-crt_erase (CRT * c, CRT_Pos s, CRT_Pos e, int ea)
+crt_erase (CRT * c, CRT_Pos s, CRT_Pos e, int ea, int color)
 {
   CRT_CA *ps = &c->screen[CRT_ADDR_POS (&s)];
   CRT_CA *pe = &c->screen[CRT_ADDR_POS (&e)];
@@ -53,7 +68,7 @@ crt_erase (CRT * c, CRT_Pos s, CRT_Pos e, int ea)
       if (ea)
         {
           ps->attr = CRT_ATTR_NORMAL;
-          ps->color = CRT_COLOR_NORMAL;
+          ps->color = color;
         }
       ps++;
     }
@@ -67,12 +82,14 @@ crt_cls (CRT * c)
   CRT_Pos e = { CRT_COLS - 1, CRT_ROWS - 1 };
   int i;
 
-  crt_erase (c, s, e, 1);
+  crt_erase (c, s, e, 1, CRT_COLOR_NORMAL);
+#if 0
   c->sh.dir = 0;
+#endif
 }
 
 void
-crt_scroll_up (CRT * c, CRT_Pos s, CRT_Pos e, int ea)
+crt_scroll_up (CRT * c, CRT_Pos s, CRT_Pos e, int ea, int color)
 {
   int l, n;
   int p;
@@ -81,9 +98,11 @@ crt_scroll_up (CRT * c, CRT_Pos s, CRT_Pos e, int ea)
   s.x = 0;
   e.x = CRT_COLS - 1;
 
+#if 0
   c->sh.s = s;
   c->sh.e = e;
   c->sh.dir = -1;
+#endif
 
   l = e.x - s.x;
   l++;
@@ -101,12 +120,12 @@ crt_scroll_up (CRT * c, CRT_Pos s, CRT_Pos e, int ea)
     }
 
   s.y = e.y;
-  crt_erase (c, s, e, ea);
+  crt_erase (c, s, e, ea, color);
 
 }
 
 void
-crt_scroll_down (CRT * c, CRT_Pos s, CRT_Pos e, int ea)
+crt_scroll_down (CRT * c, CRT_Pos s, CRT_Pos e, int ea, int color)
 {
   int l, n;
   int p;
@@ -114,27 +133,29 @@ crt_scroll_down (CRT * c, CRT_Pos s, CRT_Pos e, int ea)
   s.x = 0;
   e.x = CRT_COLS - 1;
 
+#if 0
   c->sh.s = s;
   c->sh.e = e;
   c->sh.dir = 1;
+#endif
 
   l = e.x - s.x;
   l++;
   l *= sizeof (CRT_CA);
 
   n = e.y - s.y;
-  n++;
+  //n++;
 
   p = CRT_ADDR_POS (&e);
 
   while (n--)
     {
-      memcpy (&c->screen[p], &c->screen[p - CRT_COLS], l);
       p -= CRT_COLS;
+      memcpy (&c->screen[p], &c->screen[p - CRT_COLS], l);
     }
 
   e.y = s.y;
-  crt_erase (c, s, e, ea);
+  crt_erase (c, s, e, ea, color);
 
 }
 
@@ -146,7 +167,10 @@ crt_reset (CRT * c)
   c->pos.x = 0;
   c->pos.y = 0;
   c->hide_cursor = 1;
+  c->width = CRT_COLS;
+#if 0
   c->sh.dir = 0;
+#endif
 }
 
 void
@@ -163,5 +187,7 @@ crt_insert (CRT * c, CRT_CA ca)
 
   c->screen[CRT_ADDR (c->pos.y, c->pos.x)] = ca;
 
+#if 0
   c->sh.dir = 0;
+#endif
 }