curs_sp_funcs(3x) curs_sp_funcs(3x)
curs_sp_funcs - curses screen-pointer extension
#include <curses.h> int alloc_pair_sp(SCREEN* sp, int fg, int bg); int assume_default_colors_sp(SCREEN* sp, int fg, int bg); int baudrate_sp(SCREEN* sp); int beep_sp(SCREEN* sp); bool can_change_color_sp(SCREEN* sp); int cbreak_sp(SCREEN* sp); int color_content_sp(SCREEN* sp, short color, short* r, short* g, short* b); int curs_set_sp(SCREEN* sp, int visibility); int def_prog_mode_sp(SCREEN* sp); int def_shell_mode_sp(SCREEN* sp); int define_key_sp(SCREEN* sp, const char * definition, int keycode); int delay_output_sp(SCREEN* sp, int ms); int doupdate_sp(SCREEN* sp); int echo_sp(SCREEN* sp); int endwin_sp(SCREEN* sp); char erasechar_sp(SCREEN* sp); int erasewchar_sp(SCREEN* sp, wchar_t *ch); int extended_color_content_sp(SCREEN * sp, int color, int * r, int * g, int * b); int extended_pair_content_sp(SCREEN* sp, int pair, int * fg, int * bg); int extended_slk_color_sp(SCREEN* sp, int pair); void filter_sp(SCREEN* sp); int find_pair_sp(SCREEN* sp, int fg, int bg); int flash_sp(SCREEN* sp); int flushinp_sp(SCREEN* sp); int free_pair_sp(SCREEN* sp, int pair); int get_escdelay_sp(SCREEN* sp); int getmouse_sp(SCREEN* sp, MEVENT* event); WINDOW* getwin_sp(SCREEN* sp, FILE* filep); int halfdelay_sp(SCREEN* sp, int tenths); bool has_colors_sp(SCREEN* sp); bool has_ic_sp(SCREEN* sp); bool has_il_sp(SCREEN* sp); int has_key_sp(SCREEN* sp, int ch); bool has_mouse_sp(SCREEN* sp); int init_color_sp(SCREEN* sp, short color, short r, short g, short b); int init_extended_color_sp(SCREEN* sp, int color, int r, int g, int b); int init_extended_pair_sp(SCREEN* sp, int pair, int fg, int bg); int init_pair_sp(SCREEN* sp, short pair, short fg, short bg); int intrflush_sp(SCREEN* sp, WINDOW* win, bool bf); bool is_term_resized_sp(SCREEN* sp, int lines, int columns); bool isendwin_sp(SCREEN* sp); int key_defined_sp(SCREEN* sp, const char *definition); char* keybound_sp(SCREEN* sp, int keycode, int count); NCURSES_CONST char * keyname_sp(SCREEN* sp, int c); int keyok_sp(SCREEN* sp, int keycode, bool enable); char killchar_sp(SCREEN* sp); int killwchar_sp(SCREEN* sp, wchar_t *ch); char* longname_sp(SCREEN* sp); int mcprint_sp(SCREEN* sp, char *data, int len); int mouseinterval_sp(SCREEN* sp, int erval); mmask_t mousemask_sp(SCREEN* sp, mmask_t newmask, mmask_t *oldmask); int mvcur_sp(SCREEN* sp, int oldrow, int oldcol, int newrow, int newcol); int napms_sp(SCREEN* sp, int ms); WINDOW* newpad_sp(SCREEN* sp, int nrows, int ncols); SCREEN* new_prescr(void); SCREEN* newterm_sp(SCREEN* sp, const char *type, FILE *outfd, FILE *infd); WINDOW* newwin_sp(SCREEN* sp, int nlines, int ncols, int begin_y, int begin_x); int nl_sp(SCREEN* sp); int nocbreak_sp(SCREEN* sp); int noecho_sp(SCREEN* sp); void nofilter_sp(SCREEN* sp); int nonl_sp(SCREEN* sp); void noqiflush_sp(SCREEN* sp); int noraw_sp(SCREEN* sp); int pair_content_sp(SCREEN* sp, short pair, short* fg, short* bg); void qiflush_sp(SCREEN* sp); int raw_sp(SCREEN* sp); int reset_prog_mode_sp(SCREEN* sp); void reset_color_pairs_sp(SCREEN* sp); int reset_shell_mode_sp(SCREEN* sp); int resetty_sp(SCREEN* sp); int resize_term_sp(SCREEN* sp, int lines, int columns); int resizeterm_sp(SCREEN* sp, int lines, int columns); int ripoffline_sp(SCREEN* sp, int line, int (*init)(WINDOW* win, int fmt)); int savetty_sp(SCREEN* sp); int scr_init_sp(SCREEN* sp, const char *filename); int scr_restore_sp(SCREEN* sp, const char *filename); int scr_set_sp(SCREEN* sp, const char *filename); int set_escdelay_sp(SCREEN* sp, int ms); int set_tabsize_sp(SCREEN* sp, int cols); int slk_attr_set_sp(SCREEN* sp, const attr_t attrs, short pair, void*opts); int slk_attrset_sp(SCREEN* sp, const chtype a); int slk_attroff_sp(SCREEN* sp, const chtype a); int slk_attron_sp(SCREEN* sp, const chtype a); attr_t slk_attr_sp(SCREEN* sp); int slk_clear_sp(SCREEN* sp); int slk_color_sp(SCREEN* sp, short pair); int slk_init_sp(SCREEN* sp, int fmt); char* slk_label_sp(SCREEN* sp, int labnum); int slk_noutrefresh_sp(SCREEN* sp); int slk_refresh_sp(SCREEN* sp); int slk_restore_sp(SCREEN* sp); int slk_set_sp(SCREEN* sp, int labnum, const char * label, int fmt); int slk_touch_sp(SCREEN* sp); int start_color_sp(SCREEN* sp); attr_t term_attrs_sp(SCREEN* sp); chtype termattrs_sp(SCREEN* sp); char* termname_sp(SCREEN* sp); int typeahead_sp(SCREEN* sp, int fd); int unget_wch_sp(SCREEN* sp, const wchar_t wch); int ungetch_sp(SCREEN* sp, int ch); int ungetmouse_sp(SCREEN* sp,MEVENT * event); int use_default_colors_sp(SCREEN* sp); void use_env_sp(SCREEN* sp, bool bf); int use_legacy_coding_sp(SCREEN* sp, int level); void use_tioctl_sp(SCREEN *sp, bool bf); int vid_attr_sp(SCREEN* sp, attr_t attrs, short pair, void * opts); int vid_puts_sp(SCREEN* sp, attr_t attrs, short pair, void * opts, NCURSES_SP_OUTC putc); int vidattr_sp(SCREEN* sp, chtype attrs); int vidputs_sp(SCREEN* sp, chtype attrs, NCURSES_SP_OUTC putc); wchar_t* wunctrl_sp(SCREEN* sp, cchar_t *ch); #include <form.h> FORM* new_form_sp(SCREEN* sp, FIELD **fields); #include <menu.h> MENU* new_menu_sp(SCREEN* sp, ITEM **items); #include <panel.h> PANEL* ceiling_panel(SCREEN* sp); PANEL* ground_panel(SCREEN* sp); void update_panels_sp(SCREEN* sp); #include <term.h> int del_curterm_sp(SCREEN* sp, TERMINAL *oterm); int putp_sp(SCREEN* sp, const char *str); int restartterm_sp(SCREEN* sp, NCURSES_CONST char*term, int filedes, int *errret); TERMINAL* set_curterm_sp(SCREEN* sp, TERMINAL*nterm); int tgetent_sp(SCREEN* sp, char *bp, const char *name); int tgetflag_sp(SCREEN* sp, const char *capname); int tgetnum_sp(SCREEN* sp, const char *capname); char* tgetstr_sp(SCREEN* sp, const char *capname, char **area); char* tgoto_sp(SCREEN* sp, const char *capname, int col, int row); int tigetflag_sp(SCREEN* sp, const char *capname); int tigetnum_sp(SCREEN* sp, const char *capname); char* tigetstr_sp(SCREEN* sp, const char *capname); /* may instead use 9 long parameters */ char* tparm_sp(SCREEN* sp, const char *str, ...); int tputs_sp(SCREEN* sp, const char *str, int affcnt, NCURSES_SP_OUTC putc); #include <unctrl.h> NCURSES_CONST char* unctrl_sp(SCREEN* sp, chtype c);
This implementation can be configured to provide a set of functions which improve the ability to manage multiple screens. This feature can be added to any of the configurations supported by ncurses; it adds new entrypoints without changing the meaning of any of the existing ones.
Most of the functions are new versions of existing functions. A param- eter is added at the front of the parameter list. It is a SCREEN pointer. The existing functions all use the current screen, which is a static variable. The extended functions use the specified screen, thereby re- ducing the number of variables which must be modified to update multi- ple screens.
Here are the new functions: ceiling_panel this returns a pointer to the topmost panel in the given screen. ground_panel this returns a pointer to the lowest panel in the given screen. new_prescr when creating a new screen, the library uses static variables which have been preset, e.g., by use_env(3x), filter(3x), etc. With the screen-pointer extension, there are situations where it must create a current screen before the unextended library does. The new_prescr function is used internally to handle these cases. It is also provided as an entrypoint to allow applications to cus- tomize the library initialization.
This extension introduces some new names: NCURSES_SP_FUNCS This is set to the library patch-level number. In the unextended library, this is zero (0), to make it useful for checking if the extension is provided. NCURSES_SP_NAME The new functions are named using the macro NCURSES_SP_NAME, which hides the actual implementation. Currently this adds a "_sp" suf- fix to the name of the unextended function. This manual page in- dexes the extensions showing the full name. However the proper usage of these functions uses the macro, to provide for the possi- bility of changing the naming convention for specific library con- figurations. NCURSES_SP_OUTC This is a new function-pointer type to use in the screen-pointer functions where an NCURSES_OUTC is used in the unextended library. NCURSES_OUTC This is a function-pointer type used for the cases where a func- tion passes characters to the output stream, e.g., vidputs(3x).
These routines are specific to ncurses. They were not supported on Version 7, BSD or System V implementations. It is recommended that any code depending on ncurses extensions be conditioned using NCURS- ES_SP_FUNCS.
curses(3x), curs_opaque(3x), curs_threads(3x). curs_sp_funcs(3x)