golden hour
/usr/include
⬆️ Go Up
Upload
File/Folder
Size
Actions
FlexLexer.h
6.07 KB
Del
OK
GL
-
Del
OK
KF5
-
Del
OK
X11
-
Del
OK
_G_config.h
1.26 KB
Del
OK
a.out.h
4.25 KB
Del
OK
aio.h
7.27 KB
Del
OK
aliases.h
2 KB
Del
OK
alloca.h
1.19 KB
Del
OK
apache2
-
Del
OK
ar.h
1.68 KB
Del
OK
argp.h
24.75 KB
Del
OK
argz.h
6.96 KB
Del
OK
arpa
-
Del
OK
asm
-
Del
OK
asm-generic
-
Del
OK
assert.h
3.52 KB
Del
OK
autosprintf.h
2.33 KB
Del
OK
bind9
-
Del
OK
bits
-
Del
OK
bsock
-
Del
OK
byteswap.h
1.41 KB
Del
OK
c++
-
Del
OK
com_err.h
2.07 KB
Del
OK
complex.h
3.62 KB
Del
OK
cpio.h
2.21 KB
Del
OK
cpufreq.h
5.8 KB
Del
OK
criu
-
Del
OK
crypt.h
2.22 KB
Del
OK
ctype.h
11.52 KB
Del
OK
curses.h
93.19 KB
Del
OK
cursesapp.h
6.62 KB
Del
OK
cursesf.h
27.05 KB
Del
OK
cursesm.h
19.09 KB
Del
OK
cursesp.h
8.3 KB
Del
OK
cursesw.h
48.24 KB
Del
OK
cursslk.h
7.13 KB
Del
OK
db.h
120.21 KB
Del
OK
db4.7.25
-
Del
OK
db_185.h
5.84 KB
Del
OK
dbm.h
1.37 KB
Del
OK
dirent.h
12.34 KB
Del
OK
dlfcn.h
6.88 KB
Del
OK
drm
-
Del
OK
e2p
-
Del
OK
elf.h
141.01 KB
Del
OK
endian.h
2.95 KB
Del
OK
entities.h
4.56 KB
Del
OK
envz.h
2.82 KB
Del
OK
err.h
2.18 KB
Del
OK
errno.h
2.33 KB
Del
OK
error.h
2.01 KB
Del
OK
et
-
Del
OK
eti.h
2.82 KB
Del
OK
etip.h
9.04 KB
Del
OK
execinfo.h
1.5 KB
Del
OK
expat.h
41.04 KB
Del
OK
expat_external.h
3.29 KB
Del
OK
ext2fs
-
Del
OK
fcntl.h
9.89 KB
Del
OK
features.h
12.87 KB
Del
OK
fenv.h
4.5 KB
Del
OK
fmtmsg.h
3.18 KB
Del
OK
fnmatch.h
2.27 KB
Del
OK
fontconfig
-
Del
OK
form.h
17.56 KB
Del
OK
fpu_control.h
3.5 KB
Del
OK
freetype2
-
Del
OK
fstab.h
3.04 KB
Del
OK
fts.h
5.17 KB
Del
OK
ftw.h
5.15 KB
Del
OK
gconv.h
5.16 KB
Del
OK
gcrypt-module.h
7.18 KB
Del
OK
gcrypt.h
76.51 KB
Del
OK
gd.h
32.02 KB
Del
OK
gd_io.h
1.13 KB
Del
OK
gdbm
-
Del
OK
gdbm.h
5.75 KB
Del
OK
gdcache.h
2.75 KB
Del
OK
gdfontg.h
623 B
Del
OK
gdfontl.h
621 B
Del
OK
gdfontmb.h
590 B
Del
OK
gdfonts.h
585 B
Del
OK
gdfontt.h
617 B
Del
OK
gdfx.h
2.34 KB
Del
OK
gelf.h
11.05 KB
Del
OK
getopt.h
6.53 KB
Del
OK
gettext-po.h
15.17 KB
Del
OK
glob.h
6.51 KB
Del
OK
gnu
-
Del
OK
gnu-versions.h
2.29 KB
Del
OK
google
-
Del
OK
gpg-error.h
23.66 KB
Del
OK
grp.h
6.75 KB
Del
OK
gshadow.h
4.43 KB
Del
OK
gssapi
-
Del
OK
gssapi.h
181 B
Del
OK
gssrpc
-
Del
OK
iconv.h
1.83 KB
Del
OK
idn-free.h
2.41 KB
Del
OK
idn-int.h
20 B
Del
OK
idna.h
3.48 KB
Del
OK
ieee754.h
4.81 KB
Del
OK
ifaddrs.h
2.77 KB
Del
OK
inttypes.h
11.61 KB
Del
OK
jconfig.h
1.7 KB
Del
OK
jerror.h
14.4 KB
Del
OK
jmorecfg.h
13.5 KB
Del
OK
jpeglib.h
49.12 KB
Del
OK
kadm5
-
Del
OK
kdb.h
60.12 KB
Del
OK
kde4
-
Del
OK
keyutils.h
7.08 KB
Del
OK
krad.h
8.72 KB
Del
OK
krb5
-
Del
OK
krb5.h
402 B
Del
OK
langinfo.h
15.57 KB
Del
OK
lastlog.h
126 B
Del
OK
lauxlib.h
5.64 KB
Del
OK
lber.h
14.95 KB
Del
OK
lber_types.h
1.43 KB
Del
OK
ldap.h
63.46 KB
Del
OK
ldap_cdefs.h
9.24 KB
Del
OK
ldap_features.h
1.77 KB
Del
OK
ldap_schema.h
9.23 KB
Del
OK
ldap_utf8.h
3.39 KB
Del
OK
ldif.h
4.58 KB
Del
OK
libaio.h
7.8 KB
Del
OK
libdb
-
Del
OK
libelf.h
19.11 KB
Del
OK
libexslt
-
Del
OK
libgen.h
1.37 KB
Del
OK
libintl.h
4.49 KB
Del
OK
libio.h
16.87 KB
Del
OK
libltdl
-
Del
OK
libpng15
-
Del
OK
libxml2
-
Del
OK
libxslt
-
Del
OK
limits.h
4.42 KB
Del
OK
link.h
6.99 KB
Del
OK
linux
-
Del
OK
locale.h
7.78 KB
Del
OK
ltdl.h
5.58 KB
Del
OK
lua.h
11.41 KB
Del
OK
lua.hpp
191 B
Del
OK
luaconf.h
21.64 KB
Del
OK
lualib.h
1 KB
Del
OK
lzma
-
Del
OK
lzma.h
9.51 KB
Del
OK
malloc.h
6.44 KB
Del
OK
math.h
15.7 KB
Del
OK
mcheck.h
2.4 KB
Del
OK
memory.h
962 B
Del
OK
menu.h
11.67 KB
Del
OK
misc
-
Del
OK
mntent.h
3.3 KB
Del
OK
monetary.h
1.73 KB
Del
OK
mqueue.h
3.7 KB
Del
OK
mtd
-
Del
OK
mysql
-
Del
OK
nc_tparm.h
4.05 KB
Del
OK
ncurses
-
Del
OK
ncurses.h
93.19 KB
Del
OK
ncurses_dll.h
3.83 KB
Del
OK
ncursesw
-
Del
OK
ndbm.h
2.39 KB
Del
OK
net
-
Del
OK
netash
-
Del
OK
netatalk
-
Del
OK
netax25
-
Del
OK
netdb.h
27.46 KB
Del
OK
neteconet
-
Del
OK
netinet
-
Del
OK
netipx
-
Del
OK
netiucv
-
Del
OK
netpacket
-
Del
OK
netrom
-
Del
OK
netrose
-
Del
OK
nfs
-
Del
OK
nl_types.h
1.73 KB
Del
OK
nlist.h
1.56 KB
Del
OK
nss.h
1.85 KB
Del
OK
obstack.h
18.84 KB
Del
OK
openssl
-
Del
OK
panel.h
3.97 KB
Del
OK
paths.h
2.91 KB
Del
OK
pcre.h
29.73 KB
Del
OK
pcre_scanner.h
6.45 KB
Del
OK
pcre_stringpiece.h
6.11 KB
Del
OK
pcrecpp.h
25.91 KB
Del
OK
pcrecpparg.h
6.62 KB
Del
OK
pcreposix.h
5.32 KB
Del
OK
png.h
113.36 KB
Del
OK
pngconf.h
20.94 KB
Del
OK
pnglibconf.h
6.3 KB
Del
OK
poll.h
22 B
Del
OK
pr29.h
2.07 KB
Del
OK
printf.h
6.56 KB
Del
OK
profile.h
11.87 KB
Del
OK
protobuf-c
-
Del
OK
protocols
-
Del
OK
pthread.h
39.95 KB
Del
OK
pty.h
1.51 KB
Del
OK
punycode.h
9.36 KB
Del
OK
pwd.h
5.87 KB
Del
OK
python2.7
-
Del
OK
python3.6m
-
Del
OK
quota
-
Del
OK
rdma
-
Del
OK
re_comp.h
957 B
Del
OK
regex.h
21.58 KB
Del
OK
regexp.h
6.89 KB
Del
OK
resolv.h
14.67 KB
Del
OK
rpc
-
Del
OK
rpcsvc
-
Del
OK
sasl
-
Del
OK
sched.h
4.55 KB
Del
OK
scsi
-
Del
OK
search.h
5.11 KB
Del
OK
security
-
Del
OK
selinux
-
Del
OK
semaphore.h
2.36 KB
Del
OK
sepol
-
Del
OK
setjmp.h
3.97 KB
Del
OK
sgtty.h
1.33 KB
Del
OK
shadow.h
5.1 KB
Del
OK
signal.h
13.3 KB
Del
OK
slapi-plugin.h
37.45 KB
Del
OK
sound
-
Del
OK
spawn.h
6.53 KB
Del
OK
stab.h
264 B
Del
OK
stdc-predef.h
1.59 KB
Del
OK
stdint.h
7.94 KB
Del
OK
stdio.h
30.9 KB
Del
OK
stdio_ext.h
2.74 KB
Del
OK
stdlib.h
33.23 KB
Del
OK
string.h
21.75 KB
Del
OK
stringprep.h
8 KB
Del
OK
strings.h
4.55 KB
Del
OK
sys
-
Del
OK
syscall.h
25 B
Del
OK
sysexits.h
5.11 KB
Del
OK
syslog.h
24 B
Del
OK
tar.h
3.67 KB
Del
OK
tcpd.h
11.48 KB
Del
OK
term.h
38.63 KB
Del
OK
term_entry.h
7.91 KB
Del
OK
termcap.h
3.4 KB
Del
OK
termio.h
214 B
Del
OK
termios.h
3.52 KB
Del
OK
tgmath.h
18.11 KB
Del
OK
thread_db.h
15.65 KB
Del
OK
tic.h
12.35 KB
Del
OK
tiff.h
34.95 KB
Del
OK
tiffconf-64.h
3.35 KB
Del
OK
tiffconf.h
250 B
Del
OK
tiffio.h
22.52 KB
Del
OK
tiffio.hxx
1.66 KB
Del
OK
tiffvers.h
410 B
Del
OK
time.h
13.4 KB
Del
OK
tld.h
4.54 KB
Del
OK
ttyent.h
2.44 KB
Del
OK
uapi
-
Del
OK
uchar.h
2.42 KB
Del
OK
ucontext.h
1.92 KB
Del
OK
ulimit.h
1.55 KB
Del
OK
unctrl.h
3.03 KB
Del
OK
unistd.h
41.78 KB
Del
OK
ustat.h
23 B
Del
OK
utime.h
1.5 KB
Del
OK
utmp.h
3.16 KB
Del
OK
utmpx.h
4.02 KB
Del
OK
uuid
-
Del
OK
values.h
1.92 KB
Del
OK
verto-module.h
6.48 KB
Del
OK
verto.h
18.57 KB
Del
OK
video
-
Del
OK
wait.h
22 B
Del
OK
wchar.h
31.37 KB
Del
OK
wctype.h
10.89 KB
Del
OK
wordexp.h
2.47 KB
Del
OK
xcb
-
Del
OK
xen
-
Del
OK
xlocale.h
1.66 KB
Del
OK
zconf.h
14.92 KB
Del
OK
zlib.h
84.68 KB
Del
OK
Edit: cursesm.h
// * This makes emacs happy -*-Mode: C++;-*- /**************************************************************************** * Copyright (c) 1998-2011,2012 Free Software Foundation, Inc. * * * * Permission is hereby granted, free of charge, to any person obtaining a * * copy of this software and associated documentation files (the * * "Software"), to deal in the Software without restriction, including * * without limitation the rights to use, copy, modify, merge, publish, * * distribute, distribute with modifications, sublicense, and/or sell * * copies of the Software, and to permit persons to whom the Software is * * furnished to do so, subject to the following conditions: * * * * The above copyright notice and this permission notice shall be included * * in all copies or substantial portions of the Software. * * * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, * * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR * * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR * * THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * * * Except as contained in this notice, the name(s) of the above copyright * * holders shall not be used in advertising or otherwise to promote the * * sale, use or other dealings in this Software without prior written * * authorization. * ****************************************************************************/ /**************************************************************************** * Author: Juergen Pfeifer, 1997 * ****************************************************************************/ // $Id: cursesm.h,v 1.29 2012/12/29 21:48:33 tom Exp $ #ifndef NCURSES_CURSESM_H_incl #define NCURSES_CURSESM_H_incl 1 #include <cursesp.h> extern "C" { # include <menu.h> } // // ------------------------------------------------------------------------- // This wraps the ITEM type of <menu.h> // ------------------------------------------------------------------------- // class NCURSES_IMPEXP NCursesMenuItem { friend class NCursesMenu; protected: ITEM *item; inline void OnError (int err) const THROW2(NCursesException const, NCursesMenuException) { if (err != E_OK) THROW(new NCursesMenuException (err)); } public: NCursesMenuItem (const char* p_name = NULL, const char* p_descript = NULL) : item(0) { item = p_name ? ::new_item (p_name, p_descript) : STATIC_CAST(ITEM*)(0); if (p_name && !item) OnError (E_SYSTEM_ERROR); } // Create an item. If you pass both parameters as NULL, a delimiting // item is constructed which can be used to terminate a list of // NCursesMenu objects. NCursesMenuItem& operator=(const NCursesMenuItem& rhs) { if (this != &rhs) { *this = rhs; } return *this; } NCursesMenuItem(const NCursesMenuItem& rhs) : item(0) { (void) rhs; } virtual ~NCursesMenuItem (); // Release the items memory inline const char* name () const { return ::item_name (item); } // Name of the item inline const char* description () const { return ::item_description (item); } // Description of the item inline int (index) (void) const { return ::item_index (item); } // Index of the item in an item array (or -1) inline void options_on (Item_Options opts) { OnError (::item_opts_on (item, opts)); } // Switch on the items options inline void options_off (Item_Options opts) { OnError (::item_opts_off (item, opts)); } // Switch off the item's option inline Item_Options options () const { return ::item_opts (item); } // Retrieve the items options inline void set_options (Item_Options opts) { OnError (::set_item_opts (item, opts)); } // Set the items options inline void set_value (bool f) { OnError (::set_item_value (item,f)); } // Set/Reset the items selection state inline bool value () const { return ::item_value (item); } // Retrieve the items selection state inline bool visible () const { return ::item_visible (item); } // Retrieve visibility of the item virtual bool action(); // Perform an action associated with this item; you may use this in an // user supplied driver for a menu; you may derive from this class and // overload action() to supply items with different actions. // If an action returns true, the menu will be exited. The default action // is to do nothing. }; // Prototype for an items callback function. typedef bool ITEMCALLBACK(NCursesMenuItem&); // If you don't like to create a child class for individual items to // overload action(), you may use this class and provide a callback // function pointer for items. class NCURSES_IMPEXP NCursesMenuCallbackItem : public NCursesMenuItem { private: ITEMCALLBACK* p_fct; public: NCursesMenuCallbackItem(ITEMCALLBACK* fct = NULL, const char* p_name = NULL, const char* p_descript = NULL ) : NCursesMenuItem (p_name, p_descript), p_fct (fct) { } NCursesMenuCallbackItem& operator=(const NCursesMenuCallbackItem& rhs) { if (this != &rhs) { *this = rhs; } return *this; } NCursesMenuCallbackItem(const NCursesMenuCallbackItem& rhs) : NCursesMenuItem(rhs), p_fct(0) { } virtual ~NCursesMenuCallbackItem(); bool action(); }; // This are the built-in hook functions in this C++ binding. In C++ we use // virtual member functions (see below On_..._Init and On_..._Termination) // to provide this functionality in an object oriented manner. extern "C" { void _nc_xx_mnu_init(MENU *); void _nc_xx_mnu_term(MENU *); void _nc_xx_itm_init(MENU *); void _nc_xx_itm_term(MENU *); } // // ------------------------------------------------------------------------- // This wraps the MENU type of <menu.h> // ------------------------------------------------------------------------- // class NCURSES_IMPEXP NCursesMenu : public NCursesPanel { protected: MENU *menu; private: NCursesWindow* sub; // the subwindow object bool b_sub_owner; // is this our own subwindow? bool b_framed; // has the menu a border? bool b_autoDelete; // Delete items when deleting menu? NCursesMenuItem** my_items; // The array of items for this menu // This structure is used for the menu's user data field to link the // MENU* to the C++ object and to provide extra space for a user pointer. typedef struct { void* m_user; // the pointer for the user's data const NCursesMenu* m_back; // backward pointer to C++ object const MENU* m_owner; } UserHook; // Get the backward pointer to the C++ object from a MENU static inline NCursesMenu* getHook(const MENU *m) { UserHook* hook = STATIC_CAST(UserHook*)(::menu_userptr(m)); assert(hook != 0 && hook->m_owner==m); return const_cast<NCursesMenu*>(hook->m_back); } friend void _nc_xx_mnu_init(MENU *); friend void _nc_xx_mnu_term(MENU *); friend void _nc_xx_itm_init(MENU *); friend void _nc_xx_itm_term(MENU *); // Calculate ITEM* array for the menu ITEM** mapItems(NCursesMenuItem* nitems[]); protected: // internal routines inline void set_user(void *user) { UserHook* uptr = STATIC_CAST(UserHook*)(::menu_userptr (menu)); assert (uptr != 0 && uptr->m_back==this && uptr->m_owner==menu); uptr->m_user = user; } inline void *get_user() { UserHook* uptr = STATIC_CAST(UserHook*)(::menu_userptr (menu)); assert (uptr != 0 && uptr->m_back==this && uptr->m_owner==menu); return uptr->m_user; } void InitMenu (NCursesMenuItem* menu[], bool with_frame, bool autoDeleteItems); inline void OnError (int err) const THROW2(NCursesException const, NCursesMenuException) { if (err != E_OK) THROW(new NCursesMenuException (this, err)); } // this wraps the menu_driver call. virtual int driver (int c) ; // 'Internal' constructor to create a menu without association to // an array of items. NCursesMenu( int nlines, int ncols, int begin_y = 0, int begin_x = 0) : NCursesPanel(nlines,ncols,begin_y,begin_x), menu (STATIC_CAST(MENU*)(0)), sub(0), b_sub_owner(0), b_framed(0), b_autoDelete(0), my_items(0) { } public: // Make a full window size menu NCursesMenu (NCursesMenuItem* Items[], bool with_frame=FALSE, // Reserve space for a frame? bool autoDelete_Items=FALSE) // Autocleanup of Items? : NCursesPanel(), menu(0), sub(0), b_sub_owner(0), b_framed(0), b_autoDelete(0), my_items(0) { InitMenu(Items, with_frame, autoDelete_Items); } // Make a menu with a window of this size. NCursesMenu (NCursesMenuItem* Items[], int nlines, int ncols, int begin_y = 0, int begin_x = 0, bool with_frame=FALSE, // Reserve space for a frame? bool autoDelete_Items=FALSE) // Autocleanup of Items? : NCursesPanel(nlines, ncols, begin_y, begin_x), menu(0), sub(0), b_sub_owner(0), b_framed(0), b_autoDelete(0), my_items(0) { InitMenu(Items, with_frame, autoDelete_Items); } NCursesMenu& operator=(const NCursesMenu& rhs) { if (this != &rhs) { *this = rhs; NCursesPanel::operator=(rhs); } return *this; } NCursesMenu(const NCursesMenu& rhs) : NCursesPanel(rhs), menu(rhs.menu), sub(rhs.sub), b_sub_owner(rhs.b_sub_owner), b_framed(rhs.b_framed), b_autoDelete(rhs.b_autoDelete), my_items(rhs.my_items) { } virtual ~NCursesMenu (); // Retrieve the menus subwindow inline NCursesWindow& subWindow() const { assert(sub!=NULL); return *sub; } // Set the menus subwindow void setSubWindow(NCursesWindow& sub); // Set these items for the menu inline void setItems(NCursesMenuItem* Items[]) { OnError(::set_menu_items(menu,mapItems(Items))); } // Remove the menu from the screen inline void unpost (void) { OnError (::unpost_menu (menu)); } // Post the menu to the screen if flag is true, unpost it otherwise inline void post(bool flag = TRUE) { flag ? OnError (::post_menu(menu)) : OnError (::unpost_menu (menu)); } // Get the numer of rows and columns for this menu inline void scale (int& mrows, int& mcols) const { OnError (::scale_menu (menu, &mrows, &mcols)); } // Set the format of this menu inline void set_format(int mrows, int mcols) { OnError (::set_menu_format(menu, mrows, mcols)); } // Get the format of this menu inline void menu_format(int& rows,int& ncols) { ::menu_format(menu,&rows,&ncols); } // Items of the menu inline NCursesMenuItem* items() const { return *my_items; } // Get the number of items in this menu inline int count() const { return ::item_count(menu); } // Get the current item (i.e. the one the cursor is located) inline NCursesMenuItem* current_item() const { return my_items[::item_index(::current_item(menu))]; } // Get the marker string inline const char* mark() const { return ::menu_mark(menu); } // Set the marker string inline void set_mark(const char *marker) { OnError (::set_menu_mark (menu, marker)); } // Get the name of the request code c inline static const char* request_name(int c) { return ::menu_request_name(c); } // Get the current pattern inline char* pattern() const { return ::menu_pattern(menu); } // true if there is a pattern match, false otherwise. bool set_pattern (const char *pat); // set the default attributes for the menu // i.e. set fore, back and grey attribute virtual void setDefaultAttributes(); // Get the menus background attributes inline chtype back() const { return ::menu_back(menu); } // Get the menus foreground attributes inline chtype fore() const { return ::menu_fore(menu); } // Get the menus grey attributes (used for unselectable items) inline chtype grey() const { return ::menu_grey(menu); } // Set the menus background attributes inline chtype set_background(chtype a) { return ::set_menu_back(menu,a); } // Set the menus foreground attributes inline chtype set_foreground(chtype a) { return ::set_menu_fore(menu,a); } // Set the menus grey attributes (used for unselectable items) inline chtype set_grey(chtype a) { return ::set_menu_grey(menu,a); } inline void options_on (Menu_Options opts) { OnError (::menu_opts_on (menu,opts)); } inline void options_off(Menu_Options opts) { OnError (::menu_opts_off(menu,opts)); } inline Menu_Options options() const { return ::menu_opts(menu); } inline void set_options (Menu_Options opts) { OnError (::set_menu_opts (menu,opts)); } inline int pad() const { return ::menu_pad(menu); } inline void set_pad (int padch) { OnError (::set_menu_pad (menu, padch)); } // Position the cursor to the current item inline void position_cursor () const { OnError (::pos_menu_cursor (menu)); } // Set the current item inline void set_current(NCursesMenuItem& I) { OnError (::set_current_item(menu, I.item)); } // Get the current top row of the menu inline int top_row (void) const { return ::top_row (menu); } // Set the current top row of the menu inline void set_top_row (int row) { OnError (::set_top_row (menu, row)); } // spacing control // Set the spacing for the menu inline void setSpacing(int spc_description, int spc_rows, int spc_columns) { OnError(::set_menu_spacing(menu, spc_description, spc_rows, spc_columns)); } // Get the spacing info for the menu inline void Spacing(int& spc_description, int& spc_rows, int& spc_columns) const { OnError(::menu_spacing(menu, &spc_description, &spc_rows, &spc_columns)); } // Decorations inline void frame(const char *title=NULL, const char* btitle=NULL) { if (b_framed) NCursesPanel::frame(title,btitle); else OnError(E_SYSTEM_ERROR); } inline void boldframe(const char *title=NULL, const char* btitle=NULL) { if (b_framed) NCursesPanel::boldframe(title,btitle); else OnError(E_SYSTEM_ERROR); } inline void label(const char *topLabel, const char *bottomLabel) { if (b_framed) NCursesPanel::label(topLabel,bottomLabel); else OnError(E_SYSTEM_ERROR); } // ----- // Hooks // ----- // Called after the menu gets repositioned in its window. // This is especially true if the menu is posted. virtual void On_Menu_Init(); // Called before the menu gets repositioned in its window. // This is especially true if the menu is unposted. virtual void On_Menu_Termination(); // Called after the item became the current item virtual void On_Item_Init(NCursesMenuItem& item); // Called before this item is left as current item. virtual void On_Item_Termination(NCursesMenuItem& item); // Provide a default key virtualization. Translate the keyboard // code c into a menu request code. // The default implementation provides a hopefully straightforward // mapping for the most common keystrokes and menu requests. virtual int virtualize(int c); // Operators inline NCursesMenuItem* operator[](int i) const { if ( (i < 0) || (i >= ::item_count (menu)) ) OnError (E_BAD_ARGUMENT); return (my_items[i]); } // Perform the menu's operation // Return the item where you left the selection mark for a single // selection menu, or NULL for a multivalued menu. virtual NCursesMenuItem* operator()(void); // -------------------- // Exception handlers // Called by operator() // -------------------- // Called if the request is denied virtual void On_Request_Denied(int c) const; // Called if the item is not selectable virtual void On_Not_Selectable(int c) const; // Called if pattern doesn't match virtual void On_No_Match(int c) const; // Called if the command is unknown virtual void On_Unknown_Command(int c) const; }; // // ------------------------------------------------------------------------- // This is the typical C++ typesafe way to allow to attach // user data to an item of a menu. Its assumed that the user // data belongs to some class T. Use T as template argument // to create a UserItem. // ------------------------------------------------------------------------- // template<class T> class NCURSES_IMPEXP NCursesUserItem : public NCursesMenuItem { public: NCursesUserItem (const char* p_name, const char* p_descript = NULL, const T* p_UserData = STATIC_CAST(T*)(0)) : NCursesMenuItem (p_name, p_descript) { if (item) OnError (::set_item_userptr (item, const_cast<void *>(reinterpret_cast<const void*>(p_UserData)))); } virtual ~NCursesUserItem() {} inline const T* UserData (void) const { return reinterpret_cast<const T*>(::item_userptr (item)); }; inline virtual void setUserData(const T* p_UserData) { if (item) OnError (::set_item_userptr (item, const_cast<void *>(reinterpret_cast<const void *>(p_UserData)))); } }; // // ------------------------------------------------------------------------- // The same mechanism is used to attach user data to a menu // ------------------------------------------------------------------------- // template<class T> class NCURSES_IMPEXP NCursesUserMenu : public NCursesMenu { protected: NCursesUserMenu( int nlines, int ncols, int begin_y = 0, int begin_x = 0, const T* p_UserData = STATIC_CAST(T*)(0)) : NCursesMenu(nlines,ncols,begin_y,begin_x) { if (menu) set_user (const_cast<void *>(p_UserData)); } public: NCursesUserMenu (NCursesMenuItem* Items[], const T* p_UserData = STATIC_CAST(T*)(0), bool with_frame=FALSE, bool autoDelete_Items=FALSE) : NCursesMenu (Items, with_frame, autoDelete_Items) { if (menu) set_user (const_cast<void *>(p_UserData)); }; NCursesUserMenu (NCursesMenuItem* Items[], int nlines, int ncols, int begin_y = 0, int begin_x = 0, const T* p_UserData = STATIC_CAST(T*)(0), bool with_frame=FALSE) : NCursesMenu (Items, nlines, ncols, begin_y, begin_x, with_frame) { if (menu) set_user (const_cast<void *>(p_UserData)); }; virtual ~NCursesUserMenu() { }; inline T* UserData (void) const { return reinterpret_cast<T*>(get_user ()); }; inline virtual void setUserData (const T* p_UserData) { if (menu) set_user (const_cast<void *>(p_UserData)); } }; #endif /* NCURSES_CURSESM_H_incl */
Save