1 /* Define X specific console, device, and frame object for XEmacs.
2 Copyright (C) 1989, 1992, 1993, 1994, 1995 Free Software Foundation, Inc.
3 Copyright (C) 1994, 1995 Board of Trustees, University of Illinois.
5 This file is part of XEmacs.
7 XEmacs is free software; you can redistribute it and/or modify it
8 under the terms of the GNU General Public License as published by the
9 Free Software Foundation; either version 2, or (at your option) any
12 XEmacs is distributed in the hope that it will be useful, but WITHOUT
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 You should have received a copy of the GNU General Public License
18 along with XEmacs; see the file COPYING. If not, write to
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA. */
22 /* Synched up with: Not in FSF. */
27 Ultimately based on FSF, then later on JWZ work for Lemacs.
28 Rewritten over time by Ben Wing and Chuck Thompson (original
29 multi-device work by Chuck Thompson).
32 #ifndef INCLUDED_console_x_h_
33 #define INCLUDED_console_x_h_
38 #include "xintrinsic.h"
40 #include <X11/cursorfont.h>
41 #include <X11/keysym.h>
42 #include <X11/Xatom.h>
44 #if 0 /* mrb - Xos sux. */
46 #undef USG /* ####KLUDGE for Solaris 2.2 and up */
54 #include <X11/StringDefs.h>
60 /* R5 defines the XPointer type, but R4 doesn't.
61 R4 also doesn't define a version number, but R5 does. */
62 #if (XlibSpecificationRelease < 5)
63 # define XPointer char *
66 DECLARE_CONSOLE_TYPE (x);
70 /* The X connection of this device. */
73 /* Set by x_IO_error_handler(). */
76 /* Xt application info. */
79 /* Cache of GC's for frame's on this device. */
80 struct gc_cache *gc_cache;
82 /* Selected visual, depth and colormap for this device */
87 /* Used by x_bevel_modeline in redisplay-x.c */
90 /* Atoms associated with this device. */
91 /* allocated in Xatoms_of_device_x */
92 Atom Xatom_WM_PROTOCOLS;
93 Atom Xatom_WM_DELETE_WINDOW;
94 Atom Xatom_WM_SAVE_YOURSELF;
95 Atom Xatom_WM_TAKE_FOCUS;
98 /* allocated in Xatoms_of_select_x */
100 Atom Xatom_TIMESTAMP;
105 Atom Xatom_EMACS_TMP;
108 Atom Xatom_ATOM_PAIR;
109 Atom Xatom_COMPOUND_TEXT;
111 /* allocated in Xatoms_of_objects_x */
113 Atom Xatom_FAMILY_NAME;
114 Atom Xatom_WEIGHT_NAME;
116 Atom Xatom_SETWIDTH_NAME;
117 Atom Xatom_ADD_STYLE_NAME;
118 Atom Xatom_PIXEL_SIZE;
119 Atom Xatom_POINT_SIZE;
120 Atom Xatom_RESOLUTION_X;
121 Atom Xatom_RESOLUTION_Y;
123 Atom Xatom_AVERAGE_WIDTH;
124 Atom Xatom_CHARSET_REGISTRY;
125 Atom Xatom_CHARSET_ENCODING;
127 /* The following items are all used exclusively in event-Xt.c. */
128 int MetaMask, HyperMask, SuperMask, AltMask, ModeMask;
129 KeySym lock_interpretation;
131 XModifierKeymap *x_modifier_keymap;
133 KeySym *x_keysym_map;
134 int x_keysym_map_min_code;
135 int x_keysym_map_max_code;
136 int x_keysym_map_keysyms_per_code;
137 Lisp_Object x_keysym_map_hash_table;
139 /* frame that holds the WM_COMMAND property; there should be exactly
140 one of these per device. */
141 Lisp_Object WM_COMMAND_frame;
143 /* #### It's not clear that there is much distinction anymore
144 between mouse_timestamp and global_mouse_timestamp, now that
145 Emacs doesn't see most (all?) events not destined for it. */
147 /* The timestamp of the last button or key event used by emacs itself.
148 This is used for asserting selections and input focus. */
149 Time mouse_timestamp;
151 /* This is the timestamp the last button or key event whether it was
152 dispatched to emacs or widgets. */
153 Time global_mouse_timestamp;
155 /* This is the last known timestamp received from the server. It is
156 maintained by x_event_to_emacs_event and used to patch bogus
157 WM_TAKE_FOCUS messages sent by Mwm. */
158 Time last_server_timestamp;
160 /* Used by Xlib to preserve information across calls to
161 XLookupString(), to implement compose processing.
163 According to The X Window System, p. 467, "The creation of
164 XComposeStatus structures is implementation dependent;
165 a portable program must pass NULL for this argument."
166 But this means that a portable program cannot implement
167 compose processing! WTF?
169 So we just set it to all zeros. */
171 /* No X Server ever used this, AFAIK -- mrb */
172 /* XComposeStatus x_compose_status; */
176 XIMStyles *xim_styles;
177 #endif /* HAVE_XIM */
179 /* stuff for sticky modifiers: */
181 unsigned int need_to_add_mask, down_mask;
182 KeyCode last_downkey;
184 Time modifier_release_time;
187 #define DEVICE_X_DATA(d) DEVICE_TYPE_DATA (d, x)
189 #define FRAME_X_DISPLAY(f) (DEVICE_X_DISPLAY (XDEVICE (f->device)))
190 #define DEVICE_X_DISPLAY(d) (DEVICE_X_DATA (d)->display)
191 #define DEVICE_X_BEING_DELETED(d) (DEVICE_X_DATA (d)->being_deleted)
192 #define DEVICE_X_VISUAL(d) (DEVICE_X_DATA (d)->visual)
193 #define DEVICE_X_DEPTH(d) (DEVICE_X_DATA (d)->depth)
194 #define DEVICE_X_COLORMAP(d) (DEVICE_X_DATA (d)->device_cmap)
195 #define DEVICE_XT_APP_SHELL(d) (DEVICE_X_DATA (d)->Xt_app_shell)
196 #define DEVICE_X_GC_CACHE(d) (DEVICE_X_DATA (d)->gc_cache)
197 #define DEVICE_X_GRAY_PIXMAP(d) (DEVICE_X_DATA (d)->gray_pixmap)
198 #define DEVICE_X_WM_COMMAND_FRAME(d) (DEVICE_X_DATA (d)->WM_COMMAND_frame)
199 #define DEVICE_X_MOUSE_TIMESTAMP(d) (DEVICE_X_DATA (d)->mouse_timestamp)
200 #define DEVICE_X_GLOBAL_MOUSE_TIMESTAMP(d) (DEVICE_X_DATA (d)->global_mouse_timestamp)
201 #define DEVICE_X_LAST_SERVER_TIMESTAMP(d) (DEVICE_X_DATA (d)->last_server_timestamp)
202 #define DEVICE_X_KEYSYM_MAP_HASH_TABLE(d) (DEVICE_X_DATA (d)->x_keysym_map_hash_table)
203 /* #define DEVICE_X_X_COMPOSE_STATUS(d) (DEVICE_X_DATA (d)->x_compose_status) */
205 #define DEVICE_X_XIM(d) (DEVICE_X_DATA (d)->xim)
206 #define DEVICE_X_XIM_STYLES(d) (DEVICE_X_DATA (d)->xim_styles)
207 #define DEVICE_X_FONTSET(d) (DEVICE_X_DATA (d)->fontset)
208 #endif /* HAVE_XIM */
210 /* allocated in Xatoms_of_device_x */
211 #define DEVICE_XATOM_WM_PROTOCOLS(d) (DEVICE_X_DATA (d)->Xatom_WM_PROTOCOLS)
212 #define DEVICE_XATOM_WM_DELETE_WINDOW(d) (DEVICE_X_DATA (d)->Xatom_WM_DELETE_WINDOW)
213 #define DEVICE_XATOM_WM_SAVE_YOURSELF(d) (DEVICE_X_DATA (d)->Xatom_WM_SAVE_YOURSELF)
214 #define DEVICE_XATOM_WM_TAKE_FOCUS(d) (DEVICE_X_DATA (d)->Xatom_WM_TAKE_FOCUS)
215 #define DEVICE_XATOM_WM_STATE(d) (DEVICE_X_DATA (d)->Xatom_WM_STATE)
217 /* allocated in Xatoms_of_select_x */
218 #define DEVICE_XATOM_CLIPBOARD(d) (DEVICE_X_DATA (d)->Xatom_CLIPBOARD)
219 #define DEVICE_XATOM_TIMESTAMP(d) (DEVICE_X_DATA (d)->Xatom_TIMESTAMP)
220 #define DEVICE_XATOM_TEXT(d) (DEVICE_X_DATA (d)->Xatom_TEXT)
221 #define DEVICE_XATOM_DELETE(d) (DEVICE_X_DATA (d)->Xatom_DELETE)
222 #define DEVICE_XATOM_MULTIPLE(d) (DEVICE_X_DATA (d)->Xatom_MULTIPLE)
223 #define DEVICE_XATOM_INCR(d) (DEVICE_X_DATA (d)->Xatom_INCR)
224 #define DEVICE_XATOM_EMACS_TMP(d) (DEVICE_X_DATA (d)->Xatom_EMACS_TMP)
225 #define DEVICE_XATOM_TARGETS(d) (DEVICE_X_DATA (d)->Xatom_TARGETS)
226 #define DEVICE_XATOM_NULL(d) (DEVICE_X_DATA (d)->Xatom_NULL)
227 #define DEVICE_XATOM_ATOM_PAIR(d) (DEVICE_X_DATA (d)->Xatom_ATOM_PAIR)
228 #define DEVICE_XATOM_COMPOUND_TEXT(d) (DEVICE_X_DATA (d)->Xatom_COMPOUND_TEXT)
230 /* allocated in Xatoms_of_objects_x */
231 #define DEVICE_XATOM_FOUNDRY(d) (DEVICE_X_DATA (d)->Xatom_FOUNDRY)
232 #define DEVICE_XATOM_FAMILY_NAME(d) (DEVICE_X_DATA (d)->Xatom_FAMILY_NAME)
233 #define DEVICE_XATOM_WEIGHT_NAME(d) (DEVICE_X_DATA (d)->Xatom_WEIGHT_NAME)
234 #define DEVICE_XATOM_SLANT(d) (DEVICE_X_DATA (d)->Xatom_SLANT)
235 #define DEVICE_XATOM_SETWIDTH_NAME(d) (DEVICE_X_DATA (d)->Xatom_SETWIDTH_NAME)
236 #define DEVICE_XATOM_ADD_STYLE_NAME(d) (DEVICE_X_DATA (d)->Xatom_ADD_STYLE_NAME)
237 #define DEVICE_XATOM_PIXEL_SIZE(d) (DEVICE_X_DATA (d)->Xatom_PIXEL_SIZE)
238 #define DEVICE_XATOM_POINT_SIZE(d) (DEVICE_X_DATA (d)->Xatom_POINT_SIZE)
239 #define DEVICE_XATOM_RESOLUTION_X(d) (DEVICE_X_DATA (d)->Xatom_RESOLUTION_X)
240 #define DEVICE_XATOM_RESOLUTION_Y(d) (DEVICE_X_DATA (d)->Xatom_RESOLUTION_Y)
241 #define DEVICE_XATOM_SPACING(d) (DEVICE_X_DATA (d)->Xatom_SPACING)
242 #define DEVICE_XATOM_AVERAGE_WIDTH(d) (DEVICE_X_DATA (d)->Xatom_AVERAGE_WIDTH)
243 #define DEVICE_XATOM_CHARSET_REGISTRY(d) (DEVICE_X_DATA (d)->Xatom_CHARSET_REGISTRY)
244 #define DEVICE_XATOM_CHARSET_ENCODING(d) (DEVICE_X_DATA (d)->Xatom_CHARSET_ENCODING)
246 #define Xt_SET_VALUE(widget, resource, value) do { \
248 XtSetArg (al, resource, value); \
249 XtSetValues (widget, &al, 1); \
252 #define Xt_GET_VALUE(widget, resource, location) do { \
254 XtSetArg (al, resource, location); \
255 XtGetValues (widget, &al, 1); \
258 /* The maximum number of widgets that can be displayed above the text
259 area at one time. Currently no more than 3 will ever actually be
260 displayed (menubar, psheet, debugger panel). */
261 #define MAX_CONCURRENT_TOP_WIDGETS 8
265 /* The widget of this frame. This is an EmacsShell or an
269 /* The parent of the EmacsFrame, the menubar, and the scrollbars.
270 This is an EmacsManager. */
273 /* The widget of the menubar, of whatever widget class it happens to be. */
274 Widget menubar_widget;
276 /* The widget of the edit portion of this frame; this is an EmacsFrame,
277 and the window of this widget is what the redisplay code draws on. */
280 /* Lists the widgets above the text area, in the proper order.
281 Used by the EmacsManager. */
282 Widget top_widgets[MAX_CONCURRENT_TOP_WIDGETS];
285 /*************************** Miscellaneous **************************/
287 /* The icon pixmaps; these are Lisp_Image_Instance objects, or Qnil. */
288 Lisp_Object icon_pixmap;
289 Lisp_Object icon_pixmap_mask;
292 int old_toolbar_size[4];
294 /* We don't provide a mechanism for changing these after they are
295 initialized so we might as well keep pointers to them and avoid
296 lots of expensive calls to gc_cache_lookup. */
297 GC toolbar_top_shadow_gc;
298 GC toolbar_bottom_shadow_gc;
299 GC toolbar_blank_background_gc;
300 GC toolbar_pixmap_background_gc;
301 #endif /* HAVE_TOOLBARS */
303 /* geometry string that ought to be freed. */
304 char *geom_free_me_please;
307 XPoint xic_spot; /* Spot Location cache */
310 /* Could get these at any time by asking xic, but... */
311 XIMStyle xic_style; /* XIM Style cache */
312 #endif /* XIM_XLIB */
313 #endif /* HAVE_XIM */
315 /* 1 if the frame is completely visible on the display, 0 otherwise.
316 if 0 the frame may have been iconified or may be totally
317 or partially hidden by another X window */
318 unsigned int totally_visible_p :1;
320 /* NB: Both of the following flags are derivable from the 'shell'
321 field above, but it's easier if we also have them separately here. */
323 /* Are we a top-level frame? This means that our shell is a
324 TopLevelShell, and we should do certain things to interact with
325 the window manager. */
326 unsigned int top_level_frame_p :1;
328 #ifdef EXTERNAL_WIDGET
329 /* Are we using somebody else's window for our shell window? This
330 means that our shell is an ExternalShell. If this flag is set, then
331 `top_level_frame_p' will never be set. */
332 unsigned int external_window_p :1;
333 #endif /* EXTERNAL_WIDGET */
336 #define FRAME_X_DATA(f) FRAME_TYPE_DATA (f, x)
338 #define FRAME_X_SHELL_WIDGET(f) (FRAME_X_DATA (f)->widget)
339 #define FRAME_X_CONTAINER_WIDGET(f) (FRAME_X_DATA (f)->container)
340 #define FRAME_X_MENUBAR_WIDGET(f) (FRAME_X_DATA (f)->menubar_widget)
341 #define FRAME_X_TEXT_WIDGET(f) (FRAME_X_DATA (f)->edit_widget)
342 #define FRAME_X_TOP_WIDGETS(f) (FRAME_X_DATA (f)->top_widgets)
343 #define FRAME_X_NUM_TOP_WIDGETS(f) (FRAME_X_DATA (f)->num_top_widgets)
345 #define FRAME_X_ICON_PIXMAP(f) (FRAME_X_DATA (f)->icon_pixmap)
346 #define FRAME_X_ICON_PIXMAP_MASK(f) (FRAME_X_DATA (f)->icon_pixmap_mask)
349 #define FRAME_X_OLD_TOOLBAR_SIZE(f, pos) (FRAME_X_DATA (f)->old_toolbar_size[pos])
351 #define FRAME_X_TOOLBAR_TOP_SHADOW_GC(f) (FRAME_X_DATA (f)->toolbar_top_shadow_gc)
352 #define FRAME_X_TOOLBAR_BOTTOM_SHADOW_GC(f) (FRAME_X_DATA (f)->toolbar_bottom_shadow_gc)
353 #define FRAME_X_TOOLBAR_BLANK_BACKGROUND_GC(f) (FRAME_X_DATA (f)->toolbar_blank_background_gc)
354 #define FRAME_X_TOOLBAR_PIXMAP_BACKGROUND_GC(f) (FRAME_X_DATA (f)->toolbar_pixmap_background_gc)
355 #endif /* HAVE_TOOLBARS */
357 #define FRAME_X_GEOM_FREE_ME_PLEASE(f) (FRAME_X_DATA (f)->geom_free_me_please)
359 #define FRAME_X_TOTALLY_VISIBLE_P(f) (FRAME_X_DATA (f)->totally_visible_p)
360 #define FRAME_X_TOP_LEVEL_FRAME_P(f) (FRAME_X_DATA (f)->top_level_frame_p)
362 #ifdef EXTERNAL_WIDGET
363 #define FRAME_X_EXTERNAL_WINDOW_P(f) (FRAME_X_DATA (f)->external_window_p)
367 #define FRAME_X_XIC_SPOT(f) (FRAME_X_DATA (f)->xic_spot)
369 #define FRAME_X_XIC(f) (FRAME_X_DATA (f)->xic)
370 #define FRAME_X_XIC_STYLE(f) (FRAME_X_DATA (f)->xic_style)
371 #endif /* XIM_XLIB */
372 #endif /* HAVE_XIM */
374 /* Variables associated with the X display frame this emacs is using. */
375 extern XtAppContext Xt_app_con;
377 extern Lisp_Object Vx_gc_pointer_shape;
378 extern Lisp_Object Vx_scrollbar_pointer_shape;
379 extern Lisp_Object Qx_error;
381 extern struct console_type *x_console_type;
382 extern Lisp_Object Vdefault_x_device;
384 /* Number of pixels below each line. */
385 extern int x_interline_space; /* #### implement me */
387 extern int x_selection_timeout;
389 struct frame *x_any_window_to_frame (struct device *d, Window);
390 struct frame *x_any_widget_or_parent_to_frame (struct device *d,
392 struct frame *decode_x_frame (Lisp_Object);
393 struct frame *x_window_to_frame (struct device *d, Window);
394 struct device *get_device_from_display (Display *dpy);
395 struct device *decode_x_device (Lisp_Object);
397 void x_handle_selection_notify (XSelectionEvent *event);
398 void x_handle_selection_request (XSelectionRequestEvent *event);
399 void x_handle_selection_clear (XSelectionClearEvent *event);
400 void x_handle_property_notify (XPropertyEvent *event);
402 void Xatoms_of_select_x (struct device *d);
403 void Xatoms_of_objects_x (struct device *d);
405 void x_wm_set_shell_iconic_p (Widget shell, int iconic_p);
406 void x_wm_set_cell_size (Widget wmshell, int cw, int ch);
407 void x_wm_set_variable_size (Widget wmshell, int width, int height);
409 const char *x_event_name (int event_type);
410 int x_error_handler (Display *disp, XErrorEvent *event);
411 void expect_x_error (Display *dpy);
412 int x_error_occurred_p (Display *dpy);
413 int signal_if_x_error (Display *dpy, int resumable_p);
414 int x_IO_error_handler (Display *disp);
416 void x_redraw_exposed_area (struct frame *f, int x, int y,
417 int width, int height);
418 void x_output_string (struct window *w, struct display_line *dl,
419 Charc_dynarr *buf, int xpos, int xoffset,
420 int start_pixpos, int width, face_index findex,
421 int cursor, int cursor_start, int cursor_width,
423 void x_output_x_pixmap (struct frame *f, Lisp_Image_Instance *p,
424 int x, int y, int xoffset, int yoffset,
425 int width, int height,
426 unsigned long fg, unsigned long bg,
428 void x_output_shadows (struct frame *f, int x, int y, int width,
429 int height, GC top_shadow_gc,
430 GC bottom_shadow_gc, GC background_gc,
431 int shadow_thickness, int edges);
432 void x_generate_shadow_pixels (struct frame *f,
433 unsigned long *top_shadow,
434 unsigned long *bottom_shadow,
435 unsigned long background,
436 unsigned long core_background);
438 int x_initialize_frame_menubar (struct frame *f);
439 void x_init_modifier_mapping (struct device *d);
441 #define X_ERROR_OCCURRED(dpy, body) \
442 (expect_x_error (dpy), body, x_error_occurred_p (dpy))
444 #define HANDLING_X_ERROR(dpy, body) \
445 (expect_x_error (dpy), body, signal_if_x_error (dpy, 0))
447 void Initialize_Locale (void);
451 /* X Input Method `methods' */
452 void XIM_init_device (struct device *d);
453 void XIM_init_frame (struct frame *f);
454 void XIM_SetSpotLocation (struct frame *f, int x, int y);
455 void XIM_SetGeometry (struct frame *f);
456 void XIM_focus_event (struct frame *f, int in_p);
459 /* XtTypeConverter */
460 Boolean EmacsXtCvtStringToXIMStyles (
465 XrmValuePtr to_in_out,
466 XtPointer *converter_data);
469 void EmacsFreeXIMStyles (
472 XtPointer converter_data,
477 void describe_Window (Window win);
478 void describe_XFontSet (XFontSet font_set);
479 void describe_XIM (XIM im);
480 void describe_XIMStyle (XIMStyle style);
481 void describe_XIMStyles (XIMStyles *styles);
482 void describe_XIC (XIC ic);
483 void describe_event_mask (unsigned long mask);
484 void describe_XRectangle (char *name, XRectangle *rect);
485 void describe_Status (Status status);
486 #endif /* DEBUG_XEMACS */
487 #endif /* XIM_XLIB */
488 #endif /* HAVE_XIM */
490 extern int in_resource_setting;
491 extern int in_specifier_change_function;
493 extern Lisp_Object Vx_initial_argv_list; /* #### ugh! */
495 /* Standins for various X encodings, until we know them better */
497 /* !!#### Need to verify the encoding used in lwlib -- Qnative or Qctext?
498 Almost certainly the former. Use a standin for now. */
499 #define Qlwlib_encoding Qnative
501 #define Qx_atom_name_encoding Qctext
502 /* font names are often stored in atoms, so it gets sticky if we set this
503 to something different from atom-name encoding */
504 #define Qx_font_name_encoding Qctext
506 #define Qx_color_name_encoding Qctext
508 /* the following probably must agree with Qcommand_argument_encoding and
509 Qenvironment_variable_encoding */
510 #define Qx_display_name_encoding Qnative
512 #endif /* HAVE_X_WINDOWS */
514 #endif /* INCLUDED_console_x_h_ */