form.h 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429
  1. /****************************************************************************
  2. * Copyright (c) 1998-2014,2015 Free Software Foundation, Inc. *
  3. * *
  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: *
  11. * *
  12. * The above copyright notice and this permission notice shall be included *
  13. * in all copies or substantial portions of the Software. *
  14. * *
  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. *
  22. * *
  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 *
  26. * authorization. *
  27. ****************************************************************************/
  28. /****************************************************************************
  29. * Author: Juergen Pfeifer, 1995,1997 *
  30. ****************************************************************************/
  31. /* $Id: form.h,v 0.25 2015/11/28 20:13:39 Leon.Winter Exp $ */
  32. #ifndef FORM_H
  33. #define FORM_H
  34. /* *INDENT-OFF*/
  35. #include <curses.h>
  36. #include <eti.h>
  37. #ifdef __cplusplus
  38. extern "C" {
  39. #endif
  40. #ifndef FORM_PRIV_H
  41. typedef void *FIELD_CELL;
  42. #endif
  43. #ifndef NCURSES_FIELD_INTERNALS
  44. #define NCURSES_FIELD_INTERNALS /* nothing */
  45. #endif
  46. typedef int Form_Options;
  47. typedef int Field_Options;
  48. /**********
  49. * _PAGE *
  50. **********/
  51. typedef struct {
  52. short pmin; /* index of first field on page */
  53. short pmax; /* index of last field on page */
  54. short smin; /* index of top leftmost field on page */
  55. short smax; /* index of bottom rightmost field on page */
  56. } _PAGE;
  57. /**********
  58. * FIELD *
  59. **********/
  60. typedef struct fieldnode {
  61. unsigned short status; /* flags */
  62. short rows; /* size in rows */
  63. short cols; /* size in cols */
  64. short frow; /* first row */
  65. short fcol; /* first col */
  66. int drows; /* dynamic rows */
  67. int dcols; /* dynamic cols */
  68. int maxgrow; /* maximum field growth */
  69. int nrow; /* off-screen rows */
  70. short nbuf; /* additional buffers */
  71. short just; /* justification */
  72. short page; /* page on form */
  73. short index; /* into form -> field */
  74. int pad; /* pad character */
  75. chtype fore; /* foreground attribute */
  76. chtype back; /* background attribute */
  77. Field_Options opts; /* options */
  78. struct fieldnode * snext; /* sorted order pointer */
  79. struct fieldnode * sprev; /* sorted order pointer */
  80. struct fieldnode * link; /* linked field chain */
  81. struct formnode * form; /* containing form */
  82. struct typenode * type; /* field type */
  83. void * arg; /* argument for type */
  84. FIELD_CELL * buf; /* field buffers */
  85. void * usrptr; /* user pointer */
  86. /*
  87. * The wide-character configuration requires extra information. Because
  88. * there are existing applications that manipulate the members of FIELD
  89. * directly, we cannot make the struct opaque. Offsets of members up to
  90. * this point are the same in the narrow- and wide-character configuration.
  91. * But note that the type of buf depends on the configuration, and is made
  92. * opaque for that reason.
  93. */
  94. NCURSES_FIELD_INTERNALS
  95. } FIELD;
  96. /*********
  97. * FORM *
  98. *********/
  99. typedef struct formnode {
  100. unsigned short status; /* flags */
  101. short rows; /* size in rows */
  102. short cols; /* size in cols */
  103. int currow; /* current row in field window */
  104. int curcol; /* current col in field window */
  105. int toprow; /* in scrollable field window */
  106. int begincol; /* in horiz. scrollable field */
  107. short maxfield; /* number of fields */
  108. short maxpage; /* number of pages */
  109. short curpage; /* index into page */
  110. Form_Options opts; /* options */
  111. WINDOW * win; /* window */
  112. WINDOW * sub; /* subwindow */
  113. WINDOW * w; /* window for current field */
  114. FIELD ** field; /* field [maxfield] */
  115. FIELD * current; /* current field */
  116. _PAGE * page; /* page [maxpage] */
  117. void * usrptr; /* user pointer */
  118. void (*forminit)(struct formnode *);
  119. void (*formterm)(struct formnode *);
  120. void (*fieldinit)(struct formnode *);
  121. void (*fieldterm)(struct formnode *);
  122. } FORM;
  123. /**************
  124. * FIELDTYPE *
  125. **************/
  126. typedef struct typenode {
  127. unsigned short status; /* flags */
  128. long ref; /* reference count */
  129. struct typenode * left; /* ptr to operand for | */
  130. struct typenode * right; /* ptr to operand for | */
  131. void* (*makearg)(va_list *); /* make fieldtype arg */
  132. void* (*copyarg)(const void *); /* copy fieldtype arg */
  133. void (*freearg)(void *); /* free fieldtype arg */
  134. #if NCURSES_INTEROP_FUNCS
  135. union {
  136. bool (*ofcheck)(FIELD *,const void *); /* field validation */
  137. bool (*gfcheck)(FORM*,FIELD *,const void*); /* generic field validation */
  138. } fieldcheck;
  139. union {
  140. bool (*occheck)(int,const void *); /* character validation */
  141. bool (*gccheck)(int,FORM*,
  142. FIELD*,const void*); /* generic char validation */
  143. } charcheck;
  144. union {
  145. bool (*onext)(FIELD *,const void *); /* enumerate next value */
  146. bool (*gnext)(FORM*,FIELD*,const void*); /* generic enumerate next */
  147. } enum_next;
  148. union {
  149. bool (*oprev)(FIELD *,const void *); /* enumerate prev value */
  150. bool (*gprev)(FORM*,FIELD*,const void*); /* generic enumerate prev */
  151. } enum_prev;
  152. void* (*genericarg)(void*); /* Alternate Arg method */
  153. #else
  154. bool (*fcheck)(FIELD *,const void *); /* field validation */
  155. bool (*ccheck)(int,const void *); /* character validation */
  156. bool (*next)(FIELD *,const void *); /* enumerate next value */
  157. bool (*prev)(FIELD *,const void *); /* enumerate prev value */
  158. #endif
  159. } FIELDTYPE;
  160. typedef void (*Form_Hook)(FORM *);
  161. /***************************
  162. * miscellaneous #defines *
  163. ***************************/
  164. /* field justification */
  165. #define NO_JUSTIFICATION (0)
  166. #define JUSTIFY_LEFT (1)
  167. #define JUSTIFY_CENTER (2)
  168. #define JUSTIFY_RIGHT (3)
  169. /* field options */
  170. #define O_VISIBLE (0x0001U)
  171. #define O_ACTIVE (0x0002U)
  172. #define O_PUBLIC (0x0004U)
  173. #define O_EDIT (0x0008U)
  174. #define O_WRAP (0x0010U)
  175. #define O_BLANK (0x0020U)
  176. #define O_AUTOSKIP (0x0040U)
  177. #define O_NULLOK (0x0080U)
  178. #define O_PASSOK (0x0100U)
  179. #define O_STATIC (0x0200U)
  180. #define O_DYNAMIC_JUSTIFY (0x0400U) /* ncurses extension */
  181. #define O_NO_LEFT_STRIP (0x0800U) /* ncurses extension */
  182. /* form options */
  183. #define O_NL_OVERLOAD (0x0001U)
  184. #define O_BS_OVERLOAD (0x0002U)
  185. /* form driver commands */
  186. #define REQ_NEXT_PAGE (KEY_MAX + 1) /* move to next page */
  187. #define REQ_PREV_PAGE (KEY_MAX + 2) /* move to previous page */
  188. #define REQ_FIRST_PAGE (KEY_MAX + 3) /* move to first page */
  189. #define REQ_LAST_PAGE (KEY_MAX + 4) /* move to last page */
  190. #define REQ_NEXT_FIELD (KEY_MAX + 5) /* move to next field */
  191. #define REQ_PREV_FIELD (KEY_MAX + 6) /* move to previous field */
  192. #define REQ_FIRST_FIELD (KEY_MAX + 7) /* move to first field */
  193. #define REQ_LAST_FIELD (KEY_MAX + 8) /* move to last field */
  194. #define REQ_SNEXT_FIELD (KEY_MAX + 9) /* move to sorted next field */
  195. #define REQ_SPREV_FIELD (KEY_MAX + 10) /* move to sorted prev field */
  196. #define REQ_SFIRST_FIELD (KEY_MAX + 11) /* move to sorted first field */
  197. #define REQ_SLAST_FIELD (KEY_MAX + 12) /* move to sorted last field */
  198. #define REQ_LEFT_FIELD (KEY_MAX + 13) /* move to left to field */
  199. #define REQ_RIGHT_FIELD (KEY_MAX + 14) /* move to right to field */
  200. #define REQ_UP_FIELD (KEY_MAX + 15) /* move to up to field */
  201. #define REQ_DOWN_FIELD (KEY_MAX + 16) /* move to down to field */
  202. #define REQ_NEXT_CHAR (KEY_MAX + 17) /* move to next char in field */
  203. #define REQ_PREV_CHAR (KEY_MAX + 18) /* move to prev char in field */
  204. #define REQ_NEXT_LINE (KEY_MAX + 19) /* move to next line in field */
  205. #define REQ_PREV_LINE (KEY_MAX + 20) /* move to prev line in field */
  206. #define REQ_NEXT_WORD (KEY_MAX + 21) /* move to next word in field */
  207. #define REQ_PREV_WORD (KEY_MAX + 22) /* move to prev word in field */
  208. #define REQ_BEG_FIELD (KEY_MAX + 23) /* move to first char in field */
  209. #define REQ_END_FIELD (KEY_MAX + 24) /* move after last char in fld */
  210. #define REQ_BEG_LINE (KEY_MAX + 25) /* move to beginning of line */
  211. #define REQ_END_LINE (KEY_MAX + 26) /* move after last char in line */
  212. #define REQ_LEFT_CHAR (KEY_MAX + 27) /* move left in field */
  213. #define REQ_RIGHT_CHAR (KEY_MAX + 28) /* move right in field */
  214. #define REQ_UP_CHAR (KEY_MAX + 29) /* move up in field */
  215. #define REQ_DOWN_CHAR (KEY_MAX + 30) /* move down in field */
  216. #define REQ_NEW_LINE (KEY_MAX + 31) /* insert/overlay new line */
  217. #define REQ_INS_CHAR (KEY_MAX + 32) /* insert blank char at cursor */
  218. #define REQ_INS_LINE (KEY_MAX + 33) /* insert blank line at cursor */
  219. #define REQ_DEL_CHAR (KEY_MAX + 34) /* delete char at cursor */
  220. #define REQ_DEL_PREV (KEY_MAX + 35) /* delete char before cursor */
  221. #define REQ_DEL_LINE (KEY_MAX + 36) /* delete line at cursor */
  222. #define REQ_DEL_WORD (KEY_MAX + 37) /* delete word at cursor */
  223. #define REQ_CLR_EOL (KEY_MAX + 38) /* clear to end of line */
  224. #define REQ_CLR_EOF (KEY_MAX + 39) /* clear to end of field */
  225. #define REQ_CLR_FIELD (KEY_MAX + 40) /* clear entire field */
  226. #define REQ_OVL_MODE (KEY_MAX + 41) /* begin overlay mode */
  227. #define REQ_INS_MODE (KEY_MAX + 42) /* begin insert mode */
  228. #define REQ_SCR_FLINE (KEY_MAX + 43) /* scroll field forward a line */
  229. #define REQ_SCR_BLINE (KEY_MAX + 44) /* scroll field backward a line */
  230. #define REQ_SCR_FPAGE (KEY_MAX + 45) /* scroll field forward a page */
  231. #define REQ_SCR_BPAGE (KEY_MAX + 46) /* scroll field backward a page */
  232. #define REQ_SCR_FHPAGE (KEY_MAX + 47) /* scroll field forward half page */
  233. #define REQ_SCR_BHPAGE (KEY_MAX + 48) /* scroll field backward half page */
  234. #define REQ_SCR_FCHAR (KEY_MAX + 49) /* horizontal scroll char */
  235. #define REQ_SCR_BCHAR (KEY_MAX + 50) /* horizontal scroll char */
  236. #define REQ_SCR_HFLINE (KEY_MAX + 51) /* horizontal scroll line */
  237. #define REQ_SCR_HBLINE (KEY_MAX + 52) /* horizontal scroll line */
  238. #define REQ_SCR_HFHALF (KEY_MAX + 53) /* horizontal scroll half line */
  239. #define REQ_SCR_HBHALF (KEY_MAX + 54) /* horizontal scroll half line */
  240. #define REQ_VALIDATION (KEY_MAX + 55) /* validate field */
  241. #define REQ_NEXT_CHOICE (KEY_MAX + 56) /* display next field choice */
  242. #define REQ_PREV_CHOICE (KEY_MAX + 57) /* display prev field choice */
  243. #define MIN_FORM_COMMAND (KEY_MAX + 1) /* used by form_driver */
  244. #define MAX_FORM_COMMAND (KEY_MAX + 57) /* used by form_driver */
  245. #if defined(MAX_COMMAND)
  246. # if (MAX_FORM_COMMAND > MAX_COMMAND)
  247. # error Something is wrong -- MAX_FORM_COMMAND is greater than MAX_COMMAND
  248. # elif (MAX_COMMAND != (KEY_MAX + 128))
  249. # error Something is wrong -- MAX_COMMAND is already inconsistently defined.
  250. # endif
  251. #else
  252. # define MAX_COMMAND (KEY_MAX + 128)
  253. #endif
  254. /*************************
  255. * standard field types *
  256. *************************/
  257. extern NCURSES_EXPORT_VAR(FIELDTYPE *) TYPE_ALPHA;
  258. extern NCURSES_EXPORT_VAR(FIELDTYPE *) TYPE_ALNUM;
  259. extern NCURSES_EXPORT_VAR(FIELDTYPE *) TYPE_ENUM;
  260. extern NCURSES_EXPORT_VAR(FIELDTYPE *) TYPE_INTEGER;
  261. extern NCURSES_EXPORT_VAR(FIELDTYPE *) TYPE_NUMERIC;
  262. extern NCURSES_EXPORT_VAR(FIELDTYPE *) TYPE_REGEXP;
  263. /************************************
  264. * built-in additional field types *
  265. * They are not defined in SVr4 *
  266. ************************************/
  267. extern NCURSES_EXPORT_VAR(FIELDTYPE *) TYPE_IPV4; /* Internet IP Version 4 address */
  268. /***********************
  269. * FIELDTYPE routines *
  270. ***********************/
  271. extern NCURSES_EXPORT(FIELDTYPE *) new_fieldtype (
  272. bool (* const field_check)(FIELD *,const void *),
  273. bool (* const char_check)(int,const void *));
  274. extern NCURSES_EXPORT(FIELDTYPE *) link_fieldtype(
  275. FIELDTYPE *, FIELDTYPE *);
  276. extern NCURSES_EXPORT(int) free_fieldtype (FIELDTYPE *);
  277. extern NCURSES_EXPORT(int) set_fieldtype_arg (FIELDTYPE *,
  278. void * (* const make_arg)(va_list *),
  279. void * (* const copy_arg)(const void *),
  280. void (* const free_arg)(void *));
  281. extern NCURSES_EXPORT(int) set_fieldtype_choice (FIELDTYPE *,
  282. bool (* const next_choice)(FIELD *,const void *),
  283. bool (* const prev_choice)(FIELD *,const void *));
  284. /*******************
  285. * FIELD routines *
  286. *******************/
  287. extern NCURSES_EXPORT(FIELD *) new_field (int,int,int,int,int,int);
  288. extern NCURSES_EXPORT(FIELD *) dup_field (FIELD *,int,int);
  289. extern NCURSES_EXPORT(FIELD *) link_field (FIELD *,int,int);
  290. extern NCURSES_EXPORT(int) free_field (FIELD *);
  291. extern NCURSES_EXPORT(int) field_info (const FIELD *,int *,int *,int *,int *,int *,int *);
  292. extern NCURSES_EXPORT(int) dynamic_field_info (const FIELD *,int *,int *,int *);
  293. extern NCURSES_EXPORT(int) set_max_field ( FIELD *,int);
  294. extern NCURSES_EXPORT(int) move_field (FIELD *,int,int);
  295. extern NCURSES_EXPORT(int) set_field_type (FIELD *,FIELDTYPE *,...);
  296. extern NCURSES_EXPORT(int) set_new_page (FIELD *,bool);
  297. extern NCURSES_EXPORT(int) set_field_just (FIELD *,int);
  298. extern NCURSES_EXPORT(int) field_just (const FIELD *);
  299. extern NCURSES_EXPORT(int) set_field_fore (FIELD *,chtype);
  300. extern NCURSES_EXPORT(int) set_field_back (FIELD *,chtype);
  301. extern NCURSES_EXPORT(int) set_field_pad (FIELD *,int);
  302. extern NCURSES_EXPORT(int) field_pad (const FIELD *);
  303. extern NCURSES_EXPORT(int) set_field_buffer (FIELD *,int,const char *);
  304. extern NCURSES_EXPORT(int) set_field_status (FIELD *,bool);
  305. extern NCURSES_EXPORT(int) set_field_userptr (FIELD *, void *);
  306. extern NCURSES_EXPORT(int) set_field_opts (FIELD *,Field_Options);
  307. extern NCURSES_EXPORT(int) field_opts_on (FIELD *,Field_Options);
  308. extern NCURSES_EXPORT(int) field_opts_off (FIELD *,Field_Options);
  309. extern NCURSES_EXPORT(chtype) field_fore (const FIELD *);
  310. extern NCURSES_EXPORT(chtype) field_back (const FIELD *);
  311. extern NCURSES_EXPORT(bool) new_page (const FIELD *);
  312. extern NCURSES_EXPORT(bool) field_status (const FIELD *);
  313. extern NCURSES_EXPORT(void *) field_arg (const FIELD *);
  314. extern NCURSES_EXPORT(void *) field_userptr (const FIELD *);
  315. extern NCURSES_EXPORT(FIELDTYPE *) field_type (const FIELD *);
  316. extern NCURSES_EXPORT(char *) field_buffer (const FIELD *,int);
  317. extern NCURSES_EXPORT(Field_Options) field_opts (const FIELD *);
  318. /******************
  319. * FORM routines *
  320. ******************/
  321. extern NCURSES_EXPORT(FORM *) new_form (FIELD **);
  322. extern NCURSES_EXPORT(FIELD **) form_fields (const FORM *);
  323. extern NCURSES_EXPORT(FIELD *) current_field (const FORM *);
  324. extern NCURSES_EXPORT(WINDOW *) form_win (const FORM *);
  325. extern NCURSES_EXPORT(WINDOW *) form_sub (const FORM *);
  326. extern NCURSES_EXPORT(Form_Hook) form_init (const FORM *);
  327. extern NCURSES_EXPORT(Form_Hook) form_term (const FORM *);
  328. extern NCURSES_EXPORT(Form_Hook) field_init (const FORM *);
  329. extern NCURSES_EXPORT(Form_Hook) field_term (const FORM *);
  330. extern NCURSES_EXPORT(int) free_form (FORM *);
  331. extern NCURSES_EXPORT(int) set_form_fields (FORM *,FIELD **);
  332. extern NCURSES_EXPORT(int) field_count (const FORM *);
  333. extern NCURSES_EXPORT(int) set_form_win (FORM *,WINDOW *);
  334. extern NCURSES_EXPORT(int) set_form_sub (FORM *,WINDOW *);
  335. extern NCURSES_EXPORT(int) set_current_field (FORM *,FIELD *);
  336. extern NCURSES_EXPORT(int) field_index (const FIELD *);
  337. extern NCURSES_EXPORT(int) set_form_page (FORM *,int);
  338. extern NCURSES_EXPORT(int) form_page (const FORM *);
  339. extern NCURSES_EXPORT(int) scale_form (const FORM *,int *,int *);
  340. extern NCURSES_EXPORT(int) set_form_init (FORM *,Form_Hook);
  341. extern NCURSES_EXPORT(int) set_form_term (FORM *,Form_Hook);
  342. extern NCURSES_EXPORT(int) set_field_init (FORM *,Form_Hook);
  343. extern NCURSES_EXPORT(int) set_field_term (FORM *,Form_Hook);
  344. extern NCURSES_EXPORT(int) post_form (FORM *);
  345. extern NCURSES_EXPORT(int) unpost_form (FORM *);
  346. extern NCURSES_EXPORT(int) pos_form_cursor (FORM *);
  347. extern NCURSES_EXPORT(int) form_driver (FORM *,int);
  348. # if NCURSES_WIDECHAR
  349. extern NCURSES_EXPORT(int) form_driver_w (FORM *,int,wchar_t);
  350. # endif
  351. extern NCURSES_EXPORT(int) set_form_userptr (FORM *,void *);
  352. extern NCURSES_EXPORT(int) set_form_opts (FORM *,Form_Options);
  353. extern NCURSES_EXPORT(int) form_opts_on (FORM *,Form_Options);
  354. extern NCURSES_EXPORT(int) form_opts_off (FORM *,Form_Options);
  355. extern NCURSES_EXPORT(int) form_request_by_name (const char *);
  356. extern NCURSES_EXPORT(const char *) form_request_name (int);
  357. extern NCURSES_EXPORT(void *) form_userptr (const FORM *);
  358. extern NCURSES_EXPORT(Form_Options) form_opts (const FORM *);
  359. extern NCURSES_EXPORT(bool) data_ahead (const FORM *);
  360. extern NCURSES_EXPORT(bool) data_behind (const FORM *);
  361. #if NCURSES_SP_FUNCS
  362. extern NCURSES_EXPORT(FORM *) NCURSES_SP_NAME(new_form) (SCREEN*, FIELD **);
  363. #endif
  364. #ifdef __cplusplus
  365. }
  366. #endif
  367. /* *INDENT-ON*/
  368. #endif /* FORM_H */