1 /****************************************************************************
2 * Copyright (c) 1998-2004,2009 Free Software Foundation, Inc. *
4 * Permission is hereby granted, free of charge, to any person obtaining a *
5 * copy of this software and associated documentation files (the *
6 * "Software"), to deal in the Software without restriction, including *
7 * without limitation the rights to use, copy, modify, merge, publish, *
8 * distribute, distribute with modifications, sublicense, and/or sell *
9 * copies of the Software, and to permit persons to whom the Software is *
10 * furnished to do so, subject to the following conditions: *
12 * The above copyright notice and this permission notice shall be included *
13 * in all copies or substantial portions of the Software. *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS *
16 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF *
17 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *
18 * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, *
19 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR *
20 * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *
21 * THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
23 * Except as contained in this notice, the name(s) of the above copyright *
24 * holders shall not be used in advertising or otherwise to promote the *
25 * sale, use or other dealings in this Software without prior written *
27 ****************************************************************************/
29 /****************************************************************************
30 * Author: Juergen Pfeifer, 1995,1997 *
31 ****************************************************************************/
33 /* $Id: form.h,v 0.21 2009/11/07 19:31:11 tom Exp $ */
40 #include <ncurses_cfg.h>
47 typedef void *FIELD_CELL
;
50 #ifndef NCURSES_FIELD_INTERNALS
51 #define NCURSES_FIELD_INTERNALS /* nothing */
54 typedef int Form_Options
;
55 typedef int Field_Options
;
62 short pmin
; /* index of first field on page */
63 short pmax
; /* index of last field on page */
64 short smin
; /* index of top leftmost field on page */
65 short smax
; /* index of bottom rightmost field on page */
72 typedef struct fieldnode
{
73 unsigned short status
; /* flags */
74 short rows
; /* size in rows */
75 short cols
; /* size in cols */
76 short frow
; /* first row */
77 short fcol
; /* first col */
78 int drows
; /* dynamic rows */
79 int dcols
; /* dynamic cols */
80 int maxgrow
; /* maximum field growth */
81 int nrow
; /* off-screen rows */
82 short nbuf
; /* additional buffers */
83 short just
; /* justification */
84 short page
; /* page on form */
85 short index
; /* into form -> field */
86 int pad
; /* pad character */
87 chtype fore
; /* foreground attribute */
88 chtype back
; /* background attribute */
89 Field_Options opts
; /* options */
90 struct fieldnode
* snext
; /* sorted order pointer */
91 struct fieldnode
* sprev
; /* sorted order pointer */
92 struct fieldnode
* link
; /* linked field chain */
93 struct formnode
* form
; /* containing form */
94 struct typenode
* type
; /* field type */
95 void * arg
; /* argument for type */
96 FIELD_CELL
* buf
; /* field buffers */
97 void * usrptr
; /* user pointer */
99 * The wide-character configuration requires extra information. Because
100 * there are existing applications that manipulate the members of FIELD
101 * directly, we cannot make the struct opaque. Offsets of members up to
102 * this point are the same in the narrow- and wide-character configuration.
103 * But note that the type of buf depends on the configuration, and is made
104 * opaque for that reason.
106 NCURSES_FIELD_INTERNALS
114 typedef struct formnode
{
115 unsigned short status
; /* flags */
116 short rows
; /* size in rows */
117 short cols
; /* size in cols */
118 int currow
; /* current row in field window */
119 int curcol
; /* current col in field window */
120 int toprow
; /* in scrollable field window */
121 int begincol
; /* in horiz. scrollable field */
122 short maxfield
; /* number of fields */
123 short maxpage
; /* number of pages */
124 short curpage
; /* index into page */
125 Form_Options opts
; /* options */
126 WINDOW
* win
; /* window */
127 WINDOW
* sub
; /* subwindow */
128 WINDOW
* w
; /* window for current field */
129 FIELD
** field
; /* field [maxfield] */
130 FIELD
* current
; /* current field */
131 _PAGE
* page
; /* page [maxpage] */
132 void * usrptr
; /* user pointer */
134 void (*forminit
)(struct formnode
*);
135 void (*formterm
)(struct formnode
*);
136 void (*fieldinit
)(struct formnode
*);
137 void (*fieldterm
)(struct formnode
*);
146 typedef struct typenode
{
147 unsigned short status
; /* flags */
148 long ref
; /* reference count */
149 struct typenode
* left
; /* ptr to operand for | */
150 struct typenode
* right
; /* ptr to operand for | */
152 void* (*makearg
)(va_list *); /* make fieldtype arg */
153 void* (*copyarg
)(const void *); /* copy fieldtype arg */
154 void (*freearg
)(void *); /* free fieldtype arg */
156 #if NCURSES_INTEROP_FUNCS
158 bool (*ofcheck
)(FIELD
*,const void *); /* field validation */
159 bool (*gfcheck
)(FORM
*,FIELD
*,const void*); /* generic field validation */
162 bool (*occheck
)(int,const void *); /* character validation */
163 bool (*gccheck
)(int,FORM
*,
164 FIELD
*,const void*); /* generic char validation */
167 bool (*onext
)(FIELD
*,const void *); /* enumerate next value */
168 bool (*gnext
)(FORM
*,FIELD
*,const void*); /* generic enumerate next */
171 bool (*oprev
)(FIELD
*,const void *); /* enumerate prev value */
172 bool (*gprev
)(FORM
*,FIELD
*,const void*); /* generic enumerate prev */
174 void* (*genericarg
)(void*); /* Alternate Arg method */
176 bool (*fcheck
)(FIELD
*,const void *); /* field validation */
177 bool (*ccheck
)(int,const void *); /* character validation */
179 bool (*next
)(FIELD
*,const void *); /* enumerate next value */
180 bool (*prev
)(FIELD
*,const void *); /* enumerate prev value */
184 typedef void (*Form_Hook
)(FORM
*);
186 /***************************
187 * miscellaneous #defines *
188 ***************************/
190 /* field justification */
191 #define NO_JUSTIFICATION (0)
192 #define JUSTIFY_LEFT (1)
193 #define JUSTIFY_CENTER (2)
194 #define JUSTIFY_RIGHT (3)
197 #define O_VISIBLE (0x0001U)
198 #define O_ACTIVE (0x0002U)
199 #define O_PUBLIC (0x0004U)
200 #define O_EDIT (0x0008U)
201 #define O_WRAP (0x0010U)
202 #define O_BLANK (0x0020U)
203 #define O_AUTOSKIP (0x0040U)
204 #define O_NULLOK (0x0080U)
205 #define O_PASSOK (0x0100U)
206 #define O_STATIC (0x0200U)
209 #define O_NL_OVERLOAD (0x0001U)
210 #define O_BS_OVERLOAD (0x0002U)
212 /* form driver commands */
213 #define REQ_NEXT_PAGE (KEY_MAX + 1) /* move to next page */
214 #define REQ_PREV_PAGE (KEY_MAX + 2) /* move to previous page */
215 #define REQ_FIRST_PAGE (KEY_MAX + 3) /* move to first page */
216 #define REQ_LAST_PAGE (KEY_MAX + 4) /* move to last page */
218 #define REQ_NEXT_FIELD (KEY_MAX + 5) /* move to next field */
219 #define REQ_PREV_FIELD (KEY_MAX + 6) /* move to previous field */
220 #define REQ_FIRST_FIELD (KEY_MAX + 7) /* move to first field */
221 #define REQ_LAST_FIELD (KEY_MAX + 8) /* move to last field */
222 #define REQ_SNEXT_FIELD (KEY_MAX + 9) /* move to sorted next field */
223 #define REQ_SPREV_FIELD (KEY_MAX + 10) /* move to sorted prev field */
224 #define REQ_SFIRST_FIELD (KEY_MAX + 11) /* move to sorted first field */
225 #define REQ_SLAST_FIELD (KEY_MAX + 12) /* move to sorted last field */
226 #define REQ_LEFT_FIELD (KEY_MAX + 13) /* move to left to field */
227 #define REQ_RIGHT_FIELD (KEY_MAX + 14) /* move to right to field */
228 #define REQ_UP_FIELD (KEY_MAX + 15) /* move to up to field */
229 #define REQ_DOWN_FIELD (KEY_MAX + 16) /* move to down to field */
231 #define REQ_NEXT_CHAR (KEY_MAX + 17) /* move to next char in field */
232 #define REQ_PREV_CHAR (KEY_MAX + 18) /* move to prev char in field */
233 #define REQ_NEXT_LINE (KEY_MAX + 19) /* move to next line in field */
234 #define REQ_PREV_LINE (KEY_MAX + 20) /* move to prev line in field */
235 #define REQ_NEXT_WORD (KEY_MAX + 21) /* move to next word in field */
236 #define REQ_PREV_WORD (KEY_MAX + 22) /* move to prev word in field */
237 #define REQ_BEG_FIELD (KEY_MAX + 23) /* move to first char in field */
238 #define REQ_END_FIELD (KEY_MAX + 24) /* move after last char in fld */
239 #define REQ_BEG_LINE (KEY_MAX + 25) /* move to beginning of line */
240 #define REQ_END_LINE (KEY_MAX + 26) /* move after last char in line */
241 #define REQ_LEFT_CHAR (KEY_MAX + 27) /* move left in field */
242 #define REQ_RIGHT_CHAR (KEY_MAX + 28) /* move right in field */
243 #define REQ_UP_CHAR (KEY_MAX + 29) /* move up in field */
244 #define REQ_DOWN_CHAR (KEY_MAX + 30) /* move down in field */
246 #define REQ_NEW_LINE (KEY_MAX + 31) /* insert/overlay new line */
247 #define REQ_INS_CHAR (KEY_MAX + 32) /* insert blank char at cursor */
248 #define REQ_INS_LINE (KEY_MAX + 33) /* insert blank line at cursor */
249 #define REQ_DEL_CHAR (KEY_MAX + 34) /* delete char at cursor */
250 #define REQ_DEL_PREV (KEY_MAX + 35) /* delete char before cursor */
251 #define REQ_DEL_LINE (KEY_MAX + 36) /* delete line at cursor */
252 #define REQ_DEL_WORD (KEY_MAX + 37) /* delete word at cursor */
253 #define REQ_CLR_EOL (KEY_MAX + 38) /* clear to end of line */
254 #define REQ_CLR_EOF (KEY_MAX + 39) /* clear to end of field */
255 #define REQ_CLR_FIELD (KEY_MAX + 40) /* clear entire field */
256 #define REQ_OVL_MODE (KEY_MAX + 41) /* begin overlay mode */
257 #define REQ_INS_MODE (KEY_MAX + 42) /* begin insert mode */
258 #define REQ_SCR_FLINE (KEY_MAX + 43) /* scroll field forward a line */
259 #define REQ_SCR_BLINE (KEY_MAX + 44) /* scroll field backward a line */
260 #define REQ_SCR_FPAGE (KEY_MAX + 45) /* scroll field forward a page */
261 #define REQ_SCR_BPAGE (KEY_MAX + 46) /* scroll field backward a page */
262 #define REQ_SCR_FHPAGE (KEY_MAX + 47) /* scroll field forward half page */
263 #define REQ_SCR_BHPAGE (KEY_MAX + 48) /* scroll field backward half page */
264 #define REQ_SCR_FCHAR (KEY_MAX + 49) /* horizontal scroll char */
265 #define REQ_SCR_BCHAR (KEY_MAX + 50) /* horizontal scroll char */
266 #define REQ_SCR_HFLINE (KEY_MAX + 51) /* horizontal scroll line */
267 #define REQ_SCR_HBLINE (KEY_MAX + 52) /* horizontal scroll line */
268 #define REQ_SCR_HFHALF (KEY_MAX + 53) /* horizontal scroll half line */
269 #define REQ_SCR_HBHALF (KEY_MAX + 54) /* horizontal scroll half line */
271 #define REQ_VALIDATION (KEY_MAX + 55) /* validate field */
272 #define REQ_NEXT_CHOICE (KEY_MAX + 56) /* display next field choice */
273 #define REQ_PREV_CHOICE (KEY_MAX + 57) /* display prev field choice */
275 #define MIN_FORM_COMMAND (KEY_MAX + 1) /* used by form_driver */
276 #define MAX_FORM_COMMAND (KEY_MAX + 57) /* used by form_driver */
278 #if defined(MAX_COMMAND)
279 # if (MAX_FORM_COMMAND > MAX_COMMAND)
280 # error Something is wrong -- MAX_FORM_COMMAND is greater than MAX_COMMAND
281 # elif (MAX_COMMAND != (KEY_MAX + 128))
282 # error Something is wrong -- MAX_COMMAND is already inconsistently defined.
285 # define MAX_COMMAND (KEY_MAX + 128)
288 /*************************
289 * standard field types *
290 *************************/
291 extern NCURSES_EXPORT_VAR(FIELDTYPE
*) TYPE_ALPHA
;
292 extern NCURSES_EXPORT_VAR(FIELDTYPE
*) TYPE_ALNUM
;
293 extern NCURSES_EXPORT_VAR(FIELDTYPE
*) TYPE_ENUM
;
294 extern NCURSES_EXPORT_VAR(FIELDTYPE
*) TYPE_INTEGER
;
295 extern NCURSES_EXPORT_VAR(FIELDTYPE
*) TYPE_NUMERIC
;
296 extern NCURSES_EXPORT_VAR(FIELDTYPE
*) TYPE_REGEXP
;
298 /************************************
299 * built-in additional field types *
300 * They are not defined in SVr4 *
301 ************************************/
302 extern NCURSES_EXPORT_VAR(FIELDTYPE
*) TYPE_IPV4
; /* Internet IP Version 4 address */
304 /***********************
305 * FIELDTYPE routines *
306 ***********************/
307 extern NCURSES_EXPORT(FIELDTYPE
*) new_fieldtype (
308 bool (* const field_check
)(FIELD
*,const void *),
309 bool (* const char_check
)(int,const void *));
310 extern NCURSES_EXPORT(FIELDTYPE
*) link_fieldtype(
311 FIELDTYPE
*, FIELDTYPE
*);
313 extern NCURSES_EXPORT(int) free_fieldtype (FIELDTYPE
*);
314 extern NCURSES_EXPORT(int) set_fieldtype_arg (FIELDTYPE
*,
315 void * (* const make_arg
)(va_list *),
316 void * (* const copy_arg
)(const void *),
317 void (* const free_arg
)(void *));
318 extern NCURSES_EXPORT(int) set_fieldtype_choice (FIELDTYPE
*,
319 bool (* const next_choice
)(FIELD
*,const void *),
320 bool (* const prev_choice
)(FIELD
*,const void *));
325 extern NCURSES_EXPORT(FIELD
*) new_field (int,int,int,int,int,int);
326 extern NCURSES_EXPORT(FIELD
*) dup_field (FIELD
*,int,int);
327 extern NCURSES_EXPORT(FIELD
*) link_field (FIELD
*,int,int);
329 extern NCURSES_EXPORT(int) free_field (FIELD
*);
330 extern NCURSES_EXPORT(int) field_info (const FIELD
*,int *,int *,int *,int *,int *,int *);
331 extern NCURSES_EXPORT(int) dynamic_field_info (const FIELD
*,int *,int *,int *);
332 extern NCURSES_EXPORT(int) set_max_field ( FIELD
*,int);
333 extern NCURSES_EXPORT(int) move_field (FIELD
*,int,int);
334 extern NCURSES_EXPORT(int) set_field_type (FIELD
*,FIELDTYPE
*,...);
335 extern NCURSES_EXPORT(int) set_new_page (FIELD
*,bool);
336 extern NCURSES_EXPORT(int) set_field_just (FIELD
*,int);
337 extern NCURSES_EXPORT(int) field_just (const FIELD
*);
338 extern NCURSES_EXPORT(int) set_field_fore (FIELD
*,chtype
);
339 extern NCURSES_EXPORT(int) set_field_back (FIELD
*,chtype
);
340 extern NCURSES_EXPORT(int) set_field_pad (FIELD
*,int);
341 extern NCURSES_EXPORT(int) field_pad (const FIELD
*);
342 extern NCURSES_EXPORT(int) set_field_buffer (FIELD
*,int,const char *);
343 extern NCURSES_EXPORT(int) set_field_status (FIELD
*,bool);
344 extern NCURSES_EXPORT(int) set_field_userptr (FIELD
*, void *);
345 extern NCURSES_EXPORT(int) set_field_opts (FIELD
*,Field_Options
);
346 extern NCURSES_EXPORT(int) field_opts_on (FIELD
*,Field_Options
);
347 extern NCURSES_EXPORT(int) field_opts_off (FIELD
*,Field_Options
);
349 extern NCURSES_EXPORT(chtype
) field_fore (const FIELD
*);
350 extern NCURSES_EXPORT(chtype
) field_back (const FIELD
*);
352 extern NCURSES_EXPORT(bool) new_page (const FIELD
*);
353 extern NCURSES_EXPORT(bool) field_status (const FIELD
*);
355 extern NCURSES_EXPORT(void *) field_arg (const FIELD
*);
357 extern NCURSES_EXPORT(void *) field_userptr (const FIELD
*);
359 extern NCURSES_EXPORT(FIELDTYPE
*) field_type (const FIELD
*);
361 extern NCURSES_EXPORT(char *) field_buffer (const FIELD
*,int);
363 extern NCURSES_EXPORT(Field_Options
) field_opts (const FIELD
*);
369 extern NCURSES_EXPORT(FORM
*) new_form (FIELD
**);
371 extern NCURSES_EXPORT(FIELD
**) form_fields (const FORM
*);
372 extern NCURSES_EXPORT(FIELD
*) current_field (const FORM
*);
374 extern NCURSES_EXPORT(WINDOW
*) form_win (const FORM
*);
375 extern NCURSES_EXPORT(WINDOW
*) form_sub (const FORM
*);
377 extern NCURSES_EXPORT(Form_Hook
) form_init (const FORM
*);
378 extern NCURSES_EXPORT(Form_Hook
) form_term (const FORM
*);
379 extern NCURSES_EXPORT(Form_Hook
) field_init (const FORM
*);
380 extern NCURSES_EXPORT(Form_Hook
) field_term (const FORM
*);
382 extern NCURSES_EXPORT(int) free_form (FORM
*);
383 extern NCURSES_EXPORT(int) set_form_fields (FORM
*,FIELD
**);
384 extern NCURSES_EXPORT(int) field_count (const FORM
*);
385 extern NCURSES_EXPORT(int) set_form_win (FORM
*,WINDOW
*);
386 extern NCURSES_EXPORT(int) set_form_sub (FORM
*,WINDOW
*);
387 extern NCURSES_EXPORT(int) set_current_field (FORM
*,FIELD
*);
388 extern NCURSES_EXPORT(int) field_index (const FIELD
*);
389 extern NCURSES_EXPORT(int) set_form_page (FORM
*,int);
390 extern NCURSES_EXPORT(int) form_page (const FORM
*);
391 extern NCURSES_EXPORT(int) scale_form (const FORM
*,int *,int *);
392 extern NCURSES_EXPORT(int) set_form_init (FORM
*,Form_Hook
);
393 extern NCURSES_EXPORT(int) set_form_term (FORM
*,Form_Hook
);
394 extern NCURSES_EXPORT(int) set_field_init (FORM
*,Form_Hook
);
395 extern NCURSES_EXPORT(int) set_field_term (FORM
*,Form_Hook
);
396 extern NCURSES_EXPORT(int) post_form (FORM
*);
397 extern NCURSES_EXPORT(int) unpost_form (FORM
*);
398 extern NCURSES_EXPORT(int) pos_form_cursor (FORM
*);
399 extern NCURSES_EXPORT(int) form_driver (FORM
*,int);
400 extern NCURSES_EXPORT(int) set_form_userptr (FORM
*,void *);
401 extern NCURSES_EXPORT(int) set_form_opts (FORM
*,Form_Options
);
402 extern NCURSES_EXPORT(int) form_opts_on (FORM
*,Form_Options
);
403 extern NCURSES_EXPORT(int) form_opts_off (FORM
*,Form_Options
);
404 extern NCURSES_EXPORT(int) form_request_by_name (const char *);
406 extern NCURSES_EXPORT(const char *) form_request_name (int);
408 extern NCURSES_EXPORT(void *) form_userptr (const FORM
*);
410 extern NCURSES_EXPORT(Form_Options
) form_opts (const FORM
*);
412 extern NCURSES_EXPORT(bool) data_ahead (const FORM
*);
413 extern NCURSES_EXPORT(bool) data_behind (const FORM
*);
416 extern NCURSES_EXPORT(FORM
*) NCURSES_SP_NAME(new_form
) (SCREEN
*, FIELD
**);