xref: /freebsd/contrib/ncurses/menu/m_attribs.c (revision 21817992b3314c908ab50f0bb88d2ee750b9c4ac)
10e3d5408SPeter Wemm /****************************************************************************
2*21817992SBaptiste Daroussin  * Copyright 2020,2021 Thomas E. Dickey                                     *
3e1865124SBaptiste Daroussin  * Copyright 1998-2010,2012 Free Software Foundation, Inc.                  *
40e3d5408SPeter Wemm  *                                                                          *
50e3d5408SPeter Wemm  * Permission is hereby granted, free of charge, to any person obtaining a  *
60e3d5408SPeter Wemm  * copy of this software and associated documentation files (the            *
70e3d5408SPeter Wemm  * "Software"), to deal in the Software without restriction, including      *
80e3d5408SPeter Wemm  * without limitation the rights to use, copy, modify, merge, publish,      *
90e3d5408SPeter Wemm  * distribute, distribute with modifications, sublicense, and/or sell       *
100e3d5408SPeter Wemm  * copies of the Software, and to permit persons to whom the Software is    *
110e3d5408SPeter Wemm  * furnished to do so, subject to the following conditions:                 *
120e3d5408SPeter Wemm  *                                                                          *
130e3d5408SPeter Wemm  * The above copyright notice and this permission notice shall be included  *
140e3d5408SPeter Wemm  * in all copies or substantial portions of the Software.                   *
150e3d5408SPeter Wemm  *                                                                          *
160e3d5408SPeter Wemm  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
170e3d5408SPeter Wemm  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
180e3d5408SPeter Wemm  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
190e3d5408SPeter Wemm  * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
200e3d5408SPeter Wemm  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
210e3d5408SPeter Wemm  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
220e3d5408SPeter Wemm  * THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
230e3d5408SPeter Wemm  *                                                                          *
240e3d5408SPeter Wemm  * Except as contained in this notice, the name(s) of the above copyright   *
250e3d5408SPeter Wemm  * holders shall not be used in advertising or otherwise to promote the     *
260e3d5408SPeter Wemm  * sale, use or other dealings in this Software without prior written       *
270e3d5408SPeter Wemm  * authorization.                                                           *
280e3d5408SPeter Wemm  ****************************************************************************/
290e3d5408SPeter Wemm 
300e3d5408SPeter Wemm /****************************************************************************
314a1a9510SRong-En Fan  *   Author:  Juergen Pfeifer, 1995,1997                                    *
320e3d5408SPeter Wemm  ****************************************************************************/
330e3d5408SPeter Wemm 
340e3d5408SPeter Wemm /***************************************************************************
350e3d5408SPeter Wemm * Module m_attribs                                                         *
360e3d5408SPeter Wemm * Control menus display attributes                                         *
370e3d5408SPeter Wemm ***************************************************************************/
380e3d5408SPeter Wemm 
390e3d5408SPeter Wemm #include "menu.priv.h"
400e3d5408SPeter Wemm 
41*21817992SBaptiste Daroussin MODULE_ID("$Id: m_attribs.c,v 1.20 2021/06/17 21:20:30 tom Exp $")
420e3d5408SPeter Wemm 
430e3d5408SPeter Wemm /* Macro to redraw menu if it is posted and changed */
440e3d5408SPeter Wemm #define Refresh_Menu(menu) \
450e3d5408SPeter Wemm    if ( (menu) && ((menu)->status & _POSTED) )\
460e3d5408SPeter Wemm    {\
470e3d5408SPeter Wemm       _nc_Draw_Menu( menu );\
480e3d5408SPeter Wemm       _nc_Show_Menu( menu );\
490e3d5408SPeter Wemm    }
500e3d5408SPeter Wemm 
510e3d5408SPeter Wemm /* "Template" macro to generate a function to set a menus attribute */
520e3d5408SPeter Wemm #define GEN_MENU_ATTR_SET_FCT( name ) \
537a656419SBaptiste Daroussin MENU_EXPORT(int) NCURSES_API set_menu_ ## name (MENU* menu, chtype attr) \
540e3d5408SPeter Wemm {\
5573f0a83dSXin LI   T((T_CALLED("set_menu_" #name "(%p,%s)"), (void *) menu, _traceattr(attr))); \
560e3d5408SPeter Wemm    if (!(attr==A_NORMAL || (attr & A_ATTRIBUTES)==attr))\
570e3d5408SPeter Wemm       RETURN(E_BAD_ARGUMENT);\
580e3d5408SPeter Wemm    if (menu && ( menu -> name != attr))\
590e3d5408SPeter Wemm      {\
600e3d5408SPeter Wemm        (menu -> name) = attr;\
610e3d5408SPeter Wemm        Refresh_Menu(menu);\
620e3d5408SPeter Wemm      }\
630e3d5408SPeter Wemm    Normalize_Menu( menu ) -> name = attr;\
640e3d5408SPeter Wemm    RETURN(E_OK);\
650e3d5408SPeter Wemm }
660e3d5408SPeter Wemm 
674a1a9510SRong-En Fan /* "Template" macro to generate a function to get a menu's attribute */
680e3d5408SPeter Wemm #define GEN_MENU_ATTR_GET_FCT( name ) \
697a656419SBaptiste Daroussin MENU_EXPORT(chtype) NCURSES_API menu_ ## name (const MENU * menu)\
700e3d5408SPeter Wemm {\
7106bfebdeSXin LI    T((T_CALLED("menu_" #name "(%p)"), (const void *) menu));\
724a1a9510SRong-En Fan    returnAttr(Normalize_Menu( menu ) -> name);\
730e3d5408SPeter Wemm }
740e3d5408SPeter Wemm 
750e3d5408SPeter Wemm /*---------------------------------------------------------------------------
760e3d5408SPeter Wemm |   Facility      :  libnmenu
770e3d5408SPeter Wemm |   Function      :  int set_menu_fore(MENU *menu, chtype attr)
780e3d5408SPeter Wemm |
790e3d5408SPeter Wemm |   Description   :  Set the attribute for selectable items. In single-
804a1a9510SRong-En Fan |                    valued menus this is used to highlight the current
810e3d5408SPeter Wemm |                    item ((i.e. where the cursor is), in multi-valued
820e3d5408SPeter Wemm |                    menus this is used to highlight the selected items.
830e3d5408SPeter Wemm |
840e3d5408SPeter Wemm |   Return Values :  E_OK              - success
850e3d5408SPeter Wemm |                    E_BAD_ARGUMENT    - an invalid value has been passed
860e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
870e3d5408SPeter Wemm GEN_MENU_ATTR_SET_FCT(fore)
880e3d5408SPeter Wemm 
890e3d5408SPeter Wemm /*---------------------------------------------------------------------------
900e3d5408SPeter Wemm |   Facility      :  libnmenu
910e3d5408SPeter Wemm |   Function      :  chtype menu_fore(const MENU* menu)
920e3d5408SPeter Wemm |
930e3d5408SPeter Wemm |   Description   :  Return the attribute used for selectable items that
940e3d5408SPeter Wemm |                    are current (single-valued menu) or selected (multi-
950e3d5408SPeter Wemm |                    valued menu).
960e3d5408SPeter Wemm |
970e3d5408SPeter Wemm |   Return Values :  Attribute value
980e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
990e3d5408SPeter Wemm GEN_MENU_ATTR_GET_FCT(fore)
1000e3d5408SPeter Wemm 
1010e3d5408SPeter Wemm /*---------------------------------------------------------------------------
1020e3d5408SPeter Wemm |   Facility      :  libnmenu
1030e3d5408SPeter Wemm |   Function      :  int set_menu_back(MENU *menu, chtype attr)
1040e3d5408SPeter Wemm |
1050e3d5408SPeter Wemm |   Description   :  Set the attribute for selectable but not yet selected
1060e3d5408SPeter Wemm |                    items.
1070e3d5408SPeter Wemm |
1080e3d5408SPeter Wemm |   Return Values :  E_OK             - success
1090e3d5408SPeter Wemm |                    E_BAD_ARGUMENT   - an invalid value has been passed
1100e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1110e3d5408SPeter Wemm GEN_MENU_ATTR_SET_FCT(back)
1120e3d5408SPeter Wemm 
1130e3d5408SPeter Wemm /*---------------------------------------------------------------------------
1140e3d5408SPeter Wemm |   Facility      :  libnmenu
1150e3d5408SPeter Wemm |   Function      :  chtype menu_back(const MENU *menu)
1160e3d5408SPeter Wemm |
1170e3d5408SPeter Wemm |   Description   :  Return the attribute used for selectable but not yet
1180e3d5408SPeter Wemm |                    selected items.
1190e3d5408SPeter Wemm |
1200e3d5408SPeter Wemm |   Return Values :  Attribute value
1210e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1220e3d5408SPeter Wemm GEN_MENU_ATTR_GET_FCT(back)
1230e3d5408SPeter Wemm 
1240e3d5408SPeter Wemm /*---------------------------------------------------------------------------
1250e3d5408SPeter Wemm |   Facility      :  libnmenu
1260e3d5408SPeter Wemm |   Function      :  int set_menu_grey(MENU *menu, chtype attr)
1270e3d5408SPeter Wemm |
1280e3d5408SPeter Wemm |   Description   :  Set the attribute for unselectable items.
1290e3d5408SPeter Wemm |
1300e3d5408SPeter Wemm |   Return Values :  E_OK             - success
1310e3d5408SPeter Wemm |                    E_BAD_ARGUMENT   - an invalid value has been passed
1320e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1330e3d5408SPeter Wemm GEN_MENU_ATTR_SET_FCT(grey)
1340e3d5408SPeter Wemm 
1350e3d5408SPeter Wemm /*---------------------------------------------------------------------------
1360e3d5408SPeter Wemm |   Facility      :  libnmenu
1370e3d5408SPeter Wemm |   Function      :  chtype menu_grey(const MENU *menu)
1380e3d5408SPeter Wemm |
1390e3d5408SPeter Wemm |   Description   :  Return the attribute used for non-selectable items
1400e3d5408SPeter Wemm |
1410e3d5408SPeter Wemm |   Return Values :  Attribute value
1420e3d5408SPeter Wemm +--------------------------------------------------------------------------*/
1430e3d5408SPeter Wemm GEN_MENU_ATTR_GET_FCT(grey)
14406bfebdeSXin LI 
1450e3d5408SPeter Wemm /* m_attribs.c ends here */
146