2017-11-17 20:12:59 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* apps/graphics/pdcurses/pdc_outopts.c
|
|
|
|
* Public Domain Curses
|
|
|
|
* RCSID("$Id: outopts.c,v 1.39 2008/07/14 12:22:13 wmcbrine Exp $")
|
|
|
|
*
|
|
|
|
* Copyright (C) 2017 Gregory Nutt. All rights reserved.
|
|
|
|
* Adapted by: Gregory Nutt <gnutt@nuttx.org>
|
|
|
|
*
|
|
|
|
* Adapted from the original public domain pdcurses by Gregory Nutt and
|
|
|
|
* released as part of NuttX under the 3-clause BSD license:
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in
|
|
|
|
* the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
|
|
|
* used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
|
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/* Name: outopts
|
|
|
|
*
|
|
|
|
* Synopsis:
|
|
|
|
* int clearok(WINDOW *win, bool bf);
|
|
|
|
* int idlok(WINDOW *win, bool bf);
|
|
|
|
* void idcok(WINDOW *win, bool bf);
|
|
|
|
* void immedok(WINDOW *win, bool bf);
|
|
|
|
* int leaveok(WINDOW *win, bool bf);
|
|
|
|
* int setscrreg(int top, int bot);
|
|
|
|
* int wsetscrreg(WINDOW *win, int top, int bot);
|
|
|
|
* int scrollok(WINDOW *win, bool bf);
|
|
|
|
*
|
|
|
|
* int raw_output(bool bf);
|
|
|
|
*
|
|
|
|
* Description:
|
2017-11-17 20:23:02 +01:00
|
|
|
* With clearok(), if bf is true, the next call to wrefresh() with
|
|
|
|
* this window will clear the screen completely and redraw the
|
2017-11-17 20:12:59 +01:00
|
|
|
* entire screen.
|
|
|
|
*
|
2017-11-17 20:23:02 +01:00
|
|
|
* immedok(), called with a second argument of true, causes an
|
|
|
|
* automatic wrefresh() every time a change is made to the
|
2017-11-17 20:12:59 +01:00
|
|
|
* specified window.
|
|
|
|
*
|
|
|
|
* Normally, the hardware cursor is left at the location of the
|
|
|
|
* window being refreshed. leaveok() allows the cursor to be
|
|
|
|
* left wherever the update happens to leave it. It's useful
|
|
|
|
* for applications where the cursor is not used, since it reduces
|
|
|
|
* the need for cursor motions. If possible, the cursor is made
|
|
|
|
* invisible when this option is enabled.
|
|
|
|
*
|
2017-11-17 20:23:02 +01:00
|
|
|
* wsetscrreg() sets a scrolling region in a window; "top" and
|
|
|
|
* "bot" are the line numbers for the top and bottom margins. If
|
|
|
|
* this option and scrollok() are enabled, any attempt to move off
|
|
|
|
* the bottom margin will cause all lines in the scrolling region
|
2017-11-17 20:12:59 +01:00
|
|
|
* to scroll up one line. setscrreg() is the stdscr version.
|
|
|
|
*
|
2017-11-17 20:23:02 +01:00
|
|
|
* idlok() and idcok() do nothing in PDCurses, but are provided for
|
2017-11-17 20:12:59 +01:00
|
|
|
* compatibility with other curses implementations.
|
|
|
|
*
|
2017-11-17 20:23:02 +01:00
|
|
|
* raw_output() enables the output of raw characters using the
|
|
|
|
* standard *add* and *ins* curses functions (that is, it disables
|
2017-11-17 20:12:59 +01:00
|
|
|
* translation of control characters).
|
|
|
|
*
|
|
|
|
* Return Value:
|
|
|
|
* All functions return OK on success and ERR on error.
|
|
|
|
*
|
|
|
|
* Portability X/Open BSD SYS V
|
|
|
|
* clearok Y Y Y
|
|
|
|
* idlok Y Y Y
|
|
|
|
* idcok Y - 4.0
|
|
|
|
* immedok Y - 4.0
|
|
|
|
* leaveok Y Y Y
|
|
|
|
* setscrreg Y Y Y
|
|
|
|
* wsetscrreg Y Y Y
|
|
|
|
* scrollok Y Y Y
|
|
|
|
* raw_output - - -
|
|
|
|
*/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "curspriv.h"
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Public Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
2017-11-18 01:23:23 +01:00
|
|
|
int clearok(WINDOW *win, bool bf)
|
2017-11-17 20:12:59 +01:00
|
|
|
{
|
|
|
|
PDC_LOG(("clearok() - called\n"));
|
|
|
|
|
|
|
|
if (!win)
|
|
|
|
{
|
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
|
|
|
|
win->_clear = bf;
|
|
|
|
return OK;
|
|
|
|
}
|
|
|
|
|
2017-11-18 01:23:23 +01:00
|
|
|
int idlok(WINDOW *win, bool bf)
|
2017-11-17 20:12:59 +01:00
|
|
|
{
|
|
|
|
PDC_LOG(("idlok() - called\n"));
|
|
|
|
|
|
|
|
return OK;
|
|
|
|
}
|
|
|
|
|
2017-11-18 01:23:23 +01:00
|
|
|
void idcok(WINDOW *win, bool bf)
|
2017-11-17 20:12:59 +01:00
|
|
|
{
|
|
|
|
PDC_LOG(("idcok() - called\n"));
|
|
|
|
}
|
|
|
|
|
2017-11-18 01:23:23 +01:00
|
|
|
void immedok(WINDOW *win, bool bf)
|
2017-11-17 20:12:59 +01:00
|
|
|
{
|
|
|
|
PDC_LOG(("immedok() - called\n"));
|
|
|
|
|
|
|
|
if (win)
|
|
|
|
{
|
|
|
|
win->_immed = bf;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-18 01:23:23 +01:00
|
|
|
int leaveok(WINDOW *win, bool bf)
|
2017-11-17 20:12:59 +01:00
|
|
|
{
|
|
|
|
PDC_LOG(("leaveok() - called\n"));
|
|
|
|
|
|
|
|
if (!win)
|
|
|
|
{
|
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
|
|
|
|
win->_leaveit = bf;
|
|
|
|
curs_set(!bf);
|
|
|
|
return OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
int setscrreg(int top, int bottom)
|
|
|
|
{
|
|
|
|
PDC_LOG(("setscrreg() - called: top %d bottom %d\n", top, bottom));
|
|
|
|
|
|
|
|
return wsetscrreg(stdscr, top, bottom);
|
|
|
|
}
|
|
|
|
|
2017-11-18 01:23:23 +01:00
|
|
|
int wsetscrreg(WINDOW *win, int top, int bottom)
|
2017-11-17 20:12:59 +01:00
|
|
|
{
|
|
|
|
PDC_LOG(("wsetscrreg() - called: top %d bottom %d\n", top, bottom));
|
|
|
|
|
|
|
|
if (win && 0 <= top && top <= win->_cury &&
|
|
|
|
win->_cury <= bottom && bottom < win->_maxy)
|
|
|
|
{
|
|
|
|
win->_tmarg = top;
|
|
|
|
win->_bmarg = bottom;
|
|
|
|
|
|
|
|
return OK;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-18 01:23:23 +01:00
|
|
|
int scrollok(WINDOW *win, bool bf)
|
2017-11-17 20:12:59 +01:00
|
|
|
{
|
|
|
|
PDC_LOG(("scrollok() - called\n"));
|
|
|
|
|
|
|
|
if (!win)
|
|
|
|
{
|
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
|
|
|
|
win->_scroll = bf;
|
|
|
|
return OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
int raw_output(bool bf)
|
|
|
|
{
|
|
|
|
PDC_LOG(("raw_output() - called\n"));
|
|
|
|
|
|
|
|
SP->raw_out = bf;
|
|
|
|
return OK;
|
|
|
|
}
|