Fri, 24 Jul 2015 04:24:38 +0300
Apply Leonard's patch for fixing the colors:
The colors were broken again.
* isprint for some reason returned true when the given byte is higher than 255.
The char cast of the byte was then printed which resulted in odd characters
popping up. Black appeared as ^@ which is NULL in caret notation.
* After that, the colors were all messed up because the RLINE enum didn't take
in account the color swapping.
So instead of messing up the enum order/number I went for a new "range-like"
method.
* After fixing all of that, I noticed the Interface::render_colorline had a
broken loop since the VS2010 commits.
This made the lines not print entierely and messed up the colors etc.
/* Public Domain Curses */ #include <curspriv.h> RCSID("$Id: clear.c,v 1.35 2008/07/13 16:08:18 wmcbrine Exp $") /*man-start************************************************************** Name: clear Synopsis: int clear(void); int wclear(WINDOW *win); int erase(void); int werase(WINDOW *win); int clrtobot(void); int wclrtobot(WINDOW *win); int clrtoeol(void); int wclrtoeol(WINDOW *win); Description: erase() and werase() copy blanks (i.e. the background chtype) to every cell of the window. clear() and wclear() are similar to erase() and werase(), but they also call clearok() to ensure that the the window is cleared on the next wrefresh(). clrtobot() and wclrtobot() clear the window from the current cursor position to the end of the window. clrtoeol() and wclrtoeol() clear the window from the current cursor position to the end of the current line. Return Value: All functions return OK on success and ERR on error. Portability X/Open BSD SYS V clear Y Y Y wclear Y Y Y erase Y Y Y werase Y Y Y clrtobot Y Y Y wclrtobot Y Y Y clrtoeol Y Y Y wclrtoeol Y Y Y **man-end****************************************************************/ int wclrtoeol(WINDOW *win) { int x, y, minx; chtype blank, *ptr; PDC_LOG(("wclrtoeol() - called: Row: %d Col: %d\n", win->_cury, win->_curx)); if (!win) return ERR; y = win->_cury; x = win->_curx; /* wrs (4/10/93) account for window background */ blank = win->_bkgd; for (minx = x, ptr = &win->_y[y][x]; minx < win->_maxx; minx++, ptr++) *ptr = blank; if (x < win->_firstch[y] || win->_firstch[y] == _NO_CHANGE) win->_firstch[y] = x; win->_lastch[y] = win->_maxx - 1; PDC_sync(win); return OK; } int clrtoeol(void) { PDC_LOG(("clrtoeol() - called\n")); return wclrtoeol(stdscr); } int wclrtobot(WINDOW *win) { int savey = win->_cury; int savex = win->_curx; PDC_LOG(("wclrtobot() - called\n")); if (!win) return ERR; /* should this involve scrolling region somehow ? */ if (win->_cury + 1 < win->_maxy) { win->_curx = 0; win->_cury++; for (; win->_maxy > win->_cury; win->_cury++) wclrtoeol(win); win->_cury = savey; win->_curx = savex; } wclrtoeol(win); PDC_sync(win); return OK; } int clrtobot(void) { PDC_LOG(("clrtobot() - called\n")); return wclrtobot(stdscr); } int werase(WINDOW *win) { PDC_LOG(("werase() - called\n")); if (wmove(win, 0, 0) == ERR) return ERR; return wclrtobot(win); } int erase(void) { PDC_LOG(("erase() - called\n")); return werase(stdscr); } int wclear(WINDOW *win) { PDC_LOG(("wclear() - called\n")); if (!win) return ERR; win->_clear = TRUE; return werase(win); } int clear(void) { PDC_LOG(("clear() - called\n")); return wclear(stdscr); }