XEmacs 21.2.20 "Yoko".
[chise/xemacs-chise.git.1] / src / frame.h
1 /* Define frame-object for XEmacs.
2    Copyright (C) 1988, 1992, 1993, 1994 Free Software Foundation, Inc.
3
4 This file is part of XEmacs.
5
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
9 later version.
10
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
14 for more details.
15
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.  */
20
21 /* Synched up with: FSF 19.30. */
22
23 #ifndef _XEMACS_FRAME_H_
24 #define _XEMACS_FRAME_H_
25
26 #ifdef HAVE_SCROLLBARS
27 #include "scrollbar.h"
28 #endif
29
30 #ifdef HAVE_TOOLBARS
31 #include "toolbar.h"
32 #endif
33
34 #include "device.h"
35 #include "glyphs.h"
36 #include "redisplay.h"
37
38 #define FRAME_TYPE_NAME(f) ((f)->framemeths->name)
39 #define FRAME_TYPE(f) ((f)->framemeths->symbol)
40
41 /******** Accessing / calling a frame method *********/
42
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)
49
50 struct frame
51 {
52   struct lcrecord_header header;
53
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;
57
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
61      its windows */
62   int height, width;
63
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;
67
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;
71
72   /* Size of the whole frame, including scrollbars, toolbars and end
73      of line glyphs, in pixels */
74   int pixheight, pixwidth;
75
76 #ifdef HAVE_TTY
77   /* The count of frame number.  This applies to TTY frames only. */
78   int order_count;
79 #endif
80
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
84      dependencies. */
85   int internal_border_width;
86
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;
91
92   int modiff;
93
94   /* subwindow cache elements for this frame */
95   subwindow_cachel_dynarr *subwindow_cachels;
96
97   struct expose_ignore* subwindow_exposures;
98   struct expose_ignore* subwindow_exposures_tail;
99
100 #ifdef HAVE_SCROLLBARS
101   /* frame-local scrollbar information.  See scrollbar.c. */
102   int scrollbar_y_offset;
103
104   /* cache of created scrollbars */
105   struct scrollbar_instance *sb_vcache;
106   struct scrollbar_instance *sb_hcache;
107 #endif
108
109 #ifdef HAVE_TOOLBARS
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];
114 #endif
115
116   /* Dynamic array of display lines for gutters */
117   display_line_dynarr *current_display_lines;
118   display_line_dynarr *desired_display_lines;
119
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 */
122   void *frame_data;
123
124 #define FRAME_SLOT_DECLARATION
125 #define MARKED_SLOT(x) Lisp_Object x
126 #include "frameslots.h"
127
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 */
136   int visible;
137
138   /* one-bit flags: */
139
140   /* Are we finished initializing? */
141   unsigned int init_finished :1;
142
143   /* Is frame marked for deletion?  This is used in XSetErrorHandler().  */
144   unsigned int being_deleted :1;
145
146   /* Nonzero if this frame has been destroyed. */
147   unsigned int dead :1;
148
149   /* Nonzero if last attempt at redisplay on this frame was preempted.  */
150   unsigned int display_preempted :1;
151
152   /* Nonzero if window is currently iconified.
153      This and visible are mutually exclusive.  */
154   unsigned int iconified :1;
155
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;
159
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;
163
164   /* True if frame's root window can't be split.  */
165   unsigned int no_split :1;
166
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;
176
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;
198
199   unsigned int size_change_pending :1;
200   unsigned int mirror_dirty :1;
201
202   /* flag indicating if any window on this frame is displaying a subwindow */
203   unsigned int subwindows_being_displayed :1;
204 };
205
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);
217
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;
234
235
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)
242
243 #define CHECK_LIVE_FRAME(x) do {                        \
244   CHECK_FRAME (x);                                      \
245   if (! FRAME_LIVE_P (XFRAME (x)))                      \
246     dead_wrong_type_argument (Qframe_live_p, (x));      \
247 } while (0)
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));       \
252 } while (0)
253
254 #define FRAME_TYPE_P(f, type)   EQ (FRAME_TYPE (f), Q##type)
255
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)
261 {
262   assert (EQ (FRAME_TYPE (f), sym));
263   return f;
264 }
265 # define FRAME_TYPE_DATA(f, type)                       \
266  ((struct type##_frame *) error_check_frame_type (f, Q##type)->frame_data)
267 #else
268 # define FRAME_TYPE_DATA(f, type)                       \
269   ((struct type##_frame *) (f)->frame_data)
270 #endif
271
272 #define CHECK_FRAME_TYPE(x, type)                       \
273   do {                                                  \
274     CHECK_FRAME (x);                                    \
275     if (!FRAME_TYPE_P (XFRAME (x), type))               \
276       dead_wrong_type_argument                          \
277         (type##_console_methods->predicate_symbol, x);  \
278   } while (0)
279 #define CONCHECK_FRAME_TYPE(x, type)                    \
280   do {                                                  \
281     CONCHECK_FRAME (x);                                 \
282     if (!FRAME_TYPE_P (XFRAME (x), type))               \
283       x = wrong_type_argument                           \
284         (type##_console_methods->predicate_symbol, x);  \
285   } while (0)
286
287 /* #### These should be in the frame-*.h files but there are
288    too many places where the abstraction is broken.  Need to
289    fix. */
290
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)
294
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)
298
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)
302
303 #define FRAME_WIN_P(frm) CONSOLE_TYPESYM_WIN_P (FRAME_TYPE (frm))
304
305 extern int frame_changed;
306
307 #define MARK_FRAME_FACES_CHANGED(f) do {                \
308   struct frame *mffc_f = (f);                           \
309   mffc_f->faces_changed = 1;                            \
310   mffc_f->modiff++;                                     \
311   if (!NILP (mffc_f->device))                           \
312     {                                                   \
313       struct device *mffc_d = XDEVICE (mffc_f->device); \
314       MARK_DEVICE_FACES_CHANGED (mffc_d);               \
315     }                                                   \
316   else                                                  \
317     faces_changed = 1;                                  \
318 } while (0)
319
320 #define MARK_FRAME_GLYPHS_CHANGED(f) do {               \
321   struct frame *mfgc_f = (f);                           \
322   mfgc_f->glyphs_changed = 1;                           \
323   mfgc_f->modiff++;                                     \
324   if (!NILP (mfgc_f->device))                           \
325     {                                                   \
326       struct device *mfgc_d = XDEVICE (mfgc_f->device); \
327       MARK_DEVICE_GLYPHS_CHANGED (mfgc_d);              \
328     }                                                   \
329   else                                                  \
330     glyphs_changed = 1;                                 \
331 } while (0)
332
333 #define MARK_FRAME_SUBWINDOWS_CHANGED(f) do {           \
334   struct frame *mfgc_f = (f);                           \
335   mfgc_f->subwindows_changed = 1;                               \
336   mfgc_f->modiff++;                                     \
337   if (!NILP (mfgc_f->device))                           \
338     {                                                   \
339       struct device *mfgc_d = XDEVICE (mfgc_f->device); \
340       MARK_DEVICE_SUBWINDOWS_CHANGED (mfgc_d);          \
341     }                                                   \
342   else                                                  \
343     subwindows_changed = 1;                                     \
344 } while (0)
345
346 #define MARK_FRAME_SUBWINDOWS_STATE_CHANGED(f) do {     \
347   struct frame *mfgc_f = (f);                           \
348   mfgc_f->subwindows_state_changed = 1;         \
349   mfgc_f->modiff++;                                     \
350   if (!NILP (mfgc_f->device))                           \
351     {                                                   \
352       struct device *mfgc_d = XDEVICE (mfgc_f->device); \
353       MARK_DEVICE_SUBWINDOWS_STATE_CHANGED (mfgc_d);    \
354     }                                                   \
355   else                                                  \
356     subwindows_state_changed = 1;                       \
357 } while (0)
358
359 #define MARK_FRAME_TOOLBARS_CHANGED(f) do {             \
360   struct frame *mftc_f = (f);                           \
361   mftc_f->toolbar_changed = 1;                          \
362   mftc_f->modiff++;                                     \
363   if (!NILP (mftc_f->device))                           \
364     {                                                   \
365       struct device *mftc_d = XDEVICE (mftc_f->device); \
366       MARK_DEVICE_TOOLBARS_CHANGED (mftc_d);            \
367     }                                                   \
368   else                                                  \
369     toolbar_changed = 1;                                \
370 } while (0)
371
372 #define MARK_FRAME_GUTTERS_CHANGED(f) do {      \
373   struct frame *mftc_f = (f);                           \
374   mftc_f->gutter_changed = 1;                           \
375   mftc_f->modiff++;                                     \
376   if (!NILP (mftc_f->device))                           \
377     {                                                   \
378       struct device *mftc_d = XDEVICE (mftc_f->device); \
379       MARK_DEVICE_GUTTERS_CHANGED (mftc_d);     \
380     }                                                   \
381   else                                                  \
382     gutter_changed = 1;                                 \
383 } while (0)
384
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;                      \
389   mfsc_f->modiff++;                                     \
390   if (!NILP (mfsc_f->device))                           \
391     {                                                   \
392       struct device *mfsc_d = XDEVICE (mfsc_f->device); \
393       MARK_DEVICE_SIZE_CHANGED (mfsc_d);                \
394     }                                                   \
395   else                                                  \
396     size_changed = 1;                                   \
397 } while (0)
398
399 #define MARK_FRAME_CHANGED(f) do {                      \
400   struct frame *mfc_f = (f);                            \
401   mfc_f->frame_changed = 1;                             \
402   mfc_f->modiff++;                                      \
403   if (!NILP (mfc_f->device))                            \
404     {                                                   \
405       struct device *mfc_d = XDEVICE (mfc_f->device);   \
406       MARK_DEVICE_FRAME_CHANGED (mfc_d);                \
407     }                                                   \
408   else                                                  \
409     frame_changed = 1;                                  \
410 } while (0)
411
412 #define MARK_FRAME_WINDOWS_CHANGED(f) do {              \
413   struct frame *mfwc_f = (f);                           \
414   mfwc_f->windows_changed = 1;                          \
415   mfwc_f->modiff++;                                     \
416   if (!NILP (mfwc_f->device))                           \
417     {                                                   \
418       struct device *mfwc_d = XDEVICE (mfwc_f->device); \
419       MARK_DEVICE_WINDOWS_CHANGED (mfwc_d);             \
420     }                                                   \
421   else                                                  \
422     windows_changed = 1;                                \
423 } while (0)
424
425 #define MARK_FRAME_WINDOWS_STRUCTURE_CHANGED(f) do {    \
426   struct frame *fwsc_f = (f);                           \
427   fwsc_f->windows_structure_changed = 1;                \
428   fwsc_f->modiff++;                                     \
429   if (!NILP (fwsc_f->device))                           \
430     {                                                   \
431       struct device *fwsc_d = XDEVICE (fwsc_f->device); \
432       MARK_DEVICE_WINDOWS_STRUCTURE_CHANGED (fwsc_d);   \
433     }                                                   \
434   else                                                  \
435     windows_structure_changed = 1;                      \
436   invalidate_vertical_divider_cache_in_frame (fwsc_f);  \
437 } while (0)
438
439 #define MARK_FRAME_SIZE_SLIPPED(f) do {                 \
440   struct frame *fwsc_f = (f);                           \
441   fwsc_f->size_slipped = 1;                             \
442   fwsc_f->modiff++;                                     \
443   if (!NILP (fwsc_f->device))                           \
444     {                                                   \
445       struct device *fwsc_d = XDEVICE (fwsc_f->device); \
446       MARK_DEVICE_FRAME_CHANGED (fwsc_d);               \
447     }                                                   \
448   else                                                  \
449     frame_changed = 1;                                  \
450 } while (0)
451
452 #define CLEAR_FRAME_SIZE_SLIPPED(f) do {                \
453   struct frame *fwsc_f = (f);                           \
454   fwsc_f->size_slipped = 0;                             \
455 } while (0)
456
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)
461
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))
478 #else
479 #define FRAME_SCROLLBAR_WIDTH(f) 0
480 #define FRAME_SCROLLBAR_HEIGHT(f) 0
481 #endif
482
483 #define FW_FRAME(obj)                                   \
484    (WINDOWP (obj) ? WINDOW_FRAME (XWINDOW (obj))        \
485  : (FRAMEP  (obj) ? obj                                         \
486  : Qnil))
487
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)
506
507 #if 0 /* FSFmacs */
508
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))
512
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.
520
521    Currently, there are no similar situations involving iconified, but
522    the principle is the same.
523
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
529    counterparts.
530
531    Synchronous code must use the FRAME_SET_VISIBLE macro.
532
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
535    up its contents.  */
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)
540
541 #endif /* FSFmacs */
542
543 #define FRAME_BORDER_WIDTH(f) ((f)->internal_border_width)
544 #define FRAME_BORDER_HEIGHT(f) ((f)->internal_border_width)
545
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
549    below for that.
550 */
551
552 #ifdef HAVE_TOOLBARS
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)
561 #else
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
565 #endif
566
567 #define FRAME_THEORETICAL_TOOLBAR_SIZE(f, pos)          \
568   (FRAME_RAW_THEORETICAL_TOOLBAR_VISIBLE (f, pos)       \
569    ? FRAME_RAW_THEORETICAL_TOOLBAR_SIZE (f, pos)        \
570    : 0)
571
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)
580
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)        \
584    : 0)
585
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)
594
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. */
598
599 #ifdef HAVE_TOOLBARS
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) \
604      ((INTP (XWINDOW \
605              (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar_border_width[pos])) ? \
606       (XINT (XWINDOW \
607              (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar_border_width[pos])) \
608       : 0)
609 #define FRAME_RAW_REAL_TOOLBAR_SIZE(f, pos) \
610      ((INTP (XWINDOW \
611              (FRAME_LAST_NONMINIBUF_WINDOW (f))->toolbar_size[pos])) ? \
612       (XINT (XWINDOW \
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])
616 #else
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
621 #endif
622
623 /* Note to Chuck
624    Note to Chuck
625    Note to Chuck:
626
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 */
640
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)    \
645    : 0)
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)       \
650    : 0)
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)       \
655    : 0)
656
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)
665
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)
674
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)
683
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))
689
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))
697
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))
703
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))
711
712 /* Equivalent in FSF Emacs:
713
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
719    Vframe_list.
720    */
721
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)))
727
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,
735                      Lisp_Object val);
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,
750                         int delay);
751 void adjust_frame_size (struct frame *frame);
752 void frame_size_slipped (Lisp_Object specifier, struct frame *f,
753                          Lisp_Object oldval);
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,
767                             int from_io_error);
768 void io_error_delete_frame (Lisp_Object frame);
769 Lisp_Object find_some_frame (int (*predicate) (Lisp_Object, void *),
770                              void *closure);
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);
779
780 #endif /* _XEMACS_FRAME_H_ */