/****************************************************************************
- * Copyright (c) 1998 Free Software Foundation, Inc. *
+ * Copyright (c) 1998-2001,2006 Free Software Foundation, Inc. *
* *
* Permission is hereby granted, free of charge, to any person obtaining a *
* copy of this software and associated documentation files (the *
#include <curses.priv.h>
-MODULE_ID("$Id: lib_redrawln.c,v 1.7 1998/09/19 20:09:50 Alexander.V.Lukyanov Exp $")
+MODULE_ID("$Id: lib_redrawln.c,v 1.11 2006/11/04 23:08:47 tom Exp $")
-int wredrawln(WINDOW *win, int beg, int num)
+NCURSES_EXPORT(int)
+wredrawln(WINDOW *win, int beg, int num)
{
- int i;
- int end;
- size_t len = (win->_maxx + 1) * sizeof(chtype);
+ int i;
+ int end;
+ size_t len = (win->_maxx + 1);
- T((T_CALLED("wredrawln(%p,%d,%d)"), win, beg, num));
+ T((T_CALLED("wredrawln(%p,%d,%d)"), win, beg, num));
- if (beg < 0)
- beg = 0;
+ if (beg < 0)
+ beg = 0;
- if (touchline (win, beg, num) == ERR)
- returnCode(ERR);
+ if (touchline(win, beg, num) == ERR)
+ returnCode(ERR);
- end = beg + num;
- if (end > win->_maxy + 1)
- end = win->_maxy + 1;
+ if (touchline(curscr, beg + win->_begy, num) == ERR)
+ returnCode(ERR);
- for (i = beg; i < end; i++)
- {
- memset (curscr->_line[i+win->_begy].text+win->_begx, 0, len);
- _nc_make_oldhash(i+win->_begy);
- }
+ end = beg + num;
+ if (end > curscr->_maxy + 1)
+ end = curscr->_maxy + 1;
+ if (end > win->_maxy + 1)
+ end = win->_maxy + 1;
- returnCode(OK);
+ if (len > (size_t) (curscr->_maxx + 1))
+ len = (size_t) (curscr->_maxx + 1);
+ len *= sizeof(curscr->_line[0].text[0]);
+
+ for (i = beg; i < end; i++) {
+ int crow = i + win->_begy;
+
+ memset(curscr->_line[crow].text + win->_begx, 0, len);
+ _nc_make_oldhash(crow);
+ }
+
+ returnCode(OK);
}