dialog.h 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /*
  2. * dialog.h -- common declarations for all dialog modules
  3. *
  4. * AUTHOR: Savio Lam (lam836@cs.cuhk.hk)
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public License
  8. * as published by the Free Software Foundation; either version 2
  9. * of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write to the Free Software
  18. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  19. */
  20. #include <sys/types.h>
  21. #include <fcntl.h>
  22. #include <unistd.h>
  23. #include <ctype.h>
  24. #include <stdlib.h>
  25. #include <string.h>
  26. #include <stdbool.h>
  27. #ifdef __sun__
  28. #define CURS_MACROS
  29. #endif
  30. #include CURSES_LOC
  31. /*
  32. * Colors in ncurses 1.9.9e do not work properly since foreground and
  33. * background colors are OR'd rather than separately masked. This version
  34. * of dialog was hacked to work with ncurses 1.9.9e, making it incompatible
  35. * with standard curses. The simplest fix (to make this work with standard
  36. * curses) uses the wbkgdset() function, not used in the original hack.
  37. * Turn it off if we're building with 1.9.9e, since it just confuses things.
  38. */
  39. #if defined(NCURSES_VERSION) && defined(_NEED_WRAP) && !defined(GCC_PRINTFLIKE)
  40. #define OLD_NCURSES 1
  41. #undef wbkgdset
  42. #define wbkgdset(w,p) /*nothing */
  43. #else
  44. #define OLD_NCURSES 0
  45. #endif
  46. #define TR(params) _tracef params
  47. #define KEY_ESC 27
  48. #define TAB 9
  49. #define MAX_LEN 2048
  50. #define BUF_SIZE (10*1024)
  51. #define MIN(x,y) (x < y ? x : y)
  52. #define MAX(x,y) (x > y ? x : y)
  53. #ifndef ACS_ULCORNER
  54. #define ACS_ULCORNER '+'
  55. #endif
  56. #ifndef ACS_LLCORNER
  57. #define ACS_LLCORNER '+'
  58. #endif
  59. #ifndef ACS_URCORNER
  60. #define ACS_URCORNER '+'
  61. #endif
  62. #ifndef ACS_LRCORNER
  63. #define ACS_LRCORNER '+'
  64. #endif
  65. #ifndef ACS_HLINE
  66. #define ACS_HLINE '-'
  67. #endif
  68. #ifndef ACS_VLINE
  69. #define ACS_VLINE '|'
  70. #endif
  71. #ifndef ACS_LTEE
  72. #define ACS_LTEE '+'
  73. #endif
  74. #ifndef ACS_RTEE
  75. #define ACS_RTEE '+'
  76. #endif
  77. #ifndef ACS_UARROW
  78. #define ACS_UARROW '^'
  79. #endif
  80. #ifndef ACS_DARROW
  81. #define ACS_DARROW 'v'
  82. #endif
  83. /* error return codes */
  84. #define ERRDISPLAYTOOSMALL (KEY_MAX + 1)
  85. /*
  86. * Color definitions
  87. */
  88. struct dialog_color {
  89. chtype atr; /* Color attribute */
  90. int fg; /* foreground */
  91. int bg; /* background */
  92. int hl; /* highlight this item */
  93. };
  94. struct dialog_info {
  95. const char *backtitle;
  96. struct dialog_color screen;
  97. struct dialog_color shadow;
  98. struct dialog_color dialog;
  99. struct dialog_color title;
  100. struct dialog_color border;
  101. struct dialog_color button_active;
  102. struct dialog_color button_inactive;
  103. struct dialog_color button_key_active;
  104. struct dialog_color button_key_inactive;
  105. struct dialog_color button_label_active;
  106. struct dialog_color button_label_inactive;
  107. struct dialog_color inputbox;
  108. struct dialog_color inputbox_border;
  109. struct dialog_color searchbox;
  110. struct dialog_color searchbox_title;
  111. struct dialog_color searchbox_border;
  112. struct dialog_color position_indicator;
  113. struct dialog_color menubox;
  114. struct dialog_color menubox_border;
  115. struct dialog_color item;
  116. struct dialog_color item_selected;
  117. struct dialog_color tag;
  118. struct dialog_color tag_selected;
  119. struct dialog_color tag_key;
  120. struct dialog_color tag_key_selected;
  121. struct dialog_color check;
  122. struct dialog_color check_selected;
  123. struct dialog_color uarrow;
  124. struct dialog_color darrow;
  125. };
  126. /*
  127. * Global variables
  128. */
  129. extern struct dialog_info dlg;
  130. extern char dialog_input_result[];
  131. /*
  132. * Function prototypes
  133. */
  134. /* item list as used by checklist and menubox */
  135. void item_reset(void);
  136. void item_make(const char *fmt, ...);
  137. void item_add_str(const char *fmt, ...);
  138. void item_set_tag(char tag);
  139. void item_set_data(void *p);
  140. void item_set_selected(int val);
  141. int item_activate_selected(void);
  142. void *item_data(void);
  143. char item_tag(void);
  144. /* item list manipulation for lxdialog use */
  145. #define MAXITEMSTR 200
  146. struct dialog_item {
  147. char str[MAXITEMSTR]; /* promtp displayed */
  148. char tag;
  149. void *data; /* pointer to menu item - used by menubox+checklist */
  150. int selected; /* Set to 1 by dialog_*() function if selected. */
  151. };
  152. /* list of lialog_items */
  153. struct dialog_list {
  154. struct dialog_item node;
  155. struct dialog_list *next;
  156. };
  157. extern struct dialog_list *item_cur;
  158. extern struct dialog_list item_nil;
  159. extern struct dialog_list *item_head;
  160. int item_count(void);
  161. void item_set(int n);
  162. int item_n(void);
  163. const char *item_str(void);
  164. int item_is_selected(void);
  165. int item_is_tag(char tag);
  166. #define item_foreach() \
  167. for (item_cur = item_head ? item_head: item_cur; \
  168. item_cur && (item_cur != &item_nil); item_cur = item_cur->next)
  169. /* generic key handlers */
  170. int on_key_esc(WINDOW *win);
  171. int on_key_resize(void);
  172. void init_dialog(const char *backtitle);
  173. void reset_dialog(void);
  174. void end_dialog(void);
  175. void attr_clear(WINDOW * win, int height, int width, chtype attr);
  176. void dialog_clear(void);
  177. void print_autowrap(WINDOW * win, const char *prompt, int width, int y, int x);
  178. void print_button(WINDOW * win, const char *label, int y, int x, int selected);
  179. void print_title(WINDOW *dialog, const char *title, int width);
  180. void draw_box(WINDOW * win, int y, int x, int height, int width, chtype box,
  181. chtype border);
  182. void draw_shadow(WINDOW * win, int y, int x, int height, int width);
  183. int first_alpha(const char *string, const char *exempt);
  184. int dialog_yesno(const char *title, const char *prompt, int height, int width);
  185. int dialog_msgbox(const char *title, const char *prompt, int height,
  186. int width, int pause);
  187. int dialog_textbox(const char *title, const char *file, int height, int width);
  188. int dialog_menu(const char *title, const char *prompt,
  189. const void *selected, int *s_scroll);
  190. int dialog_checklist(const char *title, const char *prompt, int height,
  191. int width, int list_height);
  192. extern char dialog_input_result[];
  193. int dialog_inputbox(const char *title, const char *prompt, int height,
  194. int width, const char *init);
  195. /*
  196. * This is the base for fictitious keys, which activate
  197. * the buttons.
  198. *
  199. * Mouse-generated keys are the following:
  200. * -- the first 32 are used as numbers, in addition to '0'-'9'
  201. * -- the lowercase are used to signal mouse-enter events (M_EVENT + 'o')
  202. * -- uppercase chars are used to invoke the button (M_EVENT + 'O')
  203. */
  204. #define M_EVENT (KEY_MAX+1)