2011-07-02 00:53:45 -04:00
|
|
|
/************************************************************************
|
|
|
|
* *
|
|
|
|
* Star Traders: A Game of Interstellar Trading *
|
|
|
|
* Copyright (C) 1990-2011, John Zaitseff *
|
|
|
|
* *
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
Author: John Zaitseff <J.Zaitseff@zap.org.au>
|
|
|
|
$Id$
|
|
|
|
|
2011-07-19 06:32:00 -04:00
|
|
|
This file, intf.h, contains declarations for basic text input/output
|
|
|
|
functions used in Star Traders. It uses the X/Open Curses library to
|
|
|
|
provide terminal-independent functionality.
|
2011-07-02 00:53:45 -04:00
|
|
|
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify it
|
|
|
|
under the terms of the GNU General Public License as published by the
|
|
|
|
Free Software Foundation, either version 3 of the License, or (at your
|
|
|
|
option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see http://www.gnu.org/licenses/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef included_INTF_H
|
|
|
|
#define included_INTF_H 1
|
|
|
|
|
|
|
|
|
2011-07-02 07:25:57 -04:00
|
|
|
#include "system.h"
|
|
|
|
|
|
|
|
|
2011-07-02 00:53:45 -04:00
|
|
|
/************************************************************************
|
|
|
|
* Constants and type declarations *
|
|
|
|
************************************************************************/
|
|
|
|
|
2011-07-20 02:12:02 -04:00
|
|
|
/*
|
|
|
|
This version of Star Traders only utilises WIN_COLS x WIN_LINES of a
|
|
|
|
terminal screen; this terminal must be at least MIN_COLS x MIN_LINES in
|
|
|
|
size; the newtxwin() function automatically places a new window in the
|
|
|
|
centre-top of the terminal screen. The program does not yet handle
|
|
|
|
terminal resizing events.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define MIN_LINES 24 // Minimum number of lines in terminal
|
|
|
|
#define MIN_COLS 80 // Minimum number of columns in terminal
|
|
|
|
|
|
|
|
#define WIN_LINES MIN_LINES // Number of lines in main window
|
|
|
|
#define WIN_COLS MIN_COLS // Number of columns in main window
|
|
|
|
|
|
|
|
#define WCENTER(x) ((COLS - (x)) / 2) // Centre the window
|
|
|
|
|
|
|
|
|
|
|
|
// Visibility of the cursor in Curses (for curs_set())
|
2011-07-04 05:15:38 -04:00
|
|
|
typedef enum curs_type {
|
|
|
|
CURS_INVISIBLE = 0,
|
|
|
|
CURS_NORMAL = 1,
|
|
|
|
CURS_VISIBLE = 2
|
|
|
|
} curs_type_t;
|
|
|
|
|
2011-07-20 02:12:02 -04:00
|
|
|
#define CURS_OFF CURS_INVISIBLE
|
|
|
|
#define CURS_ON CURS_NORMAL
|
2011-07-04 08:02:01 -04:00
|
|
|
|
|
|
|
|
2011-07-20 02:12:02 -04:00
|
|
|
// Keycodes not defined by Curses
|
|
|
|
#define KEY_BS 0010 // ASCII ^H backspace
|
|
|
|
#define KEY_TAB 0011 // ASCII ^I character tabulation
|
|
|
|
#define KEY_RETURN 0012 // ASCII ^J line feed
|
|
|
|
#define KEY_ESC 0033 // ASCII ^[ escape
|
|
|
|
#define KEY_DEL 0177 // ASCII delete
|
2011-07-10 20:31:19 -04:00
|
|
|
|
2011-07-20 02:12:02 -04:00
|
|
|
#define KEY_CTRL(x) ((x) - 0100) // ASCII control character
|
2011-07-10 20:31:19 -04:00
|
|
|
|
2011-07-20 02:12:02 -04:00
|
|
|
#define KEY_ILLEGAL 077777 // No key should ever return this!
|
|
|
|
|
2011-07-20 23:16:42 -04:00
|
|
|
// Keycodes for inserting the default value in input routines
|
|
|
|
#define KEY_DEFAULTVAL1 '='
|
|
|
|
#define KEY_DEFAULTVAL2 ';'
|
2011-07-20 02:12:02 -04:00
|
|
|
|
|
|
|
// Control-arrow key combinations, as returned by NCurses
|
2011-07-10 20:31:19 -04:00
|
|
|
#ifndef KEY_CDOWN
|
2011-07-20 02:12:02 -04:00
|
|
|
# define KEY_CDOWN 01007 // CTRL + Down Arrow
|
|
|
|
# define KEY_CUP 01060 // CTRL + Up Arrow
|
|
|
|
# define KEY_CLEFT 01033 // CTRL + Left Arrow
|
|
|
|
# define KEY_CRIGHT 01052 // CTRL + Right Arrow
|
2011-07-10 20:31:19 -04:00
|
|
|
#endif
|
2011-07-20 02:12:02 -04:00
|
|
|
|
|
|
|
// Keycodes only defined by NCurses
|
|
|
|
#ifndef KEY_RESIZE
|
|
|
|
# define KEY_RESIZE KEY_ILLEGAL
|
2011-07-10 20:31:19 -04:00
|
|
|
#endif
|
2011-07-20 02:12:02 -04:00
|
|
|
#ifndef KEY_EVENT
|
|
|
|
# define KEY_EVENT KEY_ILLEGAL
|
2011-07-10 20:31:19 -04:00
|
|
|
#endif
|
2011-07-20 02:12:02 -04:00
|
|
|
#ifndef KEY_MOUSE
|
|
|
|
# define KEY_MOUSE KEY_ILLEGAL
|
2011-07-10 20:31:19 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Timeout value (in ms) for Meta-X-style keyboard input
|
2011-07-20 02:12:02 -04:00
|
|
|
#ifdef NCURSES_VERSION
|
|
|
|
# define META_TIMEOUT ESCDELAY
|
|
|
|
#else
|
|
|
|
# define META_TIMEOUT 1000
|
|
|
|
#endif
|
2011-07-04 08:02:01 -04:00
|
|
|
|
2011-07-02 00:53:45 -04:00
|
|
|
|
2011-07-02 09:19:40 -04:00
|
|
|
/*
|
2011-07-20 02:12:02 -04:00
|
|
|
Colour pairs used in Star Traders. This list MUST be synchronised with
|
|
|
|
the initialisation of colour pairs in init_screen().
|
2011-07-02 09:19:40 -04:00
|
|
|
|
2011-07-20 02:12:02 -04:00
|
|
|
X/Open Curses only lists the following colours: black, blue, green,
|
|
|
|
cyan, red, magenta, yellow, white. Most implementations allow these
|
|
|
|
colours plus bold versions (for the foreground).
|
|
|
|
*/
|
2011-07-02 07:25:57 -04:00
|
|
|
enum color_pairs {
|
|
|
|
DEFAULT_COLORS = 0,
|
2011-07-14 01:16:04 -04:00
|
|
|
BLACK_ON_WHITE,
|
2011-07-20 02:12:02 -04:00
|
|
|
BLUE_ON_BLACK,
|
|
|
|
GREEN_ON_BLACK,
|
2011-07-14 01:16:04 -04:00
|
|
|
CYAN_ON_BLUE,
|
2011-07-20 02:12:02 -04:00
|
|
|
RED_ON_BLACK,
|
2011-07-04 08:02:01 -04:00
|
|
|
YELLOW_ON_BLACK,
|
|
|
|
YELLOW_ON_BLUE,
|
2011-07-02 07:25:57 -04:00
|
|
|
YELLOW_ON_CYAN,
|
2011-07-14 01:16:04 -04:00
|
|
|
WHITE_ON_BLACK,
|
|
|
|
WHITE_ON_BLUE,
|
2011-07-20 02:12:02 -04:00
|
|
|
WHITE_ON_RED
|
2011-07-02 07:25:57 -04:00
|
|
|
};
|
|
|
|
|
2011-07-20 02:12:02 -04:00
|
|
|
// Colour and non-colour character rendition selection
|
|
|
|
#define ATTR(color, nocolor) (use_color ? (color) : (nocolor))
|
|
|
|
|
2011-07-20 03:01:25 -04:00
|
|
|
/*
|
|
|
|
Character renditions (attributes) used in Star Traders
|
|
|
|
*/
|
2011-07-20 02:12:02 -04:00
|
|
|
#define ATTR_ROOT_WINDOW ATTR(COLOR_PAIR(WHITE_ON_BLACK), A_NORMAL)
|
2011-07-20 03:01:25 -04:00
|
|
|
#define ATTR_GAME_TITLE ATTR(COLOR_PAIR(YELLOW_ON_CYAN) | A_BOLD, A_REVERSE | A_BOLD)
|
|
|
|
|
2011-07-20 02:12:02 -04:00
|
|
|
#define ATTR_NORMAL_WINDOW ATTR(COLOR_PAIR(WHITE_ON_BLUE), A_NORMAL)
|
2011-07-20 03:01:25 -04:00
|
|
|
#define ATTR_TITLE ATTR(COLOR_PAIR(YELLOW_ON_BLACK) | A_BOLD, A_REVERSE)
|
|
|
|
#define ATTR_SUBTITLE ATTR(COLOR_PAIR(WHITE_ON_BLACK), A_REVERSE)
|
|
|
|
#define ATTR_NORMAL ATTR_NORMAL_WINDOW
|
|
|
|
#define ATTR_HIGHLIGHT ATTR(COLOR_PAIR(YELLOW_ON_BLUE) | A_BOLD, A_BOLD)
|
|
|
|
#define ATTR_BLINK ATTR(COLOR_PAIR(YELLOW_ON_BLUE) | A_BOLD | A_BLINK, A_BOLD | A_BLINK)
|
|
|
|
#define ATTR_KEYCODE ATTR(COLOR_PAIR(YELLOW_ON_BLACK) | A_BOLD, A_REVERSE)
|
|
|
|
#define ATTR_CHOICE ATTR(COLOR_PAIR(WHITE_ON_RED) | A_BOLD, A_REVERSE)
|
2011-07-20 02:12:02 -04:00
|
|
|
#define ATTR_INPUT_FIELD ATTR(COLOR_PAIR(WHITE_ON_BLACK), A_BOLD | '_')
|
2011-07-20 03:01:25 -04:00
|
|
|
#define ATTR_WAITFORKEY ATTR(COLOR_PAIR(CYAN_ON_BLUE), A_NORMAL)
|
|
|
|
|
|
|
|
#define ATTR_MAP_WINDOW ATTR(COLOR_PAIR(WHITE_ON_BLACK), A_NORMAL)
|
|
|
|
#define ATTR_MAPWIN_TITLE ATTR(COLOR_PAIR(WHITE_ON_BLUE), A_NORMAL)
|
|
|
|
#define ATTR_MAPWIN_HIGHLIGHT ATTR(COLOR_PAIR(YELLOW_ON_BLUE) | A_BOLD, A_BOLD)
|
|
|
|
#define ATTR_MAPWIN_BLINK ATTR(COLOR_PAIR(YELLOW_ON_BLUE) | A_BOLD | A_BLINK, A_BOLD | A_BLINK)
|
2011-07-20 02:12:02 -04:00
|
|
|
#define ATTR_MAP_EMPTY ATTR(COLOR_PAIR(BLUE_ON_BLACK) | A_BOLD, A_NORMAL)
|
|
|
|
#define ATTR_MAP_OUTPOST ATTR(COLOR_PAIR(GREEN_ON_BLACK) | A_BOLD, A_NORMAL)
|
|
|
|
#define ATTR_MAP_STAR ATTR(COLOR_PAIR(YELLOW_ON_BLACK) | A_BOLD, A_BOLD)
|
|
|
|
#define ATTR_MAP_COMPANY ATTR(COLOR_PAIR(RED_ON_BLACK) | A_BOLD, A_BOLD)
|
|
|
|
#define ATTR_MAP_CHOICE ATTR(COLOR_PAIR(WHITE_ON_RED) | A_BOLD, A_REVERSE)
|
2011-07-10 21:40:52 -04:00
|
|
|
|
2011-07-20 03:01:25 -04:00
|
|
|
#define ATTR_STATUS_WINDOW ATTR(COLOR_PAIR(BLACK_ON_WHITE), A_REVERSE)
|
|
|
|
|
|
|
|
#define ATTR_ERROR_WINDOW ATTR(COLOR_PAIR(WHITE_ON_RED), A_REVERSE)
|
|
|
|
#define ATTR_ERROR_TITLE ATTR(COLOR_PAIR(YELLOW_ON_BLACK) | A_BOLD, A_BOLD)
|
|
|
|
#define ATTR_ERROR_NORMAL ATTR_ERROR_WINDOW
|
|
|
|
#define ATTR_ERROR_HIGHLIGHT ATTR(COLOR_PAIR(WHITE_ON_RED) | A_BOLD, A_REVERSE)
|
|
|
|
#define ATTR_ERROR_WAITFORKEY ATTR(COLOR_PAIR(WHITE_ON_RED), A_REVERSE)
|
|
|
|
|
2011-07-10 21:40:52 -04:00
|
|
|
|
2011-07-03 22:41:30 -04:00
|
|
|
/************************************************************************
|
|
|
|
* Global variable declarations *
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
extern WINDOW *curwin; // Top-most (current) window
|
2011-07-10 21:40:52 -04:00
|
|
|
extern bool use_color; // True to use colour in Star Traders
|
2011-07-03 22:41:30 -04:00
|
|
|
|
|
|
|
|
2011-07-02 07:25:57 -04:00
|
|
|
/************************************************************************
|
2011-07-19 06:32:00 -04:00
|
|
|
* Basic text input/output function prototypes *
|
2011-07-02 07:25:57 -04:00
|
|
|
************************************************************************/
|
|
|
|
|
2011-07-20 08:41:56 -04:00
|
|
|
/*
|
|
|
|
The functions in this interface create and manage a "stack of windows"
|
|
|
|
that can overlap. It is similar in spirit to the panels library, but
|
|
|
|
does not allow windows to be raised or lowered. In spite of this
|
|
|
|
limitation, these functions are ample for the needs of this program.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: init_screen - Initialise the screen (terminal display)
|
|
|
|
Parameters: (none)
|
|
|
|
Returns: (nothing)
|
|
|
|
|
|
|
|
This function initialises the input keyboard and output terminal
|
|
|
|
display using the Curses library. It also draws an overall title at
|
|
|
|
the top with the name of the game. This function must be called before
|
|
|
|
calling any other functions in this header file.
|
|
|
|
*/
|
2011-07-02 07:25:57 -04:00
|
|
|
extern void init_screen (void);
|
2011-07-20 08:41:56 -04:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: end_screen - Deinitialise the screen (terminal display)
|
|
|
|
Parameters: (none)
|
|
|
|
Returns: (nothing)
|
|
|
|
|
|
|
|
This function closes the input keyboard and output terminal display.
|
|
|
|
It makes sure the screen is cleared before doing so.
|
|
|
|
*/
|
2011-07-02 07:25:57 -04:00
|
|
|
extern void end_screen (void);
|
|
|
|
|
2011-07-04 05:41:55 -04:00
|
|
|
|
2011-07-20 08:41:56 -04:00
|
|
|
/*
|
|
|
|
Function: newtxwin - Create a new window, inserted into window stack
|
|
|
|
Parameters: nlines - Number of lines in new window
|
|
|
|
ncols - Number of columns in new window
|
|
|
|
begin_y - Starting line number (0 to LINES-1)
|
|
|
|
begin_x - Starting column number (0 to COLS-1)
|
|
|
|
dofill - True to draw background and box frame
|
|
|
|
bkgd_attr - Background attribute
|
|
|
|
Returns: WINDOW * - Pointer to new window
|
|
|
|
|
|
|
|
This function creates a window using the Curses newwin() function and
|
|
|
|
places it top-most in the stack of windows managed by this module. A
|
|
|
|
pointer to this new window is returned; the global variable curwin also
|
|
|
|
points to this new window. Note that begin_y and begin_x are zero-
|
|
|
|
based global coordinates. If dofill is true, bkgd_attr is used to fill
|
|
|
|
the background and box(curwin, 0, 0) is called. Note that wrefresh()
|
|
|
|
is NOT called on the new window.
|
|
|
|
|
|
|
|
If newtxwin() fails to create a new window due to insufficient memory,
|
|
|
|
this function does NOT return: it terminates the program with an "out
|
|
|
|
of memory" error message.
|
|
|
|
*/
|
2011-07-19 21:41:46 -04:00
|
|
|
extern WINDOW *newtxwin (int nlines, int ncols, int begin_y, int begin_x,
|
2011-07-20 08:41:56 -04:00
|
|
|
bool dofill, chtype bkgd_attr);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: deltxwin - Delete the top-most window in the window stack
|
|
|
|
Parameters: (none)
|
|
|
|
Returns: int - ERR on failure, OK otherwise
|
|
|
|
|
|
|
|
This function removes the top-most window from the Curses screen and
|
|
|
|
from the stack managed by this module. ERR is returned if there is no
|
|
|
|
such window or if the Curses delwin() function fails.
|
|
|
|
|
|
|
|
Note that the actual terminal screen is NOT refreshed: a call to
|
|
|
|
txrefresh() should follow this one. This allows multiple windows to be
|
|
|
|
deleted without any annoying screen flashes.
|
|
|
|
*/
|
2011-07-03 22:41:30 -04:00
|
|
|
extern int deltxwin (void);
|
2011-07-20 08:41:56 -04:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: delalltxwin - Delete all windows in the window stack
|
|
|
|
Parameters: (none)
|
|
|
|
Returns: int - OK is always returned
|
|
|
|
|
|
|
|
This function deletes all windows in the stack of windows managed by
|
|
|
|
this module. After calling this function, the global variable curwin
|
|
|
|
will point to stdscr. Note that the actual terminal screen is NOT
|
|
|
|
refreshed: a call to txrefresh() should follow this one if appropriate.
|
|
|
|
*/
|
2011-07-03 22:41:30 -04:00
|
|
|
extern int delalltxwin (void);
|
2011-07-20 08:41:56 -04:00
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: txrefresh - Redraw all windows in the window stack
|
|
|
|
Parameters: (none)
|
|
|
|
Returns: int - Return code from doupdate(): either OK or ERR
|
|
|
|
|
|
|
|
This function redraws (refreshes) all windows in the stack of windows
|
|
|
|
managed by this module. Windows are refreshed from bottom (first) to
|
|
|
|
top (last). The result of doupdate() is returned.
|
|
|
|
|
|
|
|
Normal window output does not require calling txrefresh(): a call to
|
|
|
|
wrefresh(curwin) is sufficient. However, once a window has been
|
|
|
|
deleted with deltxwin() (or all windows with delalltxwin()), windows
|
|
|
|
under that one will need refreshing by calling txrefresh().
|
|
|
|
*/
|
2011-07-03 22:41:30 -04:00
|
|
|
extern int txrefresh (void);
|
|
|
|
|
2011-07-20 08:41:56 -04:00
|
|
|
|
2011-07-20 22:29:13 -04:00
|
|
|
/*
|
|
|
|
Function: attrpr - Print a string with a particular character rendition
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
attr - Character rendition to use for the string
|
|
|
|
format - printf()-like format string
|
|
|
|
... - printf()-like arguments
|
|
|
|
Returns: int - Return code from wprintw(): OK or ERR
|
|
|
|
|
|
|
|
This function sets the character rendition (attributes) to attr, prints
|
|
|
|
the string using wprintw(), then restores the previous character
|
|
|
|
rendition. The return code is as returned from wprintw(). Note that
|
|
|
|
wrefresh() is NOT called.
|
|
|
|
*/
|
|
|
|
extern int attrpr (WINDOW *win, chtype attr, const char *restrict format, ...)
|
|
|
|
__attribute__((format (printf, 3, 4)));
|
|
|
|
|
2011-07-04 05:41:55 -04:00
|
|
|
|
2011-07-20 22:29:13 -04:00
|
|
|
/*
|
|
|
|
Function: center - Centre a string in a given window
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
y - Line on which to centre the string
|
|
|
|
attr - Character rendition to use for the string
|
|
|
|
format - printf()-like format string
|
|
|
|
... - printf()-like arguments
|
|
|
|
Returns: int - Return code from wprintw(): OK or ERR
|
|
|
|
|
|
|
|
This function prints a string formatted with wprintw() in the centre of
|
|
|
|
line y in the window win, using the character rendition (attributes) in
|
|
|
|
attr. If the string is too long to fit the window, it is truncated.
|
|
|
|
Please note that wrefresh() is NOT called.
|
|
|
|
|
|
|
|
At the current time, the implementation of this function does NOT
|
|
|
|
handle multibyte strings correctly: strlen() is used to determine the
|
|
|
|
printing width of the string.
|
|
|
|
*/
|
|
|
|
extern int center (WINDOW *win, int y, chtype attr,
|
|
|
|
const char *restrict format, ...)
|
2011-07-11 01:56:01 -04:00
|
|
|
__attribute__((format (printf, 4, 5)));
|
2011-07-02 07:25:57 -04:00
|
|
|
|
2011-07-20 22:29:13 -04:00
|
|
|
|
|
|
|
/*
|
|
|
|
Function: center2 - Centre two strings in a given window
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
y - Line on which to centre the strings
|
|
|
|
attr1 - Character rendition to use for initial string
|
|
|
|
attr2 - Character rendition to use for main string
|
|
|
|
initial - Initial string (no printf() formatting)
|
|
|
|
format - printf()-like format string for main string
|
|
|
|
... - printf()-like arguments
|
|
|
|
Returns: int - Return code from wprintw(): OK or ERR
|
|
|
|
|
|
|
|
This function prints two strings side-by-side on line y in the centre
|
|
|
|
of window win. The first (initial) string is printed with character
|
|
|
|
rendition (attributes) attr1 using waddstr(). The second (main) string
|
|
|
|
uses wprintw(format, ...) with rendition attr2. If the main string is
|
|
|
|
too long to fit in the window alongside the initial string, the main
|
|
|
|
string is truncated to fit. Please note that wrefresh() is NOT called.
|
|
|
|
|
|
|
|
As with center(), the current implementation does NOT handle multibyte
|
|
|
|
strings correctly.
|
|
|
|
*/
|
|
|
|
extern int center2 (WINDOW *win, int y, chtype attr1, chtype attr2,
|
|
|
|
const char *initial, const char *restrict format, ...)
|
2011-07-15 00:55:56 -04:00
|
|
|
__attribute__((format (printf, 6, 7)));
|
|
|
|
|
2011-07-20 22:29:13 -04:00
|
|
|
|
|
|
|
/*
|
|
|
|
Function: center3 - Centre three strings in a given window
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
y - Line on which to centre the strings
|
|
|
|
attr1 - Character rendition to use for initial string
|
|
|
|
attr3 - Character rendition to use for final string
|
|
|
|
attr2 - Character rendition to use for main string
|
|
|
|
initial - Initial string (no printf() formatting)
|
|
|
|
final - Final string (no printf() formatting)
|
|
|
|
format - printf()-like format string for main string
|
|
|
|
... - printf()-like arguments
|
|
|
|
Returns: int - Return code from wprintw(): OK or ERR
|
|
|
|
|
|
|
|
This function prints three strings side-by-side on line y in the centre
|
|
|
|
of window win. The first (initial) string is printed with character
|
|
|
|
rendition (attributes) attr1 using waddstr(). The second (main) string
|
|
|
|
uses wprintw(format, ...) with rendition attr2. The third (final)
|
|
|
|
string is then printed with rendition attr3 using waddstr(). If the
|
|
|
|
strings are too long to fit the window width, the main (centre) string
|
|
|
|
is truncated. Please note that wrefresh() is NOT called. Also note
|
|
|
|
the order of rendition values: 1, 3, 2, NOT 1, 2, 3!
|
|
|
|
|
|
|
|
As with center(), the current implementation does NOT handle multibyte
|
|
|
|
strings correctly.
|
|
|
|
*/
|
|
|
|
|
|
|
|
extern int center3 (WINDOW *win, int y, chtype attr1, chtype attr3,
|
|
|
|
chtype attr2, const char *initial, const char *final,
|
|
|
|
const char *restrict format, ...)
|
2011-07-16 01:47:05 -04:00
|
|
|
__attribute__((format (printf, 8, 9)));
|
|
|
|
|
2011-07-04 05:41:55 -04:00
|
|
|
|
2011-07-20 23:10:51 -04:00
|
|
|
/*
|
|
|
|
Function: gettxchar - Read a character from the keyboard
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
Returns: int - The keyboard character
|
|
|
|
|
|
|
|
This function reads a single character from the keyboard. The key is
|
|
|
|
NOT echoed to the terminal display, nor is the cursor visibility
|
|
|
|
affected.
|
2011-07-04 08:02:01 -04:00
|
|
|
|
2011-07-20 23:10:51 -04:00
|
|
|
This implementation does not handle multibyte characters correctly:
|
|
|
|
each part of the multibyte character most likely appears as a separate
|
|
|
|
keyboard press.
|
|
|
|
*/
|
2011-07-04 08:02:01 -04:00
|
|
|
extern int gettxchar (WINDOW *win);
|
2011-07-20 23:10:51 -04:00
|
|
|
|
|
|
|
|
2011-07-21 07:40:54 -04:00
|
|
|
/*
|
|
|
|
Function: gettxline - Read a line from the keyboard (low-level)
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
buf - Pointer to preallocated buffer
|
|
|
|
bufsize - Size of buffer in bytes
|
|
|
|
modified - Pointer to modified status (result)
|
|
|
|
multifield - Allow <TAB>, etc, to exit this function
|
|
|
|
emptyval - String used if input line is empty
|
|
|
|
defaultval - String used if default key is pressed
|
|
|
|
allowed - Characters allowed in the input line
|
|
|
|
stripspc - True to strip leading/trailing spaces
|
|
|
|
y, x - Start of the input field (line, column)
|
|
|
|
width - Width of the input field
|
|
|
|
attr - Character rendition to use for input field
|
|
|
|
Returns: int - Status code: OK, ERR or KEY_ keycode
|
|
|
|
|
|
|
|
This low-level function draws an input field width characters long
|
|
|
|
using attr as the character rendition, then reads a line of input from
|
|
|
|
the keyboard and places it into the preallocated buffer buf[] of size
|
|
|
|
bufsize. On entry, buf[] must contain a valid C string; this string is
|
|
|
|
used as the initial contents of the input field. On exit, buf[]
|
|
|
|
contains the final string as edited or input by the user. This string
|
|
|
|
is printed in place of the input field using the original character
|
|
|
|
rendition (attributes) with A_BOLD added. Many Emacs/Bash-style
|
|
|
|
keyboard editing shortcuts are understood.
|
|
|
|
|
|
|
|
If ENTER, RETURN, ^M or ^J is pressed, OK is returned. In this case,
|
|
|
|
leading and trailing spaces are stripped if stripspc is true; if an
|
|
|
|
empty string is entered, the string pointed to by emptyval (if not
|
|
|
|
NULL) is stored in buf[].
|
|
|
|
|
|
|
|
If CANCEL, EXIT, ESC, ^C, ^\ or ^G is pressed, ERR is returned. In
|
|
|
|
this case, buf[] contains the string as left by the user: emptyval is
|
|
|
|
NOT used, nor are leading and trailing spaces stripped.
|
|
|
|
|
|
|
|
If multifield is true, the UP and DOWN arrow keys, as well as TAB,
|
|
|
|
Shift-TAB, ^P (Previous) and ^N (Next) return KEY_UP or KEY_DOWN as
|
|
|
|
appropriate. As with CANCEL etc., emptyval is NOT used, nor are
|
|
|
|
leading and trailing spaces stripped.
|
|
|
|
|
|
|
|
In all of these cases, the boolean variable *modified (if modified is
|
|
|
|
not NULL) is set to true if the input line was actually modified in any
|
|
|
|
way (including if the user made any changed, spaces were stripped or if
|
|
|
|
emptyval was copied into buf[]).
|
|
|
|
|
|
|
|
If KEY_DEFAULTVAL1 or KEY_DEFAULTVAL2 is pressed when the input line is
|
|
|
|
empty, the string pointed to by defaultval (if not NULL) is placed in
|
|
|
|
the buffer as if typed by the user. Editing is NOT terminated in this
|
|
|
|
case.
|
|
|
|
|
|
|
|
If allowed is not NULL, only characters in that string are allowed to
|
|
|
|
be entered into the input line. For example, if allowed points to
|
|
|
|
"0123456789abcdefABCDEF", only those characters would be allowed (in
|
|
|
|
this instance, allowing the user to type in a hexadecimal number).
|
|
|
|
|
|
|
|
Note that the character rendition (attributes) in attr may contain a
|
|
|
|
printing character. For example, A_BOLD | '_' is a valid rendition
|
|
|
|
that causes the input field to be a series of "_" characters in bold.
|
|
|
|
|
|
|
|
This implementation does not handle multibyte characters correctly:
|
|
|
|
each part of the multibyte character most likely appears as a separate
|
|
|
|
keyboard press and is handled as a separate character, causing the
|
|
|
|
cursor position to be incorrect. In addition, allowed is compared on a
|
|
|
|
byte-by-byte basis, not character-by-character.
|
|
|
|
*/
|
|
|
|
extern int gettxline (WINDOW *win, char *buf, int bufsize,
|
|
|
|
bool *restrict modified, bool multifield,
|
|
|
|
const char *emptyval, const char *defaultval,
|
2011-07-10 20:31:19 -04:00
|
|
|
const char *allowed, bool stripspc, int y, int x,
|
2011-07-21 07:40:54 -04:00
|
|
|
int width, chtype attr);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: gettxstr - Read a string from the keyboard
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
bufptr - Address of pointer to buffer
|
|
|
|
modified - Pointer to modified status (result)
|
|
|
|
multifield - Allow <TAB>, etc, to exit this function
|
|
|
|
y, x - Start of the input field (line, column)
|
|
|
|
width - Width of the input field
|
|
|
|
attr - Character rendition to use for input field
|
|
|
|
Returns: int - Status code: OK, ERR or KEY_ keycode
|
|
|
|
|
|
|
|
This function calls gettxline() to allow the user to enter a string via
|
|
|
|
the keyboard. On entry, bufptr must be the address of a char * pointer
|
|
|
|
variable; that pointer (*bufptr) must either be NULL or contain the
|
|
|
|
address of a buffer previously allocated with gettxstr(). If *bufptr
|
|
|
|
is NULL, a buffer of BUFSIZE is automatically allocated using malloc();
|
|
|
|
this buffer is used to store and return the input line.
|
|
|
|
|
|
|
|
Apart from bufptr, all parameters are as used for gettxline(). The
|
|
|
|
gettxline() parameters emptyval and defaultval are passed as "",
|
|
|
|
allowed is NULL and stripspc is true.
|
|
|
|
*/
|
|
|
|
extern int gettxstr (WINDOW *win, char **bufptr, bool *restrict modified,
|
|
|
|
bool multifield, int y, int x, int width, chtype attr);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: gettxdouble - Read a floating-point number from the keyboard
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
result - Pointer to result variable
|
|
|
|
min - Minimum value allowed (may be -INFINITY)
|
|
|
|
max - Maximum value allowed (may be INFINITY)
|
|
|
|
emptyval - Value to use for empty input
|
|
|
|
defaultval - Value to use for default input
|
|
|
|
y, x - Start of the input field (line, column)
|
|
|
|
width - Width of the input field
|
|
|
|
attr - Character rendition to use for input field
|
|
|
|
Returns: int - Status code: OK, ERR or KEY_ keycode
|
|
|
|
|
|
|
|
This function calls gettxline() to allow the user to type in a valid
|
|
|
|
floating-point number between min and max (inclusive). If gettxline()
|
|
|
|
returns OK, the entered number is checked for validity. If it is
|
|
|
|
valid, it is stored in *result and the function returns OK. If it is
|
|
|
|
not valid, the user is prompted to reenter the number. Any other
|
|
|
|
result from gettxline() is passed back to the caller. Note that the
|
|
|
|
low-level function gettxline() is called with multifield set to false.
|
|
|
|
|
|
|
|
This function is locale-aware, although multibyte strings are not
|
|
|
|
handled correctly. In particular, the default value is formatted using
|
|
|
|
strfmon() and uses the locale monetary default decimal places
|
|
|
|
(frac_digits). In addition, the user is allowed to use the locale's
|
|
|
|
radix character (decimal point) and the thousands separator, as well as
|
|
|
|
the monetary versions of these.
|
|
|
|
*/
|
|
|
|
extern int gettxdouble (WINDOW *win, double *restrict result, double min,
|
|
|
|
double max, double emptyval, double defaultval,
|
|
|
|
int y, int x, int width, chtype attr);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: gettxlong - Read an integer number from the keyboard
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
result - Pointer to result variable
|
|
|
|
min - Minimum value allowed
|
|
|
|
max - Maximum value allowed
|
|
|
|
emptyval - Value to use for empty input
|
|
|
|
defaultval - Value to use for default input
|
|
|
|
y, x - Start of the input field (line, column)
|
|
|
|
width - Width of the input field
|
|
|
|
attr - Character rendition to use for input field
|
|
|
|
Returns: int - Status code: OK, ERR or KEY_ keycode
|
|
|
|
|
|
|
|
This function behaves almost exactly like gettxdouble(), except that
|
|
|
|
only integer numbers are allowed to be entered.
|
|
|
|
|
|
|
|
This function is locale-aware, although multibyte strings are not
|
|
|
|
handled correctly. In particular, the user is allowed to use the
|
|
|
|
locale's thousands separator and the monetary thousands separator.
|
|
|
|
*/
|
|
|
|
extern int gettxlong (WINDOW *win, long int *restrict result, long int min,
|
|
|
|
long int max, long int emptyval, long int defaultval,
|
|
|
|
int y, int x, int width, chtype attr);
|
2011-07-02 00:53:45 -04:00
|
|
|
|
2011-07-20 23:10:51 -04:00
|
|
|
|
|
|
|
/*
|
|
|
|
Function: answer_yesno - Wait for a Yes/No answer
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
attr_keys - Window rendition to use for key choices
|
|
|
|
Returns: bool - True if Yes was selected, false if No
|
|
|
|
|
|
|
|
This function prompts the user by printing " [Y/N] " using appropriate
|
|
|
|
character renditions ("Y" and "N" in attr_keys, the rest in the current
|
|
|
|
rendition), then waits for the user to press either "Y" (for Yes) or
|
|
|
|
"N" (for No) on the keyboard, then prints the answer using A_BOLD.
|
|
|
|
True is returned if "Y" was selected, false if "N". Note that the
|
|
|
|
cursor becomes invisible after calling this function.
|
|
|
|
*/
|
|
|
|
extern bool answer_yesno (WINDOW *win, chtype attr_keys);
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function: wait_for_key - Print a message and wait for any key
|
|
|
|
Parameters: win - Window to use (should be curwin)
|
|
|
|
y - Line on which to print message
|
|
|
|
attr - Character rendition to use for message
|
|
|
|
Returns: (nothing)
|
|
|
|
|
|
|
|
This function displays the message "Press <SPACE> to continue" in the
|
|
|
|
centre of line y in window win, then waits for any key to be pressed.
|
|
|
|
|
|
|
|
The reason the user is not asked "Press any key to continue" is
|
|
|
|
historical: many, many people used to ask "where is the <ANY> key?" :-)
|
|
|
|
|
|
|
|
The current implementation does not handle multibyte characters
|
|
|
|
correctly: only the first byte of the character is consumed, with
|
|
|
|
further bytes left in the keyboard queue.
|
|
|
|
*/
|
|
|
|
extern void wait_for_key (WINDOW *win, int y, chtype attr);
|
2011-07-11 00:43:16 -04:00
|
|
|
|
|
|
|
|
2011-07-02 00:53:45 -04:00
|
|
|
#endif /* included_INTF_H */
|