dialog.h 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  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. #ifndef KBUILD_NO_NLS
  28. # include <libintl.h>
  29. #else
  30. # define gettext(Msgid) ((const char *) (Msgid))
  31. #endif
  32. #ifdef __sun__
  33. #define CURS_MACROS
  34. #endif
  35. #include CURSES_LOC
  36. /*
  37. * Colors in ncurses 1.9.9e do not work properly since foreground and
  38. * background colors are OR'd rather than separately masked. This version
  39. * of dialog was hacked to work with ncurses 1.9.9e, making it incompatible
  40. * with standard curses. The simplest fix (to make this work with standard
  41. * curses) uses the wbkgdset() function, not used in the original hack.
  42. * Turn it off if we're building with 1.9.9e, since it just confuses things.
  43. */
  44. #if defined(NCURSES_VERSION) && defined(_NEED_WRAP) && !defined(GCC_PRINTFLIKE)
  45. #define OLD_NCURSES 1
  46. #undef wbkgdset
  47. #define wbkgdset(w,p) /*nothing */
  48. #else
  49. #define OLD_NCURSES 0
  50. #endif
  51. #define TR(params) _tracef params
  52. #define KEY_ESC 27
  53. #define TAB 9
  54. #define MAX_LEN 2048
  55. #define BUF_SIZE (10*1024)
  56. #define MIN(x,y) (x < y ? x : y)
  57. #define MAX(x,y) (x > y ? x : y)
  58. #ifndef ACS_ULCORNER
  59. #define ACS_ULCORNER '+'
  60. #endif
  61. #ifndef ACS_LLCORNER
  62. #define ACS_LLCORNER '+'
  63. #endif
  64. #ifndef ACS_URCORNER
  65. #define ACS_URCORNER '+'
  66. #endif
  67. #ifndef ACS_LRCORNER
  68. #define ACS_LRCORNER '+'
  69. #endif
  70. #ifndef ACS_HLINE
  71. #define ACS_HLINE '-'
  72. #endif
  73. #ifndef ACS_VLINE
  74. #define ACS_VLINE '|'
  75. #endif
  76. #ifndef ACS_LTEE
  77. #define ACS_LTEE '+'
  78. #endif
  79. #ifndef ACS_RTEE
  80. #define ACS_RTEE '+'
  81. #endif
  82. #ifndef ACS_UARROW
  83. #define ACS_UARROW '^'
  84. #endif
  85. #ifndef ACS_DARROW
  86. #define ACS_DARROW 'v'
  87. #endif
  88. /* error return codes */
  89. #define ERRDISPLAYTOOSMALL (KEY_MAX + 1)
  90. /*
  91. * Color definitions
  92. */
  93. struct dialog_color {
  94. chtype atr; /* Color attribute */
  95. int fg; /* foreground */
  96. int bg; /* background */
  97. int hl; /* highlight this item */
  98. };
  99. struct dialog_info {
  100. const char *backtitle;
  101. struct dialog_color screen;
  102. struct dialog_color shadow;
  103. struct dialog_color dialog;
  104. struct dialog_color title;
  105. struct dialog_color border;
  106. struct dialog_color button_active;
  107. struct dialog_color button_inactive;
  108. struct dialog_color button_key_active;
  109. struct dialog_color button_key_inactive;
  110. struct dialog_color button_label_active;
  111. struct dialog_color button_label_inactive;
  112. struct dialog_color inputbox;
  113. struct dialog_color inputbox_border;
  114. struct dialog_color searchbox;
  115. struct dialog_color searchbox_title;
  116. struct dialog_color searchbox_border;
  117. struct dialog_color position_indicator;
  118. struct dialog_color menubox;
  119. struct dialog_color menubox_border;
  120. struct dialog_color item;
  121. struct dialog_color item_selected;
  122. struct dialog_color tag;
  123. struct dialog_color tag_selected;
  124. struct dialog_color tag_key;
  125. struct dialog_color tag_key_selected;
  126. struct dialog_color check;
  127. struct dialog_color check_selected;
  128. struct dialog_color uarrow;
  129. struct dialog_color darrow;
  130. };
  131. /*
  132. * Global variables
  133. */
  134. extern struct dialog_info dlg;
  135. extern char dialog_input_result[];
  136. /*
  137. * Function prototypes
  138. */
  139. /* item list as used by checklist and menubox */
  140. void item_reset(void);
  141. void item_make(const char *fmt, ...);
  142. void item_add_str(const char *fmt, ...);
  143. void item_set_tag(char tag);
  144. void item_set_data(void *p);
  145. void item_set_selected(int val);
  146. int item_activate_selected(void);
  147. void *item_data(void);
  148. char item_tag(void);
  149. /* item list manipulation for lxdialog use */
  150. #define MAXITEMSTR 200
  151. struct dialog_item {
  152. char str[MAXITEMSTR]; /* promtp displayed */
  153. char tag;
  154. void *data; /* pointer to menu item - used by menubox+checklist */
  155. int selected; /* Set to 1 by dialog_*() function if selected. */
  156. };
  157. /* list of lialog_items */
  158. struct dialog_list {
  159. struct dialog_item node;
  160. struct dialog_list *next;
  161. };
  162. extern struct dialog_list *item_cur;
  163. extern struct dialog_list item_nil;
  164. extern struct dialog_list *item_head;
  165. int item_count(void);
  166. void item_set(int n);
  167. int item_n(void);
  168. const char *item_str(void);
  169. int item_is_selected(void);
  170. int item_is_tag(char tag);
  171. #define item_foreach() \
  172. for (item_cur = item_head ? item_head: item_cur; \
  173. item_cur && (item_cur != &item_nil); item_cur = item_cur->next)
  174. /* generic key handlers */
  175. int on_key_esc(WINDOW *win);
  176. int on_key_resize(void);
  177. int init_dialog(const char *backtitle);
  178. void set_dialog_backtitle(const char *backtitle);
  179. void end_dialog(int x, int y);
  180. void attr_clear(WINDOW * win, int height, int width, chtype attr);
  181. void dialog_clear(void);
  182. void print_autowrap(WINDOW * win, const char *prompt, int width, int y, int x);
  183. void print_button(WINDOW * win, const char *label, int y, int x, int selected);
  184. void print_title(WINDOW *dialog, const char *title, int width);
  185. void draw_box(WINDOW * win, int y, int x, int height, int width, chtype box,
  186. chtype border);
  187. void draw_shadow(WINDOW * win, int y, int x, int height, int width);
  188. int first_alpha(const char *string, const char *exempt);
  189. int dialog_yesno(const char *title, const char *prompt, int height, int width);
  190. int dialog_msgbox(const char *title, const char *prompt, int height,
  191. int width, int pause);
  192. int dialog_textbox(const char *title, const char *file, int height, int width);
  193. int dialog_menu(const char *title, const char *prompt,
  194. const void *selected, int *s_scroll);
  195. int dialog_checklist(const char *title, const char *prompt, int height,
  196. int width, int list_height);
  197. extern char dialog_input_result[];
  198. int dialog_inputbox(const char *title, const char *prompt, int height,
  199. int width, const char *init);
  200. /*
  201. * This is the base for fictitious keys, which activate
  202. * the buttons.
  203. *
  204. * Mouse-generated keys are the following:
  205. * -- the first 32 are used as numbers, in addition to '0'-'9'
  206. * -- the lowercase are used to signal mouse-enter events (M_EVENT + 'o')
  207. * -- uppercase chars are used to invoke the button (M_EVENT + 'O')
  208. */
  209. #define M_EVENT (KEY_MAX+1)