xref: /openbsd-src/lib/libmenu/m_attribs.c (revision c7ef0cfc17afcba97172c25e1e3a943e893bc632)
1*c7ef0cfcSnicm /* $OpenBSD: m_attribs.c,v 1.8 2023/10/17 09:52:10 nicm Exp $ */
29f1aa62bSmillert 
3457960bfSmillert /****************************************************************************
4*c7ef0cfcSnicm  * Copyright 2020,2021 Thomas E. Dickey                                     *
5*c7ef0cfcSnicm  * Copyright 1998-2010,2012 Free Software Foundation, Inc.                  *
6457960bfSmillert  *                                                                          *
7457960bfSmillert  * Permission is hereby granted, free of charge, to any person obtaining a  *
8457960bfSmillert  * copy of this software and associated documentation files (the            *
9457960bfSmillert  * "Software"), to deal in the Software without restriction, including      *
10457960bfSmillert  * without limitation the rights to use, copy, modify, merge, publish,      *
11457960bfSmillert  * distribute, distribute with modifications, sublicense, and/or sell       *
12457960bfSmillert  * copies of the Software, and to permit persons to whom the Software is    *
13457960bfSmillert  * furnished to do so, subject to the following conditions:                 *
14457960bfSmillert  *                                                                          *
15457960bfSmillert  * The above copyright notice and this permission notice shall be included  *
16457960bfSmillert  * in all copies or substantial portions of the Software.                   *
17457960bfSmillert  *                                                                          *
18457960bfSmillert  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
19457960bfSmillert  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
20457960bfSmillert  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
21457960bfSmillert  * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
22457960bfSmillert  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
23457960bfSmillert  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
24457960bfSmillert  * THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
25457960bfSmillert  *                                                                          *
26457960bfSmillert  * Except as contained in this notice, the name(s) of the above copyright   *
27457960bfSmillert  * holders shall not be used in advertising or otherwise to promote the     *
28457960bfSmillert  * sale, use or other dealings in this Software without prior written       *
29457960bfSmillert  * authorization.                                                           *
30457960bfSmillert  ****************************************************************************/
31457960bfSmillert 
32457960bfSmillert /****************************************************************************
3381d8c4e1Snicm  *   Author:  Juergen Pfeifer, 1995,1997                                    *
34457960bfSmillert  ****************************************************************************/
35c166cd22Stholo 
36c166cd22Stholo /***************************************************************************
379f1aa62bSmillert * Module m_attribs                                                         *
38c166cd22Stholo * Control menus display attributes                                         *
39c166cd22Stholo ***************************************************************************/
40c166cd22Stholo 
41c166cd22Stholo #include "menu.priv.h"
42c166cd22Stholo 
43*c7ef0cfcSnicm MODULE_ID("$Id: m_attribs.c,v 1.8 2023/10/17 09:52:10 nicm Exp $")
440107aba4Smillert 
45c166cd22Stholo /* Macro to redraw menu if it is posted and changed */
46c166cd22Stholo #define Refresh_Menu(menu) \
47c166cd22Stholo    if ( (menu) && ((menu)->status & _POSTED) )\
48c166cd22Stholo    {\
49c166cd22Stholo       _nc_Draw_Menu( menu );\
50c166cd22Stholo       _nc_Show_Menu( menu );\
51c166cd22Stholo    }
52c166cd22Stholo 
53c166cd22Stholo /* "Template" macro to generate a function to set a menus attribute */
54c166cd22Stholo #define GEN_MENU_ATTR_SET_FCT( name ) \
55*c7ef0cfcSnicm MENU_EXPORT(int) NCURSES_API set_menu_ ## name (MENU* menu, chtype attr) \
56c166cd22Stholo {\
57*c7ef0cfcSnicm   T((T_CALLED("set_menu_" #name "(%p,%s)"), (void *) menu, _traceattr(attr))); \
58c166cd22Stholo    if (!(attr==A_NORMAL || (attr & A_ATTRIBUTES)==attr))\
59c166cd22Stholo       RETURN(E_BAD_ARGUMENT);\
60c166cd22Stholo    if (menu && ( menu -> name != attr))\
61c166cd22Stholo      {\
62c166cd22Stholo        (menu -> name) = attr;\
63c166cd22Stholo        Refresh_Menu(menu);\
64c166cd22Stholo      }\
65c166cd22Stholo    Normalize_Menu( menu ) -> name = attr;\
66c166cd22Stholo    RETURN(E_OK);\
67c166cd22Stholo }
68c166cd22Stholo 
6981d8c4e1Snicm /* "Template" macro to generate a function to get a menu's attribute */
70c166cd22Stholo #define GEN_MENU_ATTR_GET_FCT( name ) \
71*c7ef0cfcSnicm MENU_EXPORT(chtype) NCURSES_API menu_ ## name (const MENU * menu)\
72c166cd22Stholo {\
73*c7ef0cfcSnicm    T((T_CALLED("menu_" #name "(%p)"), (const void *) menu));\
7481d8c4e1Snicm    returnAttr(Normalize_Menu( menu ) -> name);\
75c166cd22Stholo }
76c166cd22Stholo 
77c166cd22Stholo /*---------------------------------------------------------------------------
78c166cd22Stholo |   Facility      :  libnmenu
79c166cd22Stholo |   Function      :  int set_menu_fore(MENU *menu, chtype attr)
80c166cd22Stholo |
81c166cd22Stholo |   Description   :  Set the attribute for selectable items. In single-
8281d8c4e1Snicm |                    valued menus this is used to highlight the current
83c166cd22Stholo |                    item ((i.e. where the cursor is), in multi-valued
84c166cd22Stholo |                    menus this is used to highlight the selected items.
85c166cd22Stholo |
86c166cd22Stholo |   Return Values :  E_OK              - success
87c166cd22Stholo |                    E_BAD_ARGUMENT    - an invalid value has been passed
88c166cd22Stholo +--------------------------------------------------------------------------*/
89c166cd22Stholo GEN_MENU_ATTR_SET_FCT(fore)
90c166cd22Stholo 
91c166cd22Stholo /*---------------------------------------------------------------------------
92c166cd22Stholo |   Facility      :  libnmenu
93c166cd22Stholo |   Function      :  chtype menu_fore(const MENU* menu)
94c166cd22Stholo |
95c166cd22Stholo |   Description   :  Return the attribute used for selectable items that
96c166cd22Stholo |                    are current (single-valued menu) or selected (multi-
97c166cd22Stholo |                    valued menu).
98c166cd22Stholo |
99c166cd22Stholo |   Return Values :  Attribute value
100c166cd22Stholo +--------------------------------------------------------------------------*/
101c166cd22Stholo GEN_MENU_ATTR_GET_FCT(fore)
102c166cd22Stholo 
103c166cd22Stholo /*---------------------------------------------------------------------------
104c166cd22Stholo |   Facility      :  libnmenu
105c166cd22Stholo |   Function      :  int set_menu_back(MENU *menu, chtype attr)
106c166cd22Stholo |
107c166cd22Stholo |   Description   :  Set the attribute for selectable but not yet selected
108c166cd22Stholo |                    items.
109c166cd22Stholo |
110c166cd22Stholo |   Return Values :  E_OK             - success
111c166cd22Stholo |                    E_BAD_ARGUMENT   - an invalid value has been passed
112c166cd22Stholo +--------------------------------------------------------------------------*/
113c166cd22Stholo GEN_MENU_ATTR_SET_FCT(back)
114c166cd22Stholo 
115c166cd22Stholo /*---------------------------------------------------------------------------
116c166cd22Stholo |   Facility      :  libnmenu
117c166cd22Stholo |   Function      :  chtype menu_back(const MENU *menu)
118c166cd22Stholo |
119c166cd22Stholo |   Description   :  Return the attribute used for selectable but not yet
120c166cd22Stholo |                    selected items.
121c166cd22Stholo |
122c166cd22Stholo |   Return Values :  Attribute value
123c166cd22Stholo +--------------------------------------------------------------------------*/
124c166cd22Stholo GEN_MENU_ATTR_GET_FCT(back)
125c166cd22Stholo 
126c166cd22Stholo /*---------------------------------------------------------------------------
127c166cd22Stholo |   Facility      :  libnmenu
128c166cd22Stholo |   Function      :  int set_menu_grey(MENU *menu, chtype attr)
129c166cd22Stholo |
130c166cd22Stholo |   Description   :  Set the attribute for unselectable items.
131c166cd22Stholo |
132c166cd22Stholo |   Return Values :  E_OK             - success
133c166cd22Stholo |                    E_BAD_ARGUMENT   - an invalid value has been passed
134c166cd22Stholo +--------------------------------------------------------------------------*/
135c166cd22Stholo GEN_MENU_ATTR_SET_FCT(grey)
136c166cd22Stholo 
137c166cd22Stholo /*---------------------------------------------------------------------------
138c166cd22Stholo |   Facility      :  libnmenu
139c166cd22Stholo |   Function      :  chtype menu_grey(const MENU *menu)
140c166cd22Stholo |
141c166cd22Stholo |   Description   :  Return the attribute used for non-selectable items
142c166cd22Stholo |
143c166cd22Stholo |   Return Values :  Attribute value
144c166cd22Stholo +--------------------------------------------------------------------------*/
145c166cd22Stholo GEN_MENU_ATTR_GET_FCT(grey)
146*c7ef0cfcSnicm 
147c166cd22Stholo /* m_attribs.c ends here */
148