1 /* Define frame-object for XEmacs.
2 Copyright (C) 1988, 1992, 1993, 1994 Free Software Foundation, Inc.
4 This file is part of XEmacs.
6 XEmacs is free software; you can redistribute it and/or modify it
7 under the terms of the GNU General Public License as published by the
8 Free Software Foundation; either version 2, or (at your option) any
11 XEmacs is distributed in the hope that it will be useful, but WITHOUT
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 You should have received a copy of the GNU General Public License
17 along with XEmacs; see the file COPYING. If not, write to
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19 Boston, MA 02111-1307, USA. */
21 /* Synched up with: FSF 19.30. */
23 #ifndef _XEMACS_FRAME_H_
24 #define _XEMACS_FRAME_H_
26 #ifdef HAVE_SCROLLBARS
27 #include "scrollbar.h"
36 #include "redisplay.h"
38 #define FRAME_TYPE_NAME(f) ((f)->framemeths->name)
39 #define FRAME_TYPE(f) ((f)->framemeths->symbol)
41 /******** Accessing / calling a frame method *********/
43 #define HAS_FRAMEMETH_P(f, m) HAS_CONTYPE_METH_P ((f)->framemeths, m)
44 #define FRAMEMETH(f, m, args) CONTYPE_METH ((f)->framemeths, m, args)
45 #define MAYBE_FRAMEMETH(f, m, args) \
46 MAYBE_CONTYPE_METH ((f)->framemeths, m, args)
47 #define FRAMEMETH_OR_GIVEN(f, m, args, given) \
48 CONTYPE_METH_OR_GIVEN((f)->framemeths, m, args, given)
52 struct lcrecord_header header;
54 /* Methods for this frame's console. This can also be retrieved
55 through frame->device->console, but it's faster this way. */
56 struct console_methods *framemeths;
58 /* Size of text only area of this frame, excluding scrollbars,
59 toolbars and end of line glyphs. The size can be in characters
60 or pixels, depending on units in which window system resizes
64 /* New height and width for pending size change, in the same units
65 as above. 0 if no change pending. */
66 int new_height, new_width;
68 /* Size of text-only are of the frame, in default font characters.
69 This may be inaccurate due to rounding error */
70 int char_height, char_width;
72 /* Size of the whole frame, including scrollbars, toolbars and end
73 of line glyphs, in pixels */
74 int pixheight, pixwidth;
77 /* The count of frame number. This applies to TTY frames only. */
81 /* Width of the internal border. This is a line of background color
82 just inside the window's border. It is normally only non-zero on
83 X frames, but we put it here to avoid introducing window system
85 int internal_border_width;
87 /* This frame's root window mirror. This structure exactly mirrors
88 the frame's window structure but contains only pointers to the
89 display structures. */
90 struct window_mirror *root_mirror;
94 /* subwindow cache elements for this frame */
95 subwindow_cachel_dynarr *subwindow_cachels;
97 struct expose_ignore* subwindow_exposures;
98 struct expose_ignore* subwindow_exposures_tail;
100 #ifdef HAVE_SCROLLBARS
101 /* frame-local scrollbar information. See scrollbar.c. */
102 int scrollbar_y_offset;
104 /* cache of created scrollbars */
105 struct scrollbar_instance *sb_vcache;
106 struct scrollbar_instance *sb_hcache;
110 /* Size of toolbars as seen by redisplay. This is used to determine
111 whether to re-layout windows by a call to change_frame_size early
112 in redisplay_frame. */
113 unsigned int current_toolbar_size[4];
116 /* Dynamic array of display lines for gutters */
117 display_line_dynarr *current_display_lines;
118 display_line_dynarr *desired_display_lines;
120 /* A structure of auxiliary data specific to the device type.
121 struct x_frame is used for X window frames; defined in console-x.h */
124 #define FRAME_SLOT_DECLARATION
125 #define MARKED_SLOT(x) Lisp_Object x
126 #include "frameslots.h"
128 /* Nonzero if frame is currently displayed.
129 Mutually exclusive with iconified
130 JV: This now a tristate flag:
131 Value : Emacs meaning :f-v-p : X meaning
132 0 : not displayed : nil : unmapped
133 >0 : user can access it,needs repainting : t : mapped and visible
134 <0 : user can access it,needs no repainting : hidden :mapped and invisible
135 where f-v-p is the return value of frame-visible-p */
140 /* Are we finished initializing? */
141 unsigned int init_finished :1;
143 /* Is frame marked for deletion? This is used in XSetErrorHandler(). */
144 unsigned int being_deleted :1;
146 /* Nonzero if this frame has been destroyed. */
147 unsigned int dead :1;
149 /* Nonzero if last attempt at redisplay on this frame was preempted. */
150 unsigned int display_preempted :1;
152 /* Nonzero if window is currently iconified.
153 This and visible are mutually exclusive. */
154 unsigned int iconified :1;
156 /* Nonzero if this frame should be cleared and then redrawn.
157 Setting this will also effectively set frame_changed. */
158 unsigned int clear :1;
160 /* True if frame actually has a minibuffer window on it.
161 0 if using a minibuffer window that isn't on this frame. */
162 unsigned int has_minibuffer :1;
164 /* True if frame's root window can't be split. */
165 unsigned int no_split :1;
167 unsigned int top_toolbar_was_visible :1;
168 unsigned int bottom_toolbar_was_visible :1;
169 unsigned int left_toolbar_was_visible :1;
170 unsigned int right_toolbar_was_visible :1;
171 /* gutter visibility */
172 unsigned int top_gutter_was_visible :1;
173 unsigned int bottom_gutter_was_visible :1;
174 unsigned int left_gutter_was_visible :1;
175 unsigned int right_gutter_was_visible :1;
177 /* redisplay flags */
178 unsigned int buffers_changed :1;
179 unsigned int clip_changed :1;
180 unsigned int extents_changed :1;
181 unsigned int faces_changed :1;
182 unsigned int frame_changed :1;
183 unsigned int subwindows_changed :1;
184 unsigned int subwindows_state_changed :1;
185 unsigned int glyphs_changed :1;
186 unsigned int icon_changed :1;
187 unsigned int menubar_changed :1;
188 unsigned int modeline_changed :1;
189 unsigned int point_changed :1;
190 unsigned int size_changed :1;
191 unsigned int toolbar_changed :1;
192 unsigned int gutter_changed :1;
193 unsigned int windows_changed :1;
194 unsigned int windows_structure_changed :1;
195 unsigned int window_face_cache_reset :1; /* used by expose handler */
196 unsigned int echo_area_garbaged :1; /* used by Fredisplay_echo_area */
197 unsigned int size_slipped :1;
199 unsigned int size_change_pending :1;
200 unsigned int mirror_dirty :1;
202 /* flag indicating if any window on this frame is displaying a subwindow */
203 unsigned int subwindows_being_displayed :1;
206 EXFUN (Fdelete_frame, 2);
207 EXFUN (Fframe_iconified_p, 1);
208 EXFUN (Fframe_name, 1);
209 EXFUN (Fframe_property, 3);
210 EXFUN (Fmake_frame, 2);
211 EXFUN (Fmake_frame_visible, 1);
212 EXFUN (Fraise_frame, 1);
213 EXFUN (Fselect_frame, 1);
214 EXFUN (Fset_frame_pointer, 2);
215 EXFUN (Fset_frame_position, 3);
216 EXFUN (Fset_frame_size, 4);
218 extern Lisp_Object Qbackground_toolbar_color, Qbell_volume, Qborder_color;
219 extern Lisp_Object Qborder_width, Qbottom_toolbar_shadow_color;
220 extern Lisp_Object Qbottom_toolbar_shadow_pixmap, Qdelete_frame;
221 extern Lisp_Object Qdeselect_frame_hook, Qdrag_and_drop_functions, Qgc_pointer;
222 extern Lisp_Object Qiconic, Qinitially_unmapped, Qinter_line_space;
223 extern Lisp_Object Qinternal_border_width, Qinvisible, Qmap_frame_hook;
224 extern Lisp_Object Qminibuffer, Qmodeline_pointer, Qmouse_enter_frame_hook;
225 extern Lisp_Object Qmouse_leave_frame_hook, Qpointer_background;
226 extern Lisp_Object Qpointer_color, Qpopup, Qscrollbar_placement;
227 extern Lisp_Object Qselect_frame_hook, Qspace_pointer;
228 extern Lisp_Object Qsynchronize_minibuffers, Qtext_pointer;
229 extern Lisp_Object Qtoolbar_shadow_thickness, Qtop_toolbar_shadow_color;
230 extern Lisp_Object Qtop_toolbar_shadow_pixmap, Qunmap_frame_hook;
231 extern Lisp_Object Qunsplittable, Quse_backing_store, Qvisible, Qvisual_bell;
232 extern Lisp_Object Vframe_icon_title_format, Vframe_title_format;
233 extern Lisp_Object Vmouse_motion_handler;
236 DECLARE_LRECORD (frame, struct frame);
237 #define XFRAME(x) XRECORD (x, frame, struct frame)
238 #define XSETFRAME(x, p) XSETRECORD (x, p, frame)
239 #define FRAMEP(x) RECORDP (x, frame)
240 #define CHECK_FRAME(x) CHECK_RECORD (x, frame)
241 #define CONCHECK_FRAME(x) CONCHECK_RECORD (x, frame)
243 #define CHECK_LIVE_FRAME(x) do { \
245 if (! FRAME_LIVE_P (XFRAME (x))) \
246 dead_wrong_type_argument (Qframe_live_p, (x)); \
248 #define CONCHECK_LIVE_FRAME(x) do { \
249 CONCHECK_FRAME (x); \
250 if (! FRAME_LIVE_P (XFRAME (x))) \
251 x = wrong_type_argument (Qframe_live_p, (x)); \
254 #define FRAME_TYPE_P(f, type) EQ (FRAME_TYPE (f), Q##type)
256 #ifdef ERROR_CHECK_TYPECHECK
257 INLINE struct frame *
258 error_check_frame_type (struct frame * f, Lisp_Object sym);
259 INLINE struct frame *
260 error_check_frame_type (struct frame * f, Lisp_Object sym)
262 assert (EQ (FRAME_TYPE (f), sym));
265 # define FRAME_TYPE_DATA(f, type) \
266 ((struct type##_frame *) error_check_frame_type (f, Q##type)->frame_data)
268 # define FRAME_TYPE_DATA(f, type) \
269 ((struct type##_frame *) (f)->frame_data)
272 #define CHECK_FRAME_TYPE(x, type) \
275 if (!FRAME_TYPE_P (XFRAME (x), type)) \
276 dead_wrong_type_argument \
277 (type##_console_methods->predicate_symbol, x); \
279 #define CONCHECK_FRAME_TYPE(x, type) \
281 CONCHECK_FRAME (x); \
282 if (!FRAME_TYPE_P (XFRAME (x), type)) \
283 x = wrong_type_argument \
284 (type##_console_methods->predicate_symbol, x); \
287 /* #### These should be in the frame-*.h files but there are
288 too many places where the abstraction is broken. Need to
291 #define FRAME_X_P(frm) CONSOLE_TYPESYM_X_P (FRAME_TYPE (frm))
292 #define CHECK_X_FRAME(z) CHECK_FRAME_TYPE (z, x)
293 #define CONCHECK_X_FRAME(z) CONCHECK_FRAME_TYPE (z, x)
295 #define FRAME_TTY_P(frm) CONSOLE_TYPESYM_TTY_P (FRAME_TYPE (frm))
296 #define CHECK_TTY_FRAME(z) CHECK_FRAME_TYPE (z, tty)
297 #define CONCHECK_TTY_FRAME(z) CONCHECK_FRAME_TYPE (z, tty)
299 #define FRAME_STREAM_P(frm) CONSOLE_TYPESYM_STREAM_P (FRAME_TYPE (frm))
300 #define CHECK_STREAM_FRAME(z) CHECK_FRAME_TYPE (z, stream)
301 #define CONCHECK_STREAM_FRAME(z) CONCHECK_FRAME_TYPE (z, stream)
303 #define FRAME_WIN_P(frm) CONSOLE_TYPESYM_WIN_P (FRAME_TYPE (frm))
305 extern int frame_changed;
307 #define MARK_FRAME_FACES_CHANGED(f) do { \
308 struct frame *mffc_f = (f); \
309 mffc_f->faces_changed = 1; \
311 if (!NILP (mffc_f->device)) \
313 struct device *mffc_d = XDEVICE (mffc_f->device); \
314 MARK_DEVICE_FACES_CHANGED (mffc_d); \
320 #define MARK_FRAME_GLYPHS_CHANGED(f) do { \
321 struct frame *mfgc_f = (f); \
322 mfgc_f->glyphs_changed = 1; \
324 if (!NILP (mfgc_f->device)) \
326 struct device *mfgc_d = XDEVICE (mfgc_f->device); \
327 MARK_DEVICE_GLYPHS_CHANGED (mfgc_d); \
330 glyphs_changed = 1; \
333 #define MARK_FRAME_SUBWINDOWS_CHANGED(f) do { \
334 struct frame *mfgc_f = (f); \
335 mfgc_f->subwindows_changed = 1; \
337 if (!NILP (mfgc_f->device)) \
339 struct device *mfgc_d = XDEVICE (mfgc_f->device); \
340 MARK_DEVICE_SUBWINDOWS_CHANGED (mfgc_d); \
343 subwindows_changed = 1; \
346 #define MARK_FRAME_SUBWINDOWS_STATE_CHANGED(f) do { \
347 struct frame *mfgc_f = (f); \
348 mfgc_f->subwindows_state_changed = 1; \
350 if (!NILP (mfgc_f->device)) \
352 struct device *mfgc_d = XDEVICE (mfgc_f->device); \
353 MARK_DEVICE_SUBWINDOWS_STATE_CHANGED (mfgc_d); \
356 subwindows_state_changed = 1; \
359 #define MARK_FRAME_TOOLBARS_CHANGED(f) do { \
360 struct frame *mftc_f = (f); \
361 mftc_f->toolbar_changed = 1; \
363 if (!NILP (mftc_f->device)) \
365 struct device *mftc_d = XDEVICE (mftc_f->device); \
366 MARK_DEVICE_TOOLBARS_CHANGED (mftc_d); \
369 toolbar_changed = 1; \
372 #define MARK_FRAME_GUTTERS_CHANGED(f) do { \
373 struct frame *mftc_f = (f); \
374 mftc_f->gutter_changed = 1; \
376 if (!NILP (mftc_f->device)) \
378 struct device *mftc_d = XDEVICE (mftc_f->device); \
379 MARK_DEVICE_GUTTERS_CHANGED (mftc_d); \
382 gutter_changed = 1; \
385 #define MARK_FRAME_SIZE_CHANGED(f) do { \
386 struct frame *mfsc_f = (f); \
387 mfsc_f->size_changed = 1; \
388 mfsc_f->size_change_pending = 1; \
390 if (!NILP (mfsc_f->device)) \
392 struct device *mfsc_d = XDEVICE (mfsc_f->device); \
393 MARK_DEVICE_SIZE_CHANGED (mfsc_d); \
399 #define MARK_FRAME_CHANGED(f) do { \
400 struct frame *mfc_f = (f); \
401 mfc_f->frame_changed = 1; \
403 if (!NILP (mfc_f->device)) \
405 struct device *mfc_d = XDEVICE (mfc_f->device); \
406 MARK_DEVICE_FRAME_CHANGED (mfc_d); \
412 #define MARK_FRAME_WINDOWS_CHANGED(f) do { \
413 struct frame *mfwc_f = (f); \
414 mfwc_f->windows_changed = 1; \
416 if (!NILP (mfwc_f->device)) \
418 struct device *mfwc_d = XDEVICE (mfwc_f->device); \
419 MARK_DEVICE_WINDOWS_CHANGED (mfwc_d); \
422 windows_changed = 1; \
425 #define MARK_FRAME_WINDOWS_STRUCTURE_CHANGED(f) do { \
426 struct frame *fwsc_f = (f); \
427 fwsc_f->windows_structure_changed = 1; \
429 if (!NILP (fwsc_f->device)) \
431 struct device *fwsc_d = XDEVICE (fwsc_f->device); \
432 MARK_DEVICE_WINDOWS_STRUCTURE_CHANGED (fwsc_d); \
435 windows_structure_changed = 1; \
436 invalidate_vertical_divider_cache_in_frame (fwsc_f); \
439 #define MARK_FRAME_SIZE_SLIPPED(f) do { \
440 struct frame *fwsc_f = (f); \
441 fwsc_f->size_slipped = 1; \
443 if (!NILP (fwsc_f->device)) \
445 struct device *fwsc_d = XDEVICE (fwsc_f->device); \
446 MARK_DEVICE_FRAME_CHANGED (fwsc_d); \
452 #define CLEAR_FRAME_SIZE_SLIPPED(f) do { \
453 struct frame *fwsc_f = (f); \
454 fwsc_f->size_slipped = 0; \
457 #define SET_FRAME_CLEAR(f) MARK_FRAME_CHANGED (f); (f)->clear = 1
458 #define FRAME_DEVICE(f) ((f)->device)
459 #define FRAME_CONSOLE(f) DEVICE_CONSOLE (XDEVICE (FRAME_DEVICE (f)))
460 #define FRAME_LIVE_P(f) (!(f)->dead)
462 #define FRAME_MINIBUF_ONLY_P(f) \
463 EQ (FRAME_ROOT_WINDOW (f), FRAME_MINIBUF_WINDOW (f))
464 #define FRAME_HAS_MINIBUF_P(f) ((f)->has_minibuffer)
465 #define FRAME_HEIGHT(f) ((f)->height)
466 #define FRAME_WIDTH(f) ((f)->width)
467 #define FRAME_CHARHEIGHT(f) ((f)->char_height)
468 #define FRAME_CHARWIDTH(f) ((f)->char_width)
469 #define FRAME_PIXHEIGHT(f) ((f)->pixheight)
470 #define FRAME_PIXWIDTH(f) ((f)->pixwidth)
471 #ifdef HAVE_SCROLLBARS
472 #define FRAME_SCROLLBAR_WIDTH(f) \
473 (NILP ((f)->vertical_scrollbar_visible_p) ? \
474 0 : XINT ((f)->scrollbar_width))
475 #define FRAME_SCROLLBAR_HEIGHT(f) \
476 (NILP ((f)->horizontal_scrollbar_visible_p) ? \
477 0 : XINT ((f)->scrollbar_height))
479 #define FRAME_SCROLLBAR_WIDTH(f) 0
480 #define FRAME_SCROLLBAR_HEIGHT(f) 0
483 #define FW_FRAME(obj) \
484 (WINDOWP (obj) ? WINDOW_FRAME (XWINDOW (obj)) \
485 : (FRAMEP (obj) ? obj \
488 #define FRAME_NEW_HEIGHT(f) ((f)->new_height)
489 #define FRAME_NEW_WIDTH(f) ((f)->new_width)
490 #define FRAME_CURSOR_X(f) ((f)->cursor_x)
491 #define FRAME_CURSOR_Y(f) ((f)->cursor_y)
492 #define FRAME_VISIBLE_P(f) ((f)->visible)
493 #define FRAME_REPAINT_P(f) ((f)->visible>0)
494 #define FRAME_NO_SPLIT_P(f) ((f)->no_split)
495 #define FRAME_ICONIFIED_P(f) ((f)->iconified)
496 #define FRAME_FOCUS_FRAME(f) ((f)->focus_frame)
497 #define FRAME_MINIBUF_WINDOW(f) ((f)->minibuffer_window)
498 #define FRAME_ROOT_WINDOW(f) ((f)->root_window)
499 /* Catch people attempting to set this. */
500 #define FRAME_SELECTED_WINDOW(f) NON_LVALUE ((f)->selected_window)
501 #define FRAME_LAST_NONMINIBUF_WINDOW(f) \
502 NON_LVALUE ((f)->last_nonminibuf_window)
503 #define FRAME_SB_VCACHE(f) ((f)->sb_vcache)
504 #define FRAME_SB_HCACHE(f) ((f)->sb_hcache)
505 #define FRAME_SUBWINDOW_CACHE(f) ((f)->subwindow_cachels)
509 #define FRAME_VISIBLE_P(f) ((f)->visible != 0)
510 #define FRAME_SET_VISIBLE(f,p) \
511 ((f)->async_visible = (p), FRAME_SAMPLE_VISIBILITY (f))
513 /* Emacs's redisplay code could become confused if a frame's
514 visibility changes at arbitrary times. For example, if a frame is
515 visible while the desired glyphs are being built, but becomes
516 invisible before they are updated, then some rows of the
517 desired_glyphs will be left marked as enabled after redisplay is
518 complete, which should never happen. The next time the frame
519 becomes visible, redisplay will probably barf.
521 Currently, there are no similar situations involving iconified, but
522 the principle is the same.
524 So instead of having asynchronous input handlers directly set and
525 clear the frame's visibility and iconification flags, they just set
526 the async_visible and async_iconified flags; the redisplay code
527 calls the FRAME_SAMPLE_VISIBILITY macro before doing any redisplay,
528 which sets visible and iconified from their asynchronous
531 Synchronous code must use the FRAME_SET_VISIBLE macro.
533 Also, if a frame used to be invisible, but has just become visible,
534 it must be marked as garbaged, since redisplay hasn't been keeping
536 #define FRAME_SAMPLE_VISIBILITY(f) \
537 (((f)->async_visible && ! (f)->visible) ? SET_FRAME_GARBAGED (f) : 0, \
538 (f)->visible = (f)->async_visible, \
539 (f)->iconified = (f)->async_iconified)
543 #define FRAME_BORDER_WIDTH(f) ((f)->internal_border_width)
544 #define FRAME_BORDER_HEIGHT(f) ((f)->internal_border_width)
546 /* This returns the frame-local value; that tells you what you should
547 use when computing the frame size. It is *not* the actual toolbar
548 size because that depends on the selected window. Use the macros
553 #define FRAME_RAW_THEORETICAL_TOOLBAR_VISIBLE(f, pos) \
554 (!NILP((f)->toolbar_buttons[pos]) && !NILP ((f)->toolbar_visible_p[pos]))
555 #define FRAME_RAW_THEORETICAL_TOOLBAR_SIZE(f, pos) \
556 (!NILP ((f)->toolbar_buttons[pos]) && INTP((f)->toolbar_size[pos]) ? \
557 (XINT ((f)->toolbar_size[pos])) : 0)
558 #define FRAME_RAW_THEORETICAL_TOOLBAR_BORDER_WIDTH(f, pos) \
559 (!NILP ((f)->toolbar_buttons[pos]) && INTP((f)->toolbar_border_width[pos]) ? \
560 (XINT ((f)->toolbar_border_width[pos])) : 0)
562 #define FRAME_RAW_THEORETICAL_TOOLBAR_VISIBLE(f, pos) 0
563 #define FRAME_RAW_THEORETICAL_TOOLBAR_SIZE(f, pos) 0
564 #define FRAME_RAW_THEORETICAL_TOOLBAR_BORDER_WIDTH(f, pos) 0
567 #define FRAME_THEORETICAL_TOOLBAR_SIZE(f, pos) \
568 (FRAME_RAW_THEORETICAL_TOOLBAR_VISIBLE (f, pos) \
569 ? FRAME_RAW_THEORETICAL_TOOLBAR_SIZE (f, pos) \
572 #define FRAME_THEORETICAL_TOP_TOOLBAR_HEIGHT(f) \
573 FRAME_THEORETICAL_TOOLBAR_SIZE (f, TOP_TOOLBAR)
574 #define FRAME_THEORETICAL_BOTTOM_TOOLBAR_HEIGHT(f) \
575 FRAME_THEORETICAL_TOOLBAR_SIZE (f, BOTTOM_TOOLBAR)
576 #define FRAME_THEORETICAL_LEFT_TOOLBAR_WIDTH(f) \
577 FRAME_THEORETICAL_TOOLBAR_SIZE (f, LEFT_TOOLBAR)
578 #define FRAME_THEORETICAL_RIGHT_TOOLBAR_WIDTH(f) \
579 FRAME_THEORETICAL_TOOLBAR_SIZE (f, RIGHT_TOOLBAR)
581 #define FRAME_THEORETICAL_TOOLBAR_BORDER_WIDTH(f, pos) \
582 (FRAME_RAW_THEORETICAL_TOOLBAR_VISIBLE (f, pos) \
583 ? FRAME_RAW_THEORETICAL_TOOLBAR_BORDER_WIDTH (f, pos) \
586 #define FRAME_THEORETICAL_TOP_TOOLBAR_BORDER_WIDTH(f) \
587 FRAME_THEORETICAL_TOOLBAR_BORDER_WIDTH (f, TOP_TOOLBAR)
588 #define FRAME_THEORETICAL_BOTTOM_TOOLBAR_BORDER_WIDTH(f) \
589 FRAME_THEORETICAL_TOOLBAR_BORDER_WIDTH (f, BOTTOM_TOOLBAR)
590 #define FRAME_THEORETICAL_LEFT_TOOLBAR_BORDER_WIDTH(f) \
591 FRAME_THEORETICAL_TOOLBAR_BORDER_WIDTH (f, LEFT_TOOLBAR)
592 #define FRAME_THEORETICAL_RIGHT_TOOLBAR_BORDER_WIDTH(f) \
593 FRAME_THEORETICAL_TOOLBAR_BORDER_WIDTH (f, RIGHT_TOOLBAR)
595 /* This returns the window-local value rather than the frame-local value;
596 that tells you about what's actually visible rather than what should
597 be used when computing the frame size. */
600 #define FRAME_RAW_REAL_TOOLBAR_VISIBLE(f, pos) \
601 (HAS_DEVMETH_P (XDEVICE (FRAME_DEVICE (f)), initialize_frame_toolbars) \
602 && !NILP (XWINDOW (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar_visible_p[pos]))
603 #define FRAME_RAW_REAL_TOOLBAR_BORDER_WIDTH(f, pos) \
605 (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar_border_width[pos])) ? \
607 (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar_border_width[pos])) \
609 #define FRAME_RAW_REAL_TOOLBAR_SIZE(f, pos) \
611 (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar_size[pos])) ? \
613 (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar_size[pos])) : 0)
614 #define FRAME_REAL_TOOLBAR(f, pos) \
615 (XWINDOW (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar[pos])
617 #define FRAME_RAW_REAL_TOOLBAR_VISIBLE(f, pos) 0
618 #define FRAME_RAW_REAL_TOOLBAR_BORDER_WIDTH(f, pos) 0
619 #define FRAME_RAW_REAL_TOOLBAR_SIZE(f, pos) 0
620 #define FRAME_REAL_TOOLBAR(f, pos) Qnil
627 The former definitions of FRAME_REAL_FOO_TOOLBAR_VISIBLE
628 looked at the toolbar data to see what was there. The
629 current ones look at the current values of the specifiers.
630 This is a semantic change; the former definition returned
631 what was *actually* there right at the moment, while the
632 current one returns what *ought* to be there once redisplay
633 has run to completion. I think this new definition is more
634 correct in almost all circumstances and is much less likely
635 to lead to strange race conditions. I'm not completely
636 sure that there aren't some places in the redisplay code
637 that use these macros and expect the former semantics, so
638 if you encounter some odd toolbar behavior, you might want
639 to look into this. --ben */
641 #define FRAME_REAL_TOOLBAR_VISIBLE(f, pos) \
642 ((!NILP (FRAME_REAL_TOOLBAR (f, pos)) \
643 && FRAME_RAW_REAL_TOOLBAR_SIZE (f, pos) > 0) \
644 ? FRAME_RAW_REAL_TOOLBAR_VISIBLE (f, pos) \
646 #define FRAME_REAL_TOOLBAR_SIZE(f, pos) \
647 ((!NILP (FRAME_REAL_TOOLBAR (f, pos)) \
648 && FRAME_RAW_REAL_TOOLBAR_VISIBLE (f, pos)) \
649 ? FRAME_RAW_REAL_TOOLBAR_SIZE (f, pos) \
651 #define FRAME_REAL_TOOLBAR_BORDER_WIDTH(f, pos) \
652 ((!NILP (FRAME_REAL_TOOLBAR (f, pos)) \
653 && FRAME_RAW_REAL_TOOLBAR_VISIBLE (f, pos)) \
654 ? FRAME_RAW_REAL_TOOLBAR_BORDER_WIDTH (f, pos) \
657 #define FRAME_REAL_TOP_TOOLBAR_HEIGHT(f) \
658 FRAME_REAL_TOOLBAR_SIZE (f, TOP_TOOLBAR)
659 #define FRAME_REAL_BOTTOM_TOOLBAR_HEIGHT(f) \
660 FRAME_REAL_TOOLBAR_SIZE (f, BOTTOM_TOOLBAR)
661 #define FRAME_REAL_LEFT_TOOLBAR_WIDTH(f) \
662 FRAME_REAL_TOOLBAR_SIZE (f, LEFT_TOOLBAR)
663 #define FRAME_REAL_RIGHT_TOOLBAR_WIDTH(f) \
664 FRAME_REAL_TOOLBAR_SIZE (f, RIGHT_TOOLBAR)
666 #define FRAME_REAL_TOP_TOOLBAR_BORDER_WIDTH(f) \
667 FRAME_REAL_TOOLBAR_BORDER_WIDTH (f, TOP_TOOLBAR)
668 #define FRAME_REAL_BOTTOM_TOOLBAR_BORDER_WIDTH(f) \
669 FRAME_REAL_TOOLBAR_BORDER_WIDTH (f, BOTTOM_TOOLBAR)
670 #define FRAME_REAL_LEFT_TOOLBAR_BORDER_WIDTH(f) \
671 FRAME_REAL_TOOLBAR_BORDER_WIDTH (f, LEFT_TOOLBAR)
672 #define FRAME_REAL_RIGHT_TOOLBAR_BORDER_WIDTH(f) \
673 FRAME_REAL_TOOLBAR_BORDER_WIDTH (f, RIGHT_TOOLBAR)
675 #define FRAME_REAL_TOP_TOOLBAR_VISIBLE(f) \
676 FRAME_REAL_TOOLBAR_VISIBLE (f, TOP_TOOLBAR)
677 #define FRAME_REAL_BOTTOM_TOOLBAR_VISIBLE(f) \
678 FRAME_REAL_TOOLBAR_VISIBLE (f, BOTTOM_TOOLBAR)
679 #define FRAME_REAL_LEFT_TOOLBAR_VISIBLE(f) \
680 FRAME_REAL_TOOLBAR_VISIBLE (f, LEFT_TOOLBAR)
681 #define FRAME_REAL_RIGHT_TOOLBAR_VISIBLE(f) \
682 FRAME_REAL_TOOLBAR_VISIBLE (f, RIGHT_TOOLBAR)
684 #define FRAME_TOP_BORDER_START(f) \
685 (FRAME_REAL_TOP_TOOLBAR_HEIGHT (f) + \
686 2 * FRAME_REAL_TOP_TOOLBAR_BORDER_WIDTH (f))
687 #define FRAME_TOP_BORDER_END(f) \
688 (FRAME_TOP_BORDER_START (f) + FRAME_BORDER_HEIGHT (f))
690 #define FRAME_BOTTOM_BORDER_START(f) \
691 (FRAME_PIXHEIGHT (f) - FRAME_BORDER_HEIGHT (f) - \
692 FRAME_REAL_BOTTOM_TOOLBAR_HEIGHT (f) - \
693 2 * FRAME_REAL_BOTTOM_TOOLBAR_BORDER_WIDTH (f))
694 #define FRAME_BOTTOM_BORDER_END(f) \
695 (FRAME_PIXHEIGHT (f) - FRAME_REAL_BOTTOM_TOOLBAR_HEIGHT (f) - \
696 2 * FRAME_REAL_BOTTOM_TOOLBAR_BORDER_WIDTH (f))
698 #define FRAME_LEFT_BORDER_START(f) \
699 (FRAME_REAL_LEFT_TOOLBAR_WIDTH (f) + \
700 2 * FRAME_REAL_LEFT_TOOLBAR_BORDER_WIDTH (f))
701 #define FRAME_LEFT_BORDER_END(f) \
702 (FRAME_LEFT_BORDER_START (f) + FRAME_BORDER_WIDTH (f))
704 #define FRAME_RIGHT_BORDER_START(f) \
705 (FRAME_PIXWIDTH (f) - FRAME_BORDER_WIDTH (f) - \
706 FRAME_REAL_RIGHT_TOOLBAR_WIDTH(f) - \
707 2 * FRAME_REAL_RIGHT_TOOLBAR_BORDER_WIDTH (f))
708 #define FRAME_RIGHT_BORDER_END(f) \
709 (FRAME_PIXWIDTH (f) - FRAME_REAL_RIGHT_TOOLBAR_WIDTH (f) - \
710 2 * FRAME_REAL_RIGHT_TOOLBAR_BORDER_WIDTH(f))
712 /* Equivalent in FSF Emacs:
714 FOR_EACH_FRAME (LIST_VAR, FRAME_VAR) followed by a statement is a
715 `for' loop which iterates over the elements of Vframe_list. The
716 loop will set FRAME_VAR, a Lisp_Object, to each frame in
717 Vframe_list in succession and execute the statement. LIST_VAR
718 should be a Lisp_Object too; it is used to iterate through the
722 /* NO_BREAK means that "break" doesn't do what you think it does!
723 Use goto instead. "continue" is OK, though. */
724 #define FRAME_LOOP_NO_BREAK(frmcons, devcons, concons) \
725 DEVICE_LOOP_NO_BREAK (devcons, concons) \
726 DEVICE_FRAME_LOOP (frmcons, XDEVICE (XCAR (devcons)))
728 void update_frame_title (struct frame *f);
729 Lisp_Object next_frame (Lisp_Object f, Lisp_Object frametype,
730 Lisp_Object console);
731 Lisp_Object prev_frame (Lisp_Object f, Lisp_Object frametype,
732 Lisp_Object console);
733 void store_in_alist (Lisp_Object *alistptr,
734 CONST char *propname,
736 void pixel_to_char_size (struct frame *f, int pixel_width, int pixel_height,
737 int *char_width, int *char_height);
738 void char_to_pixel_size (struct frame *f, int char_width, int char_height,
739 int *pixel_width, int *pixel_height);
740 void round_size_to_char (struct frame *f, int in_width, int in_height,
741 int *out_width, int *out_height);
742 void pixel_to_real_char_size (struct frame *f, int pixel_width, int pixel_height,
743 int *char_width, int *char_height);
744 void char_to_real_pixel_size (struct frame *f, int char_width, int char_height,
745 int *pixel_width, int *pixel_height);
746 void round_size_to_real_char (struct frame *f, int in_width, int in_height,
747 int *out_width, int *out_height);
748 void change_frame_size (struct frame *frame,
749 int newlength, int newwidth,
751 void adjust_frame_size (struct frame *frame);
752 void frame_size_slipped (Lisp_Object specifier, struct frame *f,
754 void hold_frame_size_changes (void);
755 void unhold_one_frame_size_changes (struct frame *f);
756 void unhold_frame_size_changes (void);
757 void select_frame_1 (Lisp_Object frame);
758 void select_frame_2 (Lisp_Object frame);
759 struct frame *selected_frame (void);
760 struct frame *device_selected_frame (struct device *d);
761 struct frame *decode_frame (Lisp_Object frame);
762 struct frame *decode_frame_or_selected (Lisp_Object cdf);
763 Lisp_Object make_frame (struct frame *f);
764 int other_visible_frames (struct frame *f);
765 void delete_frame_internal (struct frame *f, int force,
766 int called_from_delete_device,
768 void io_error_delete_frame (Lisp_Object frame);
769 Lisp_Object find_some_frame (int (*predicate) (Lisp_Object, void *),
771 int device_matches_console_spec (Lisp_Object frame, Lisp_Object device,
772 Lisp_Object console);
773 Lisp_Object frame_first_window (struct frame *f);
774 int show_gc_cursor (struct frame *f, Lisp_Object cursor);
775 void set_frame_selected_window (struct frame *f, Lisp_Object window);
776 int is_surrogate_for_selected_frame (struct frame *f);
777 void update_frame_icon (struct frame *f);
778 void invalidate_vertical_divider_cache_in_frame (struct frame *f);
780 void init_frame (void);
782 #endif /* _XEMACS_FRAME_H_ */