xref: /openbsd/lib/libmenu/m_opts.c (revision c7ef0cfc)
1*c7ef0cfcSnicm /* $OpenBSD: m_opts.c,v 1.9 2023/10/17 09:52:10 nicm Exp $ */
29f1aa62bSmillert 
3457960bfSmillert /****************************************************************************
4*c7ef0cfcSnicm  * Copyright 2020 Thomas E. Dickey                                          *
5*c7ef0cfcSnicm  * Copyright 1998-2004,2010 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_opts                                                            *
38c166cd22Stholo * Menus option routines                                                    *
39c166cd22Stholo ***************************************************************************/
40c166cd22Stholo 
41c166cd22Stholo #include "menu.priv.h"
42c166cd22Stholo 
43*c7ef0cfcSnicm MODULE_ID("$Id: m_opts.c,v 1.9 2023/10/17 09:52:10 nicm Exp $")
440107aba4Smillert 
45c166cd22Stholo /*---------------------------------------------------------------------------
46c166cd22Stholo |   Facility      :  libnmenu
47c166cd22Stholo |   Function      :  int set_menu_opts(MENU *menu, Menu_Options opts)
48c166cd22Stholo |
49c166cd22Stholo |   Description   :  Set the options for this menu. If the new settings
50c166cd22Stholo |                    end up in a change of the geometry of the menu, it
51c166cd22Stholo |                    will be recalculated. This operation is forbidden if
52c166cd22Stholo |                    the menu is already posted.
53c166cd22Stholo |
54c166cd22Stholo |   Return Values :  E_OK           - success
55c166cd22Stholo |                    E_BAD_ARGUMENT - invalid menu options
56c166cd22Stholo |                    E_POSTED       - menu is already posted
57c166cd22Stholo +--------------------------------------------------------------------------*/
MENU_EXPORT(int)58*c7ef0cfcSnicm MENU_EXPORT(int)
5984af20ceSmillert set_menu_opts(MENU *menu, Menu_Options opts)
60c166cd22Stholo {
61*c7ef0cfcSnicm   T((T_CALLED("set_menu_opts(%p,%d)"), (void *)menu, opts));
6281d8c4e1Snicm 
63936c48d9Smillert   opts &= ALL_MENU_OPTS;
64936c48d9Smillert 
65c166cd22Stholo   if (opts & ~ALL_MENU_OPTS)
66c166cd22Stholo     RETURN(E_BAD_ARGUMENT);
67c166cd22Stholo 
68c166cd22Stholo   if (menu)
69c166cd22Stholo     {
70c166cd22Stholo       if (menu->status & _POSTED)
71c166cd22Stholo 	RETURN(E_POSTED);
72c166cd22Stholo 
73c166cd22Stholo       if ((opts & O_ROWMAJOR) != (menu->opt & O_ROWMAJOR))
74c166cd22Stholo 	{
75c166cd22Stholo 	  /* we need this only if the layout really changed ... */
76c166cd22Stholo 	  if (menu->items && menu->items[0])
77c166cd22Stholo 	    {
78c166cd22Stholo 	      menu->toprow = 0;
79c166cd22Stholo 	      menu->curitem = menu->items[0];
80c166cd22Stholo 	      assert(menu->curitem);
81c166cd22Stholo 	      set_menu_format(menu, menu->frows, menu->fcols);
82c166cd22Stholo 	    }
83c166cd22Stholo 	}
84c166cd22Stholo 
85c166cd22Stholo       menu->opt = opts;
86c166cd22Stholo 
87c166cd22Stholo       if (opts & O_ONEVALUE)
88c166cd22Stholo 	{
89c166cd22Stholo 	  ITEM **item;
90c166cd22Stholo 
910107aba4Smillert 	  if (((item = menu->items) != (ITEM **)0))
92c166cd22Stholo 	    for (; *item; item++)
93c166cd22Stholo 	      (*item)->value = FALSE;
94c166cd22Stholo 	}
95c166cd22Stholo 
96c166cd22Stholo       if (opts & O_SHOWDESC)	/* this also changes the geometry */
97c166cd22Stholo 	_nc_Calculate_Item_Length_and_Width(menu);
98c166cd22Stholo     }
99c166cd22Stholo   else
100c166cd22Stholo     _nc_Default_Menu.opt = opts;
101c166cd22Stholo 
102c166cd22Stholo   RETURN(E_OK);
103c166cd22Stholo }
104c166cd22Stholo 
105c166cd22Stholo /*---------------------------------------------------------------------------
106c166cd22Stholo |   Facility      :  libnmenu
107c166cd22Stholo |   Function      :  int menu_opts_off(MENU *menu, Menu_Options opts)
108c166cd22Stholo |
109c166cd22Stholo |   Description   :  Switch off the options for this menu. If the new settings
110c166cd22Stholo |                    end up in a change of the geometry of the menu, it
111c166cd22Stholo |                    will be recalculated. This operation is forbidden if
112c166cd22Stholo |                    the menu is already posted.
113c166cd22Stholo |
114c166cd22Stholo |   Return Values :  E_OK           - success
115c166cd22Stholo |                    E_BAD_ARGUMENT - invalid options
116c166cd22Stholo |                    E_POSTED       - menu is already posted
117c166cd22Stholo +--------------------------------------------------------------------------*/
118*c7ef0cfcSnicm MENU_EXPORT(int)
menu_opts_off(MENU * menu,Menu_Options opts)11984af20ceSmillert menu_opts_off(MENU *menu, Menu_Options opts)
120c166cd22Stholo {
121c166cd22Stholo   MENU *cmenu = menu;		/* use a copy because set_menu_opts must detect
12281d8c4e1Snicm 
12381d8c4e1Snicm 				   NULL menu itself to adjust its behavior */
12481d8c4e1Snicm 
125*c7ef0cfcSnicm   T((T_CALLED("menu_opts_off(%p,%d)"), (void *)menu, opts));
126c166cd22Stholo 
127936c48d9Smillert   opts &= ALL_MENU_OPTS;
128c166cd22Stholo   if (opts & ~ALL_MENU_OPTS)
129c166cd22Stholo     RETURN(E_BAD_ARGUMENT);
130c166cd22Stholo   else
131c166cd22Stholo     {
132c166cd22Stholo       Normalize_Menu(cmenu);
133c166cd22Stholo       opts = cmenu->opt & ~opts;
13481d8c4e1Snicm       returnCode(set_menu_opts(menu, opts));
135c166cd22Stholo     }
136c166cd22Stholo }
137c166cd22Stholo 
138c166cd22Stholo /*---------------------------------------------------------------------------
139c166cd22Stholo |   Facility      :  libnmenu
140c166cd22Stholo |   Function      :  int menu_opts_on(MENU *menu, Menu_Options opts)
141c166cd22Stholo |
142c166cd22Stholo |   Description   :  Switch on the options for this menu. If the new settings
143c166cd22Stholo |                    end up in a change of the geometry of the menu, it
144c166cd22Stholo |                    will be recalculated. This operation is forbidden if
145c166cd22Stholo |                    the menu is already posted.
146c166cd22Stholo |
147c166cd22Stholo |   Return Values :  E_OK           - success
148c166cd22Stholo |                    E_BAD_ARGUMENT - invalid menu options
149c166cd22Stholo |                    E_POSTED       - menu is already posted
150c166cd22Stholo +--------------------------------------------------------------------------*/
151*c7ef0cfcSnicm MENU_EXPORT(int)
menu_opts_on(MENU * menu,Menu_Options opts)15284af20ceSmillert menu_opts_on(MENU *menu, Menu_Options opts)
153c166cd22Stholo {
154c166cd22Stholo   MENU *cmenu = menu;		/* use a copy because set_menu_opts must detect
15581d8c4e1Snicm 
15681d8c4e1Snicm 				   NULL menu itself to adjust its behavior */
15781d8c4e1Snicm 
158*c7ef0cfcSnicm   T((T_CALLED("menu_opts_on(%p,%d)"), (void *)menu, opts));
159c166cd22Stholo 
160936c48d9Smillert   opts &= ALL_MENU_OPTS;
161c166cd22Stholo   if (opts & ~ALL_MENU_OPTS)
162c166cd22Stholo     RETURN(E_BAD_ARGUMENT);
163c166cd22Stholo   else
164c166cd22Stholo     {
165c166cd22Stholo       Normalize_Menu(cmenu);
166c166cd22Stholo       opts = cmenu->opt | opts;
16781d8c4e1Snicm       returnCode(set_menu_opts(menu, opts));
168c166cd22Stholo     }
169c166cd22Stholo }
170c166cd22Stholo 
171c166cd22Stholo /*---------------------------------------------------------------------------
172c166cd22Stholo |   Facility      :  libnmenu
173c166cd22Stholo |   Function      :  Menu_Options menu_opts(const MENU *menu)
174c166cd22Stholo |
175c166cd22Stholo |   Description   :  Return the options for this menu.
176c166cd22Stholo |
177c166cd22Stholo |   Return Values :  Menu options
178c166cd22Stholo +--------------------------------------------------------------------------*/
179*c7ef0cfcSnicm MENU_EXPORT(Menu_Options)
menu_opts(const MENU * menu)18084af20ceSmillert menu_opts(const MENU *menu)
181c166cd22Stholo {
182*c7ef0cfcSnicm   T((T_CALLED("menu_opts(%p)"), (const void *)menu));
18381d8c4e1Snicm   returnMenuOpts(ALL_MENU_OPTS & Normalize_Menu(menu)->opt);
184c166cd22Stholo }
185c166cd22Stholo 
186c166cd22Stholo /* m_opts.c ends here */
187