Below is the full text to include/winX.h from NetHack 3.4.3. To link to a particular line, write [[winX.h#line123]], for example.
1. /* SCCS Id: @(#)winX.h 3.4 1996/08/18 */ 2. /* Copyright (c) Dean Luick, 1992 */ 3. /* NetHack may be freely redistributed. See license for details. */ 4.
The NetHack General Public License applies to screenshots, source code and other content from NetHack. |
5. /* 6. * Definitions for the X11 window-port. See doc/window.doc for details on 7. * the window interface. 8. */ 9. #ifndef WINX_H 10. #define WINX_H 11. 12. #ifndef E 13. #define E extern 14. #endif 15. 16. #if defined(BOS) || defined(NHSTDC) 17. #define DIMENSION_P int 18. #else 19. # ifdef WIDENED_PROTOTYPES 20. #define DIMENSION_P unsigned int 21. # else 22. #define DIMENSION_P Dimension 23. # endif 24. #endif 25. 26. /* 27. * Generic text buffer. 28. */ 29. #define START_SIZE 512 /* starting text buffer size */ 30. struct text_buffer { 31. char *text; 32. int text_size; 33. int text_last; 34. int num_lines; 35. }; 36. 37. 38. /* 39. * Information specific to a map window. 40. */ 41. struct text_map_info_t { 42. unsigned char text[ROWNO][COLNO]; /* Actual displayed screen. */ 43. #ifdef TEXTCOLOR 44. unsigned char colors[ROWNO][COLNO]; /* Color of each character. */ 45. GC color_gcs[CLR_MAX], /* GC for each color */ 46. inv_color_gcs[CLR_MAX]; /* GC for each inverse color */ 47. #define copy_gc color_gcs[NO_COLOR] 48. #define inv_copy_gc inv_color_gcs[NO_COLOR] 49. #else 50. GC copy_gc, /* Drawing GC */ 51. inv_copy_gc; /* Inverse drawing GC */ 52. #endif 53. }; 54. 55. struct tile_map_info_t { 56. unsigned short glyphs[ROWNO][COLNO]; /* Saved glyph numbers. */ 57. GC white_gc; 58. GC black_gc; 59. unsigned long image_width; /* dimensions of tile image */ 60. unsigned long image_height; 61. }; 62. 63. struct map_info_t { 64. Dimension viewport_width, /* Saved viewport size, so we can */ 65. viewport_height; /* clip to cursor on a resize. */ 66. unsigned char t_start[ROWNO], /* Starting column for new info. */ 67. t_stop[ROWNO]; /* Ending column for new info. */ 68. int square_width, /* Saved font/tile information so */ 69. square_height, /* we can calculate the correct */ 70. square_ascent, /* placement of changes. */ 71. square_lbearing; 72. boolean is_tile; 73. union { 74. struct text_map_info_t *text_map; 75. struct tile_map_info_t *tile_map; 76. } mtype; 77. }; 78. 79. 80. /* 81. * Information specific to a message window. 82. */ 83. struct line_element { 84. struct line_element *next; 85. char *line; /* char buffer */ 86. int buf_length; /* length of buffer */ 87. int str_length; /* length of string in buffer */ 88. }; 89. 90. struct mesg_info_t { 91. XFontStruct *fs; /* Font for the window. */ 92. int num_lines; /* line count */ 93. struct line_element *head; /* head of circular line queue */ 94. struct line_element *line_here;/* current drawn line position */ 95. struct line_element *last_pause;/* point to the line after the prev */ 96. /* bottom of screen */ 97. struct line_element *last_pause_head;/* pointer to head of previous */ 98. /* turn */ 99. GC gc; /* GC for text drawing */ 100. int char_width, /* Saved font information so we can */ 101. char_height, /* calculate the correct placement */ 102. char_ascent, /* of changes. */ 103. char_lbearing; 104. Dimension viewport_width, /* Saved viewport size, so we can adjust */ 105. viewport_height;/* the slider on a resize. */ 106. Boolean dirty; /* Lines have been added to the window. */ 107. }; 108. 109. /* 110. * Information specific to a "text" status window. 111. */ 112. struct status_info_t { 113. struct text_buffer text; /* Just a text buffer. */ 114. }; 115. 116. /* 117. * Information specific to a menu window. First a structure for each 118. * menu entry, then the structure for each menu window. 119. */ 120. typedef struct x11_mi { 121. struct x11_mi *next; 122. anything identifier; /* Opaque type to identify this selection */ 123. long pick_count; /* specific selection count; -1 if none */ 124. char *str; /* The text of the item. */ 125. int attr; /* Attribute for the line. */ 126. boolean selected; /* Been selected? */ 127. char selector; /* Char used to select this entry. */ 128. char gselector; /* Group selector. */ 129. } x11_menu_item; 130. 131. struct menu { 132. x11_menu_item *base; /* Starting pointer for item list. */ 133. x11_menu_item *last; /* End pointer for item list. */ 134. const char *query; /* Query string. */ 135. const char *gacc; /* Group accelerators. */ 136. int count; /* Number of strings. */ 137. String *list_pointer;/* String list. */ 138. Boolean *sensitive; /* Active list. */ 139. char curr_selector;/* Next keyboard accelerator to assign, */ 140. /* if 0, then we're out. */ 141. }; 142. 143. struct menu_info_t { 144. struct menu curr_menu; /* Menu being displayed. */ 145. struct menu new_menu; /* New menu being built. */ 146. 147. XFontStruct *fs; /* Font for the window. */ 148. long menu_count; /* number entered by user */ 149. Dimension line_height; /* Total height of a line of text. */ 150. Dimension internal_height; /* Internal height between widget & border */ 151. Dimension internal_width; /* Internal width between widget & border */ 152. short how; /* Menu mode PICK_NONE, PICK_ONE, PICK_ANY */ 153. boolean valid_widgets; /* TRUE if widgets have been created. */ 154. boolean is_menu; /* Has been confirmed to being a menu window. */ 155. boolean is_active; /* TRUE when waiting for user input. */ 156. boolean is_up; /* TRUE when window is popped-up. */ 157. boolean cancelled; /* Menu has been explicitly cancelled. */ 158. boolean counting; /* true when menu_count has a valid value */ 159. }; 160. 161. /* 162. * Information specific to a text window. 163. */ 164. struct text_info_t { 165. struct text_buffer text; 166. XFontStruct *fs; /* Font for the text window. */ 167. int max_width; /* Width of widest line so far. */ 168. int extra_width, /* Sum of left and right border widths. */ 169. extra_height; /* Sum of top and bottom border widths. */ 170. boolean blocked; /* */ 171. boolean destroy_on_ack; /* Destroy this window when acknowleged. */ 172. #ifdef GRAPHIC_TOMBSTONE 173. boolean is_rip; /* This window needs a tombstone. */ 174. #endif 175. }; 176. 177. 178. /* 179. * Basic window structure. 180. */ 181. struct xwindow { 182. int type; /* type of nethack window */ 183. Widget popup; /* direct parent of widget w or viewport */ 184. Widget w; /* the widget that does things */ 185. Dimension pixel_width; /* window size, in pixels */ 186. Dimension pixel_height; 187. int prevx, cursx; /* Cursor position, only used by */ 188. int prevy, cursy; /* map and "plain" status windows.*/ 189. 190. union { 191. struct map_info_t *Map_info; /* map window info */ 192. struct mesg_info_t *Mesg_info; /* message window info */ 193. struct status_info_t *Status_info; /* status window info */ 194. struct menu_info_t *Menu_info; /* menu window info */ 195. struct text_info_t *Text_info; /* menu window info */ 196. } Win_info; 197. boolean keep_window; 198. }; 199. 200. /* Defines to use for the window information union. */ 201. #define map_information Win_info.Map_info 202. #define mesg_information Win_info.Mesg_info 203. #define status_information Win_info.Status_info 204. #define menu_information Win_info.Menu_info 205. #define text_information Win_info.Text_info 206. 207. 208. #define MAX_WINDOWS 20 /* max number of open windows */ 209. 210. #define NHW_NONE 0 /* Unallocated window type. Must be */ 211. /* different from any other NHW_* type. */ 212. 213. #define NO_CLICK 0 /* No click occured on the map window. Must */ 214. /* be different than CLICK_1 and CLICK_2. */ 215. 216. #define DEFAULT_MESSAGE_WIDTH 60/* width in chars of the message window */ 217. 218. #define DISPLAY_FILE_SIZE 35 /* Max number of lines in the default */ 219. /* file display window. */ 220. 221. #define MAX_KEY_STRING 64 /* String size for converting a keypress */ 222. /* event into a character(s) */ 223. 224. #define DEFAULT_LINES_DISPLAYED 12 /* # of lines displayed message window */ 225. #define MAX_HISTORY 60 /* max history saved on message window */ 226. 227. 228. /* Window variables (winX.c). */ 229. E struct xwindow window_list[MAX_WINDOWS]; 230. E XtAppContext app_context; /* context of application */ 231. E Widget toplevel; /* toplevel widget */ 232. E Atom wm_delete_window; /* delete window protocol */ 233. E boolean exit_x_event; /* exit condition for event loop */ 234. #define EXIT_ON_KEY_PRESS 0 /* valid values for exit_x_event */ 235. #define EXIT_ON_KEY_OR_BUTTON_PRESS 1 236. #define EXIT_ON_EXIT 2 237. #define EXIT_ON_SENT_EVENT 3 238. E int click_x, click_y, click_button, updated_inventory; 239. 240. typedef struct { 241. Boolean slow; 242. Boolean autofocus; 243. Boolean message_line; 244. Boolean double_tile_size; /* double tile size */ 245. String tile_file; /* name of file to open for tiles */ 246. String icon; /* name of desired icon */ 247. int message_lines; /* number of lines to attempt to show */ 248. String pet_mark_bitmap; /* X11 bitmap file used to mark pets */ 249. Pixel pet_mark_color; /* color of pet mark */ 250. #ifdef GRAPHIC_TOMBSTONE 251. String tombstone; /* name of XPM file for tombstone */ 252. int tombtext_x; /* x-coord of center of first tombstone text */ 253. int tombtext_y; /* y-coord of center of first tombstone text */ 254. int tombtext_dx; /* x-displacement between tombstone line */ 255. int tombtext_dy; /* y-displacement between tombstone line */ 256. #endif 257. } AppResources; 258. 259. E AppResources appResources; 260. E void (*input_func)(); 261. 262. extern struct window_procs X11_procs; 263. 264. /* Check for an invalid window id. */ 265. #define check_winid(window) \ 266. if ((window) < 0 || (window) >= MAX_WINDOWS) { \ 267. panic("illegal windid [%d] in %s at line %d", \ 268. window, __FILE__, __LINE__); \ 269. } 270. 271. 272. /* ### dialogs.c ### */ 273. E Widget FDECL(CreateDialog, (Widget, String, XtCallbackProc, XtCallbackProc)); 274. E void FDECL(SetDialogPrompt,(Widget, String)); 275. E String FDECL(GetDialogResponse,(Widget)); 276. E void FDECL(SetDialogResponse,(Widget, String)); 277. E void FDECL(positionpopup,(Widget,BOOLEAN_P)); 278. 279. /* ### winX.c ### */ 280. E struct xwindow *FDECL(find_widget,(Widget)); 281. E Boolean FDECL(nhApproxColor,(Screen*, Colormap, char*, XColor*)); 282. E Dimension FDECL(nhFontHeight,(Widget)); 283. E char FDECL(key_event_to_char,(XKeyEvent*)); 284. E void FDECL(msgkey, (Widget, XtPointer, XEvent*)); 285. E void FDECL(nh_XtPopup, (Widget, int, Widget)); 286. E void FDECL(nh_XtPopdown, (Widget)); 287. E void NDECL(win_X11_init); 288. E void FDECL(nh_keyscroll, (Widget, XEvent*, String*, Cardinal*)); 289. 290. /* ### winmesg.c ### */ 291. E void FDECL(set_message_slider, (struct xwindow*)); 292. E void FDECL(create_message_window,(struct xwindow*, BOOLEAN_P, Widget)); 293. E void FDECL(destroy_message_window,(struct xwindow*)); 294. E void FDECL(display_message_window, (struct xwindow*)); 295. E void FDECL(append_message,(struct xwindow*, const char*)); 296. E void FDECL(set_last_pause, (struct xwindow*)); 297. 298. /* ### winmap.c ### */ 299. E void NDECL(post_process_tiles); 300. E void FDECL(check_cursor_visibility,(struct xwindow*)); 301. E void FDECL(display_map_window,(struct xwindow*)); 302. E void FDECL(clear_map_window,(struct xwindow*)); 303. E void FDECL(map_input, (Widget, XEvent*, String*, Cardinal*)); 304. E void FDECL(set_map_size,(struct xwindow*, DIMENSION_P, DIMENSION_P)); 305. E void FDECL(create_map_window,(struct xwindow*, BOOLEAN_P, Widget)); 306. E void FDECL(destroy_map_window,(struct xwindow*)); 307. E int FDECL(x_event,(int)); 308. 309. /* ### winmenu.c ### */ 310. E void FDECL(menu_delete, (Widget, XEvent*, String*, Cardinal*)); 311. E void FDECL(menu_key,(Widget, XEvent*, String*, Cardinal*)); 312. E void FDECL(create_menu_window,(struct xwindow*)); 313. E void FDECL(destroy_menu_window,(struct xwindow*)); 314. 315. /* ### winmisc.c ### */ 316. E void FDECL(ps_key,(Widget, XEvent*, String*, Cardinal*)); /* player selection action */ 317. E void FDECL(race_key,(Widget, XEvent*, String*, Cardinal*)); /* race selection action */ 318. E void FDECL(gend_key, (Widget,XEvent *,String *,Cardinal *)); /* gender */ 319. E void FDECL(algn_key, (Widget,XEvent *,String *,Cardinal *)); /* alignment */ 320. E void FDECL(ec_delete, (Widget, XEvent*, String*, Cardinal*)); 321. E void FDECL(ec_key,(Widget, XEvent*, String*, Cardinal*)); /* extended command action */ 322. 323. /* ### winstatus.c ### */ 324. E void FDECL(create_status_window,(struct xwindow*, BOOLEAN_P, Widget)); 325. E void FDECL(destroy_status_window,(struct xwindow*)); 326. E void FDECL(adjust_status,(struct xwindow*, const char*)); 327. E void NDECL(null_out_status); 328. E void NDECL(check_turn_events); 329. 330. /* ### wintext.c ### */ 331. E void FDECL(delete_text, (Widget, XEvent*, String*, Cardinal*)); 332. E void FDECL(dismiss_text,(Widget, XEvent*, String*, Cardinal*)); 333. E void FDECL(key_dismiss_text,(Widget, XEvent*, String*, Cardinal*)); 334. #ifdef GRAPHIC_TOMBSTONE 335. E void FDECL(rip_dismiss_text,(Widget, XEvent*, String*, Cardinal*)); 336. #endif 337. E void FDECL(add_to_text_window,(struct xwindow*, int, const char*)); 338. E void FDECL(display_text_window,(struct xwindow*, BOOLEAN_P)); 339. E void FDECL(create_text_window,(struct xwindow*)); 340. E void FDECL(destroy_text_window,(struct xwindow*)); 341. E void FDECL(clear_text_window,(struct xwindow*)); 342. E void FDECL(append_text_buffer,(struct text_buffer*, const char*, BOOLEAN_P)); /* text buffer routines */ 343. E void FDECL(init_text_buffer,(struct text_buffer*)); 344. E void FDECL(clear_text_buffer,(struct text_buffer*)); 345. E void FDECL(free_text_buffer,(struct text_buffer*)); 346. #ifdef GRAPHIC_TOMBSTONE 347. E void FDECL(calculate_rip_text, (int)); 348. #endif 349. 350. 351. /* ### winval.c ### */ 352. E Widget FDECL(create_value,(Widget, const char*)); 353. E void FDECL(set_name,(Widget, char*)); 354. E void FDECL(set_name_width,(Widget, int)); 355. E int FDECL(get_name_width,(Widget)); 356. E void FDECL(set_value,(Widget, const char*)); 357. E void FDECL(set_value_width,(Widget, int)); 358. E int FDECL(get_value_width,(Widget)); 359. E void FDECL(hilight_value,(Widget)); 360. E void FDECL(swap_fg_bg,(Widget)); 361. 362. /* external declarations */ 363. E void FDECL(X11_init_nhwindows, (int *, char **)); 364. E void NDECL(X11_player_selection); 365. E void NDECL(X11_askname); 366. E void NDECL(X11_get_nh_event) ; 367. E void FDECL(X11_exit_nhwindows, (const char *)); 368. E void FDECL(X11_suspend_nhwindows, (const char *)); 369. E void NDECL(X11_resume_nhwindows); 370. E winid FDECL(X11_create_nhwindow, (int)); 371. E void FDECL(X11_clear_nhwindow, (winid)); 372. E void FDECL(X11_display_nhwindow, (winid, BOOLEAN_P)); 373. E void FDECL(X11_destroy_nhwindow, (winid)); 374. E void FDECL(X11_curs, (winid,int,int)); 375. E void FDECL(X11_putstr, (winid, int, const char *)); 376. E void FDECL(X11_display_file, (const char *, BOOLEAN_P)); 377. E void FDECL(X11_start_menu, (winid)); 378. E void FDECL(X11_add_menu, (winid,int,const ANY_P *, 379. CHAR_P, CHAR_P, int, const char *, BOOLEAN_P)); 380. E void FDECL(X11_end_menu, (winid, const char *)); 381. E int FDECL(X11_select_menu, (winid, int, MENU_ITEM_P **)); 382. E void NDECL(X11_update_inventory); 383. E void NDECL(X11_mark_synch); 384. E void NDECL(X11_wait_synch); 385. #ifdef CLIPPING 386. E void FDECL(X11_cliparound, (int, int)); 387. #endif 388. E void FDECL(X11_print_glyph, (winid,XCHAR_P,XCHAR_P,int)); 389. E void FDECL(X11_raw_print, (const char *)); 390. E void FDECL(X11_raw_print_bold, (const char *)); 391. E int NDECL(X11_nhgetch); 392. E int FDECL(X11_nh_poskey, (int *, int *, int *)); 393. E void NDECL(X11_nhbell); 394. E int NDECL(X11_doprev_message); 395. E char FDECL(X11_yn_function, (const char *, const char *, CHAR_P)); 396. E void FDECL(X11_getlin, (const char *,char *)); 397. E int NDECL(X11_get_ext_cmd); 398. E void FDECL(X11_number_pad, (int)); 399. E void NDECL(X11_delay_output); 400. 401. /* other defs that really should go away (they're tty specific) */ 402. E void NDECL(X11_start_screen); 403. E void NDECL(X11_end_screen); 404. 405. #ifdef GRAPHIC_TOMBSTONE 406. E void FDECL(X11_outrip, (winid,int)); 407. #else 408. E void FDECL(genl_outrip, (winid,int)); 409. #endif 410. 411. #endif /* WINX_H */