source: menu/lxdialog/dialog.h@ eb8667a

new_features
Last change on this file since eb8667a was 743414b, checked in by Pierre Labastie <pierre@…>, 13 years ago

Changes slightly the code in menu directory so that "conf"
and "mconf" build without issuing warnings

  • Property mode set to 100644
File size: 6.1 KB
Line 
1
2/*
3 * dialog.h -- common declarations for all dialog modules
4 *
5 * AUTHOR: Savio Lam (lam836@cs.cuhk.hk)
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 */
21
22#include <sys/types.h>
23#include <fcntl.h>
24#include <unistd.h>
25#include <ctype.h>
26#include <stdlib.h>
27#include <string.h>
28
29#ifdef LOCALE
30#include <locale.h>
31#endif
32
33#ifdef CURSES_LOC
34#ifdef __sun__
35#define CURS_MACROS
36#endif
37#include CURSES_LOC
38
39/*
40 * Colors in ncurses 1.9.9e do not work properly since foreground and
41 * background colors are OR'd rather than separately masked. This version
42 * of dialog was hacked to work with ncurses 1.9.9e, making it incompatible
43 * with standard curses. The simplest fix (to make this work with standard
44 * curses) uses the wbkgdset() function, not used in the original hack.
45 * Turn it off if we're building with 1.9.9e, since it just confuses things.
46 */
47#if defined(NCURSES_VERSION) && defined(_NEED_WRAP) && !defined(GCC_PRINTFLIKE)
48#define OLD_NCURSES 1
49#undef wbkgdset
50#define wbkgdset(w,p) /*nothing*/
51#else
52#define OLD_NCURSES 0
53#endif
54
55#define TR(params) _tracef params
56
57#define ESC 27
58#define TAB 9
59#define MAX_LEN 2048
60#define BUF_SIZE (10*1024)
61#define MIN(x,y) (x < y ? x : y)
62#define MAX(x,y) (x > y ? x : y)
63
64
65#ifndef ACS_ULCORNER
66#define ACS_ULCORNER '+'
67#endif
68#ifndef ACS_LLCORNER
69#define ACS_LLCORNER '+'
70#endif
71#ifndef ACS_URCORNER
72#define ACS_URCORNER '+'
73#endif
74#ifndef ACS_LRCORNER
75#define ACS_LRCORNER '+'
76#endif
77#ifndef ACS_HLINE
78#define ACS_HLINE '-'
79#endif
80#ifndef ACS_VLINE
81#define ACS_VLINE '|'
82#endif
83#ifndef ACS_LTEE
84#define ACS_LTEE '+'
85#endif
86#ifndef ACS_RTEE
87#define ACS_RTEE '+'
88#endif
89#ifndef ACS_UARROW
90#define ACS_UARROW '^'
91#endif
92#ifndef ACS_DARROW
93#define ACS_DARROW 'v'
94#endif
95
96/*
97 * Attribute names
98 */
99#define screen_attr attributes[0]
100#define shadow_attr attributes[1]
101#define dialog_attr attributes[2]
102#define title_attr attributes[3]
103#define border_attr attributes[4]
104#define button_active_attr attributes[5]
105#define button_inactive_attr attributes[6]
106#define button_key_active_attr attributes[7]
107#define button_key_inactive_attr attributes[8]
108#define button_label_active_attr attributes[9]
109#define button_label_inactive_attr attributes[10]
110#define inputbox_attr attributes[11]
111#define inputbox_border_attr attributes[12]
112#define searchbox_attr attributes[13]
113#define searchbox_title_attr attributes[14]
114#define searchbox_border_attr attributes[15]
115#define position_indicator_attr attributes[16]
116#define menubox_attr attributes[17]
117#define menubox_border_attr attributes[18]
118#define item_attr attributes[19]
119#define item_selected_attr attributes[20]
120#define tag_attr attributes[21]
121#define tag_selected_attr attributes[22]
122#define tag_key_attr attributes[23]
123#define tag_key_selected_attr attributes[24]
124#define check_attr attributes[25]
125#define check_selected_attr attributes[26]
126#define uarrow_attr attributes[27]
127#define darrow_attr attributes[28]
128
129/* number of attributes */
130#define ATTRIBUTE_COUNT 29
131
132/*
133 * Global variables
134 */
135extern bool use_colors;
136
137extern chtype attributes[];
138#endif
139
140extern const char *backtitle;
141
142struct dialog_list_item {
143 char *name;
144 int namelen;
145 char *tag;
146 int selected; /* Set to 1 by dialog_*() function. */
147};
148
149/*
150 * Function prototypes
151 */
152
153void init_dialog (void);
154void end_dialog (void);
155void dialog_clear (void);
156#ifdef CURSES_LOC
157void attr_clear (WINDOW * win, int height, int width, chtype attr);
158void color_setup (void);
159void print_autowrap (WINDOW * win, const char *prompt, int width, int y, int x);
160void print_button (WINDOW * win, const char *label, int y, int x, int selected);
161void draw_box (WINDOW * win, int y, int x, int height, int width, chtype box,
162 chtype border);
163void draw_shadow (WINDOW * win, int y, int x, int height, int width);
164#endif
165
166int first_alpha (const char *string, const char *exempt);
167int dialog_yesno (const char *title, const char *prompt, int height, int width);
168int dialog_msgbox (const char *title, const char *prompt, int height,
169 int width, int pause);
170int dialog_textbox (const char *title, const char *file, int height, int width);
171int dialog_menu (const char *title, const char *prompt, int height, int width,
172 int menu_height, const char *choice, int item_no,
173 struct dialog_list_item ** items);
174int dialog_checklist (const char *title, const char *prompt, int height,
175 int width, int list_height, int item_no,
176 struct dialog_list_item ** items, int flag);
177extern char dialog_input_result[];
178int dialog_inputbox (const char *title, const char *prompt, int height,
179 int width, const char *init);
180
181struct dialog_list_item *first_sel_item(int item_no,
182 struct dialog_list_item ** items);
183
184/*
185 * This is the base for fictitious keys, which activate
186 * the buttons.
187 *
188 * Mouse-generated keys are the following:
189 * -- the first 32 are used as numbers, in addition to '0'-'9'
190 * -- the lowercase are used to signal mouse-enter events (M_EVENT + 'o')
191 * -- uppercase chars are used to invoke the button (M_EVENT + 'O')
192 */
193#ifdef CURSES_LOC
194#define M_EVENT (KEY_MAX+1)
195#endif
196
197
198/*
199 * The `flag' parameter in checklist is used to select between
200 * radiolist and checklist
201 */
202#define FLAG_CHECK 1
203#define FLAG_RADIO 0
Note: See TracBrowser for help on using the repository browser.