Coverity erroneously complains that we call wmove with x or y == -1, even though our copy of that function properly checks for that. But: setsyx is documented to always return OK (even on errors), so let it do that. (and make coverity happy in the process) Change-Id: I1bc9ba2a075037f0e1a855b67a93883978564887 Signed-off-by: Patrick Georgi <pgeorgi@chromium.org> Found-by: Coverity Scan #1260797 Reviewed-on: https://review.coreboot.org/17836 Tested-by: build bot (Jenkins) Reviewed-by: Martin Roth <martinroth@google.com>
		
			
				
	
	
		
			149 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Public Domain Curses */
 | 
						|
 | 
						|
#include <curspriv.h>
 | 
						|
 | 
						|
RCSID("$Id: getyx.c,v 1.29 2008/07/15 17:13:26 wmcbrine Exp $")
 | 
						|
 | 
						|
/*man-start**************************************************************
 | 
						|
 | 
						|
  Name:                                                         getyx
 | 
						|
 | 
						|
  Synopsis:
 | 
						|
        void getyx(WINDOW *win, int y, int x);
 | 
						|
        void getparyx(WINDOW *win, int y, int x);
 | 
						|
        void getbegyx(WINDOW *win, int y, int x);
 | 
						|
        void getmaxyx(WINDOW *win, int y, int x);
 | 
						|
 | 
						|
        void getsyx(int y, int x);
 | 
						|
        int setsyx(int y, int x);
 | 
						|
 | 
						|
        int getbegy(WINDOW *win);
 | 
						|
        int getbegx(WINDOW *win);
 | 
						|
        int getcury(WINDOW *win);
 | 
						|
        int getcurx(WINDOW *win);
 | 
						|
        int getpary(WINDOW *win);
 | 
						|
        int getparx(WINDOW *win);
 | 
						|
        int getmaxy(WINDOW *win);
 | 
						|
        int getmaxx(WINDOW *win);
 | 
						|
 | 
						|
  Description:
 | 
						|
        The getyx() macro (defined in curses.h -- the prototypes here
 | 
						|
        are merely illustrative) puts the current cursor position of the
 | 
						|
        specified window into y and x. getbegyx() and getmaxyx() return
 | 
						|
        the starting coordinates and size of the specified window,
 | 
						|
        respectively. getparyx() returns the starting coordinates of the
 | 
						|
        parent's window, if the specified window is a subwindow;
 | 
						|
        otherwise it sets y and x to -1. These are all macros.
 | 
						|
 | 
						|
        getsyx() gets the coordinates of the virtual screen cursor, and
 | 
						|
        stores them in y and x. If leaveok() is TRUE, it returns -1, -1.
 | 
						|
        If lines have been removed with ripoffline(), then getsyx()
 | 
						|
        includes these lines in its count; so, the returned y and x
 | 
						|
        values should only be used with setsyx().
 | 
						|
 | 
						|
        setsyx() sets the virtual screen cursor to the y, x coordinates.
 | 
						|
        If y, x are -1, -1, leaveok() is set TRUE.
 | 
						|
 | 
						|
        getsyx() and setsyx() are meant to be used by a library routine
 | 
						|
        that manipulates curses windows without altering the position of
 | 
						|
        the cursor. Note that getsyx() is defined only as a macro.
 | 
						|
 | 
						|
        getbegy(), getbegx(), getcurx(), getcury(), getmaxy(),
 | 
						|
        getmaxx(), getpary(), and getparx() return the appropriate
 | 
						|
        coordinate or size values, or ERR in the case of a NULL window.
 | 
						|
 | 
						|
  Portability                                X/Open    BSD    SYS V
 | 
						|
        getyx                                   Y       Y       Y
 | 
						|
        getparyx                                -       -      4.0
 | 
						|
        getbegyx                                -       -      3.0
 | 
						|
        getmaxyx                                -       -      3.0
 | 
						|
        getsyx                                  -       -      3.0
 | 
						|
        setsyx                                  -       -      3.0
 | 
						|
        getbegy                                 -       -       -
 | 
						|
        getbegx                                 -       -       -
 | 
						|
        getcury                                 -       -       -
 | 
						|
        getcurx                                 -       -       -
 | 
						|
        getpary                                 -       -       -
 | 
						|
        getparx                                 -       -       -
 | 
						|
        getmaxy                                 -       -       -
 | 
						|
        getmaxx                                 -       -       -
 | 
						|
 | 
						|
**man-end****************************************************************/
 | 
						|
 | 
						|
int getbegy(WINDOW *win)
 | 
						|
{
 | 
						|
    PDC_LOG(("getbegy() - called\n"));
 | 
						|
 | 
						|
    return win ? win->_begy : ERR;
 | 
						|
}
 | 
						|
 | 
						|
int getbegx(WINDOW *win)
 | 
						|
{
 | 
						|
    PDC_LOG(("getbegx() - called\n"));
 | 
						|
 | 
						|
    return win ? win->_begx : ERR;
 | 
						|
}
 | 
						|
 | 
						|
int getcury(WINDOW *win)
 | 
						|
{
 | 
						|
    PDC_LOG(("getcury() - called\n"));
 | 
						|
 | 
						|
    return win ? win->_cury : ERR;
 | 
						|
}
 | 
						|
 | 
						|
int getcurx(WINDOW *win)
 | 
						|
{
 | 
						|
    PDC_LOG(("getcurx() - called\n"));
 | 
						|
 | 
						|
    return win ? win->_curx : ERR;
 | 
						|
}
 | 
						|
 | 
						|
int getpary(WINDOW *win)
 | 
						|
{
 | 
						|
    PDC_LOG(("getpary() - called\n"));
 | 
						|
 | 
						|
    return win ? win->_pary : ERR;
 | 
						|
}
 | 
						|
 | 
						|
int getparx(WINDOW *win)
 | 
						|
{
 | 
						|
    PDC_LOG(("getparx() - called\n"));
 | 
						|
 | 
						|
    return win ? win->_parx : ERR;
 | 
						|
}
 | 
						|
 | 
						|
int getmaxy(WINDOW *win)
 | 
						|
{
 | 
						|
    PDC_LOG(("getmaxy() - called\n"));
 | 
						|
 | 
						|
    return win ? win->_maxy : ERR;
 | 
						|
}
 | 
						|
 | 
						|
int getmaxx(WINDOW *win)
 | 
						|
{
 | 
						|
    PDC_LOG(("getmaxx() - called\n"));
 | 
						|
 | 
						|
    return win ? win->_maxx : ERR;
 | 
						|
}
 | 
						|
 | 
						|
int setsyx(int y, int x)
 | 
						|
{
 | 
						|
    PDC_LOG(("setsyx() - called\n"));
 | 
						|
 | 
						|
    if(y == -1 && x == -1)
 | 
						|
    {
 | 
						|
        curscr->_leaveit = TRUE;
 | 
						|
        return OK;
 | 
						|
    }
 | 
						|
    else if (y == -1 || x == -1)
 | 
						|
    {
 | 
						|
        return OK;
 | 
						|
    }
 | 
						|
    else
 | 
						|
    {
 | 
						|
        curscr->_leaveit = FALSE;
 | 
						|
        wmove(curscr, y, x);
 | 
						|
	return OK;
 | 
						|
    }
 | 
						|
}
 |