xref: /netbsd/lib/libmenu/attributes.c (revision bf9ec67e)
1 /*	$NetBSD: attributes.c,v 1.6 2001/06/13 10:45:59 wiz Exp $	*/
2 
3 /*-
4  * Copyright (c) 1998-1999 Brett Lymn (blymn@baea.com.au, brett_lymn@yahoo.com.au)
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. The name of the author may not be used to endorse or promote products
13  *    derived from this software without specific prior written permission
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
16  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
17  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
18  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
19  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
20  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
21  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
22  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
24  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25  *
26  *
27  */
28 
29 #include <menu.h>
30 
31 /* defined in menu.c - the default menu struct */
32 extern MENU _menui_default_menu;
33 
34 /*
35  * Set the menu foreground attribute
36  */
37 int
38 set_menu_fore(MENU *menu, attr_t attr)
39 {
40 	if (menu == NULL)
41 		_menui_default_menu.fore = attr;
42 	else
43 		menu->fore = attr;
44         return E_OK;
45 }
46 
47 /*
48  * Return the menu foreground attribute
49  */
50 char
51 menu_fore(MENU *menu)
52 {
53 	if (menu == NULL)
54 		return _menui_default_menu.fore;
55 	else
56 		return menu->fore;
57 }
58 
59 /*
60  * Set the menu background attribute
61  */
62 int
63 set_menu_back(MENU *menu, attr_t attr)
64 {
65 	if (menu == NULL)
66 		_menui_default_menu.back = attr;
67 	else
68 		menu->back = attr;
69         return E_OK;
70 }
71 
72 /*
73  * Return the menu background attribute
74  */
75 char
76 menu_back(MENU *menu)
77 {
78 	if (menu == NULL)
79 		return _menui_default_menu.back;
80 	else
81 		return menu->back;
82 }
83 
84 /*
85  * Set the menu greyed out attribute
86  */
87 int
88 set_menu_grey(MENU *menu, attr_t attr)
89 {
90 	if (menu == NULL)
91 		_menui_default_menu.grey = attr;
92 	else
93 		menu->grey = attr;
94         return E_OK;
95 }
96 
97 /*
98  * Return the menu greyed out attribute
99  */
100 char
101 menu_grey(MENU *menu)
102 {
103 	if (menu == NULL)
104 		return _menui_default_menu.grey;
105 	else
106 		return menu->grey;
107 }
108 
109 /*
110  * Set the menu pad character - the filler char between name and description
111  */
112 int
113 set_menu_pad(MENU *menu, int pad)
114 {
115 	if (menu == NULL)
116 		_menui_default_menu.pad = pad;
117 	else
118 		menu->pad = pad;
119         return E_OK;
120 }
121 
122 /*
123  * Return the menu pad character
124  */
125 int
126 menu_pad(MENU *menu)
127 {
128 	if (menu == NULL)
129 		return _menui_default_menu.pad;
130 	else
131 		return menu->pad;
132 }
133