move entry/exit debugging to 21.1
[unix-history] / usr / src / lib / libcurses / toucholap.c
index ac7018a..53f193d 100644 (file)
@@ -1,57 +1,51 @@
 /*
 /*
- * Copyright (c) 1981 Regents of the University of California.
- * All rights reserved.
+ * Copyright (c) 1981, 1993, 1994
+ *     The Regents of the University of California.  All rights reserved.
  *
  *
- * Redistribution and use in source and binary forms are permitted
- * provided that the above copyright notice and this paragraph are
- * duplicated in all such forms and that any documentation,
- * advertising materials, and other materials related to such
- * distribution and use acknowledge that the software was developed
- * by the University of California, Berkeley.  The name of the
- * University may not be used to endorse or promote products derived
- * from this software without specific prior written permission.
- * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
- * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
- * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
+ * %sccs.include.redist.c%
  */
 
 #ifndef lint
  */
 
 #ifndef lint
-static char sccsid[] = "@(#)toucholap.c        5.3 (Berkeley) %G%";
+static char sccsid[] = "@(#)toucholap.c        8.2 (Berkeley) %G%";
 #endif /* not lint */
 
 #endif /* not lint */
 
-# include      "curses.ext"
-
-# define       min(a,b)        (a < b ? a : b)
-# define       max(a,b)        (a > b ? a : b)
+#include "curses.h"
 
 /*
 
 /*
+ * touchoverlap --
  *     Touch, on win2, the part that overlaps with win1.
  *     Touch, on win2, the part that overlaps with win1.
- *
  */
  */
+int
 touchoverlap(win1, win2)
 touchoverlap(win1, win2)
-reg WINDOW     *win1, *win2; {
+       register WINDOW *win1, *win2;
+{
+       register int y, endy, endx, starty, startx;
 
 
-       reg int         x, y, endy, endx, starty, startx;
-
-# ifdef DEBUG
-       fprintf(outf, "TOUCHOVERLAP(%0.2o, %0.2o);\n", win1, win2);
-# endif
-       starty = max(win1->_begy, win2->_begy);
-       startx = max(win1->_begx, win2->_begx);
-       endy = min(win1->_maxy + win1->_begy, win2->_maxy + win2->_begx);
-       endx = min(win1->_maxx + win1->_begx, win2->_maxx + win2->_begx);
-# ifdef DEBUG
-       fprintf(outf, "TOUCHOVERLAP:from (%d,%d) to (%d,%d)\n", starty, startx, endy, endx);
-       fprintf(outf, "TOUCHOVERLAP:win1 (%d,%d) to (%d,%d)\n", win1->_begy, win1->_begx, win1->_begy + win1->_maxy, win1->_begx + win1->_maxx);
-       fprintf(outf, "TOUCHOVERLAP:win2 (%d,%d) to (%d,%d)\n", win2->_begy, win2->_begx, win2->_begy + win2->_maxy, win2->_begx + win2->_maxx);
-# endif
+#ifdef DEBUG
+       __CTRACE("touchoverlap: (%0.2o, %0.2o);\n", win1, win2);
+#endif
+       starty = max(win1->begy, win2->begy);
+       startx = max(win1->begx, win2->begx);
+       endy = min(win1->maxy + win1->begy, win2->maxy + win2->begx);
+       endx = min(win1->maxx + win1->begx, win2->maxx + win2->begx);
+#ifdef DEBUG
+       __CTRACE("touchoverlap: from (%d,%d) to (%d,%d)\n",
+           starty, startx, endy, endx);
+       __CTRACE("touchoverlap: win1 (%d,%d) to (%d,%d)\n",
+           win1->begy, win1->begx, win1->begy + win1->maxy,
+           win1->begx + win1->maxx);
+       __CTRACE("touchoverlap: win2 (%d,%d) to (%d,%d)\n",
+           win2->begy, win2->begx, win2->begy + win2->maxy,
+           win2->begx + win2->maxx);
+#endif
        if (starty >= endy || startx >= endx)
        if (starty >= endy || startx >= endx)
-               return;
-       starty -= win2->_begy;
-       startx -= win2->_begx;
-       endy -= win2->_begy;
-       endx -= win2->_begx;
-       endx--;
-       for (y = starty; y < endy; y++)
-               touchline(win2, y, startx, endx);
+               return (OK);
+       starty -= win2->begy;
+       startx -= win2->begx;
+       endy -= win2->begy;
+       endx -= win2->begx;
+       for (--endx, y = starty; y < endy; y++)
+               __touchline(win2, y, startx, endx, 0);
+       return (OK);
 }
 }
+