aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJim Blandy1992-12-24 06:05:56 +0000
committerJim Blandy1992-12-24 06:05:56 +0000
commita42e972438ae75e95e6cb4ff25db244b4d8fb4fa (patch)
tree8438f99832b7fe60f2deaf3fb41a2a317fe8f0cd /src
parent950c26286ee0a238181043c6c344dfed08938176 (diff)
downloademacs-a42e972438ae75e95e6cb4ff25db244b4d8fb4fa.tar.gz
emacs-a42e972438ae75e95e6cb4ff25db244b4d8fb4fa.zip
* frame.h (struct frame): New fields `can_have_scrollbars' and
`has_vertical_scrollbars'. (FRAME_CAN_HAVE_SCROLLBARS, FRAME_HAS_VERTICAL_SCROLLBARS): New accessors, for both the MULTI_FRAME and non-MULTI_FRAME. (VERTICAL_SCROLLBAR_WIDTH, WINDOW_VERTICAL_SCROLLBAR, WINDOW_VERTICAL_SCROLLBAR_COLUMN, WINDOW_VERTICAL_SCROLLBAR_HEIGHT): New macros. * window.h (struct window): New field `vertical_scrollbar'. * xterm.h (struct x_display): vertical_scrollbars, judge_timestamp, vertical_scrollbar_extra: New fields. (struct scrollbar): New struct. (VERTICAL_SCROLLBAR_PIXEL_WIDTH, VERTICAL_SCROLLBAR_PIXEL_HEIGHT, VERTICAL_SCROLLBAR_LEFT_BORDER, VERTICAL_SCROLLBAR_RIGHT_BORDER, VERTICAL_SCROLLBAR_TOP_BORDER, VERTICAL_SCROLLBAR_BOTTOM_BORDER, CHAR_TO_PIXEL_WIDTH, CHAR_TO_PIXEL_HEIGHT, PIXEL_TO_CHAR_WIDTH, PIXEL_TO_CHAR_HEIGHT): New accessors and macros. * frame.c (make_frame): Initialize the `can_have_scrollbars' and `has_vertical_scrollbars' fields of the frame. * term.c (term_init): Note that TERMCAP terminals don't support scrollbars. (mouse_position_hook): Document new args. (set_vertical_scrollbar_hook, condemn_scrollbars_hook, redeem_scrollbar_hook, judge_scrollbars_hook): New hooks. * termhooks.h: Declare and document them. (enum scrollbar_part): New type. (struct input_event): Describe the new form of the scrollbar_click event type. Change `part' from a Lisp_Object to an enum scrollbar_part. Add a new field `scrollbar'. * keyboard.c (kbd_buffer_get_event): Pass appropriate new parameters to *mouse_position_hook, and make_lispy_movement. * xfns.c (x_set_vertical_scrollbar): New function. (x_figure_window_size): Use new macros to calculate frame size. (Fx_create_frame): Note that X Windows frames do support scroll bars. Default to "yes". * xterm.c: #include <X11/cursorfont.h> and "window.h". (x_vertical_scrollbar_cursor): New variable. (x_term_init): Initialize it. (last_mouse_bar, last_mouse_bar_frame, last_mouse_part, last_mouse_scroll_range_start, last_mouse_scroll_range_end): New variables. (XTmouse_position): Use them to return scrollbar movement events. Take new arguments, for that purpose. (x_window_to_scrollbar, x_scrollbar_create, x_scrollbar_set_handle, x_scrollbar_remove, x_scrollbar_move, XTset_scrollbar, XTcondemn_scrollbars, XTredeem_scrollbar, XTjudge_scrollbars, x_scrollbar_expose, x_scrollbar_background_expose, x_scrollbar_handle_click, x_scrollbar_handle_motion): New functions to implement scrollbars. (x_term_init): Set the termhooks.h hooks to point to them. (x_set_window_size): Use new macros to calculate frame size. Set vertical_scrollbar_extra field. (x_make_frame_visible): Use the frame accessor FRAME_HAS_VERTICAL_SCROLLBARS to decide if we need to map the frame's subwindows as well. (XTread_socket): Use new size-calculation macros from xterm.h when processing ConfigureNotify events. (x_wm_set_size_hint): Use PIXEL_TO_CHAR_WIDTH and PIXEL_TO_CHAR_HEIGHT macros. * ymakefile (xdisp.o): This now depends on termhooks.h. (xterm.o): This now depends on window.h. * floatfns.c (Flog): Fix unescaped newline in string. * frame.c (Fnext_frame): Same. * textprop.c (Fprevious_single_property_change): Same. (syms_of_textprop): Same, for DEFVAR for `interval_balance_threshold'. Change the meaning of focus redirection to make switching windows work properly. Fredirect_frame_focus has the details. * frame.h (focus_frame): Doc fix. [not MULTI_FRAME] (FRAME_FOCUS_FRAME): Make this Qnil, which indicates no focus redirection, instead of zero, which is selected_frame. * frame.c (make_frame): Initialize f->focus_frame to Qnil, rather than making it point to frame itself. (Fselect_frame): If changing the selected frame from FOO to BAR, make all redirections to FOO shift to BAR as well. Doc fix. (Fredirect_frame_focus): Doc fix. Accept nil as a valid redirection, not just as a default for FRAME. (Fframe_focus): Doc fix. * keyboard.c (kbd_buffer_store_event, kbd_buffer_get_event): Deal with focus redirections being nil. * xterm.c (XTframe_rehighlight): Doc fix. Deal with focus redirections being nil. It's a pain to remember that you can't assign to FRAME->visible. Let's change all references to the `visible' member of struct frame to use the accessor macros, and then write a setter for the `visible' field that does the right thing. * frame.h (FRAME_VISIBLE_P): Make this not an l-value. (FRAME_SET_VISIBLE): New macro. * frame.c (make_terminal_frame, Fdelete_frame): Use FRAME_SET_VISIBLE. (Fframe_visible_p, Fvisible_frame_list): Use FRAME_VISIBLE_P and FRAME_ICONIFIED_P. * dispnew.c (Fredraw_display): Use the FRAME_VISIBLE_P and FRAME_GARBAGED_P accessors. * xdisp.c (redisplay): Use the FRAME_VISIBLE_P accessor. * xfns.c (x_set_foreground_color, x_set_background_color, x_set_cursor_color, x_set_border_pixel, x_set_icon_type): Use the FRAME_VISIBLE_P accessor. (Fx_create_frame): Use FRAME_SET_VISIBILITY. * xterm.c (clear_cursor, x_display_bar_cursor, x_display_box_cursor): Use FRAME_SET_VISIBILITY.
Diffstat (limited to 'src')
-rw-r--r--src/frame.c78
1 files changed, 59 insertions, 19 deletions
diff --git a/src/frame.c b/src/frame.c
index b4fa6123645..7ac1682830a 100644
--- a/src/frame.c
+++ b/src/frame.c
@@ -156,8 +156,10 @@ make_frame (mini_p)
156 f->no_split = 0; 156 f->no_split = 0;
157 f->garbaged = 0; 157 f->garbaged = 0;
158 f->has_minibuffer = mini_p; 158 f->has_minibuffer = mini_p;
159 f->focus_frame = frame; 159 f->focus_frame = Qnil;
160 f->explicit_name = 0; 160 f->explicit_name = 0;
161 f->can_have_scrollbars = 0;
162 f->has_vertical_scrollbars = 0;
161 163
162 f->param_alist = Qnil; 164 f->param_alist = Qnil;
163 165
@@ -314,8 +316,7 @@ make_terminal_frame ()
314 Vframe_list = Qnil; 316 Vframe_list = Qnil;
315 f = make_frame (1); 317 f = make_frame (1);
316 f->name = build_string ("terminal"); 318 f->name = build_string ("terminal");
317 f->async_visible = 1; 319 FRAME_SET_VISIBLE (f, 1);
318 f->visible = 1;
319 f->display.nothing = 1; /* Nonzero means frame isn't deleted. */ 320 f->display.nothing = 1; /* Nonzero means frame isn't deleted. */
320 XSET (Vterminal_frame, Lisp_Frame, f); 321 XSET (Vterminal_frame, Lisp_Frame, f);
321 return f; 322 return f;
@@ -329,7 +330,10 @@ focus on that frame.\n\
329This function is interactive, and may be bound to the ``switch-frame''\n\ 330This function is interactive, and may be bound to the ``switch-frame''\n\
330event; when invoked this way, it switches to the frame named in the\n\ 331event; when invoked this way, it switches to the frame named in the\n\
331event. When called from lisp, FRAME may be a ``switch-frame'' event;\n\ 332event. When called from lisp, FRAME may be a ``switch-frame'' event;\n\
332if it is, select the frame named in the event.") 333if it is, select the frame named in the event.\n\
334\n\
335Changing the selected frame can change focus redirections. See\n\
336`redirect-frame-focus' for details.")
333 (frame, no_enter) 337 (frame, no_enter)
334 Lisp_Object frame, no_enter; 338 Lisp_Object frame, no_enter;
335{ 339{
@@ -345,6 +349,31 @@ if it is, select the frame named in the event.")
345 if (selected_frame == XFRAME (frame)) 349 if (selected_frame == XFRAME (frame))
346 return frame; 350 return frame;
347 351
352 /* If a frame's focus has been redirected toward the currently
353 selected frame, we should change the redirection to point to the
354 newly selected frame. This means that if the focus is redirected
355 from a minibufferless frame to a surrogate minibuffer frame, we
356 can use `other-window' to switch between all the frames using
357 that minibuffer frame, and the focus redirection will follow us
358 around. */
359 {
360 Lisp_Object tail;
361
362 for (tail = Vframe_list; CONSP (tail); tail = XCONS (tail)->cdr)
363 {
364 Lisp_Object focus;
365
366 if (XTYPE (XCONS (tail)->car) != Lisp_Frame)
367 abort ();
368
369 focus = FRAME_FOCUS_FRAME (XFRAME (XCONS (tail)->car));
370
371 if (XTYPE (focus) == Lisp_Frame
372 && XFRAME (focus) == selected_frame)
373 Fredirect_frame_focus (XCONS (tail)->car, frame);
374 }
375 }
376
348 selected_frame = XFRAME (frame); 377 selected_frame = XFRAME (frame);
349 if (! FRAME_MINIBUF_ONLY_P (selected_frame)) 378 if (! FRAME_MINIBUF_ONLY_P (selected_frame))
350 last_nonminibuf_frame = selected_frame; 379 last_nonminibuf_frame = selected_frame;
@@ -535,7 +564,7 @@ prev_frame (frame, minibuf)
535 564
536DEFUN ("next-frame", Fnext_frame, Snext_frame, 0, 2, 0, 565DEFUN ("next-frame", Fnext_frame, Snext_frame, 0, 2, 0,
537 "Return the next frame in the frame list after FRAME.\n\ 566 "Return the next frame in the frame list after FRAME.\n\
538By default, skip minibuffer-only frames. 567By default, skip minibuffer-only frames.\n\
539If omitted, FRAME defaults to the selected frame.\n\ 568If omitted, FRAME defaults to the selected frame.\n\
540If optional argument MINIFRAME is non-nil, include minibuffer-only frames.\n\ 569If optional argument MINIFRAME is non-nil, include minibuffer-only frames.\n\
541If MINIFRAME is a window, include only frames using that window for their\n\ 570If MINIFRAME is a window, include only frames using that window for their\n\
@@ -623,7 +652,7 @@ A frame may not be deleted if its minibuffer is used by other frames.")
623 f->root_window = Qnil; 652 f->root_window = Qnil;
624 653
625 Vframe_list = Fdelq (frame, Vframe_list); 654 Vframe_list = Fdelq (frame, Vframe_list);
626 f->visible = 0; 655 FRAME_SET_VISIBLE (f, 0);
627 displ = f->display; 656 displ = f->display;
628 f->display.nothing = 0; 657 f->display.nothing = 0;
629 658
@@ -867,9 +896,9 @@ Return the symbol `icon' if frame is visible only as an icon.")
867{ 896{
868 CHECK_LIVE_FRAME (frame, 0); 897 CHECK_LIVE_FRAME (frame, 0);
869 898
870 if (XFRAME (frame)->visible) 899 if (FRAME_VISIBLE_P (XFRAME (frame)))
871 return Qt; 900 return Qt;
872 if (XFRAME (frame)->iconified) 901 if (FRAME_ICONIFIED_P (XFRAME (frame)))
873 return Qicon; 902 return Qicon;
874 return Qnil; 903 return Qnil;
875} 904}
@@ -890,7 +919,7 @@ DEFUN ("visible-frame-list", Fvisible_frame_list, Svisible_frame_list,
890 if (XTYPE (frame) != Lisp_Frame) 919 if (XTYPE (frame) != Lisp_Frame)
891 continue; 920 continue;
892 f = XFRAME (frame); 921 f = XFRAME (frame);
893 if (f->visible) 922 if (FRAME_VISIBLE_P (f))
894 value = Fcons (frame, value); 923 value = Fcons (frame, value);
895 } 924 }
896 return value; 925 return value;
@@ -901,25 +930,34 @@ DEFUN ("visible-frame-list", Fvisible_frame_list, Svisible_frame_list,
901DEFUN ("redirect-frame-focus", Fredirect_frame_focus, Sredirect_frame_focus, 930DEFUN ("redirect-frame-focus", Fredirect_frame_focus, Sredirect_frame_focus,
902 1, 2, 0, 931 1, 2, 0,
903 "Arrange for keystrokes typed at FRAME to be sent to FOCUS-FRAME.\n\ 932 "Arrange for keystrokes typed at FRAME to be sent to FOCUS-FRAME.\n\
904This means that, after reading a keystroke typed at FRAME,\n\ 933In other words, switch-frame events caused by events in FRAME will\n\
905`last-event-frame' will be FOCUS-FRAME.\n\ 934request a switch to FOCUS-FRAME, and `last-event-frame' will be\n\
935FOCUS-FRAME after reading an event typed at FRAME.\n\
906\n\ 936\n\
907If FOCUS-FRAME is omitted or eq to FRAME, any existing redirection is\n\ 937If FOCUS-FRAME is omitted or nil, any existing redirection is\n\
908cancelled, and the frame again receives its own keystrokes.\n\ 938cancelled, and the frame again receives its own keystrokes.\n\
909\n\ 939\n\
910The redirection lasts until the next call to `redirect-frame-focus'\n\ 940Focus redirection is useful for temporarily redirecting keystrokes to\n\
911or `select-frame'.\n\ 941a surrogate minibuffer frame when a frame doesn't have its own\n\
942minibuffer window.\n\
912\n\ 943\n\
913This is useful for temporarily redirecting keystrokes to the minibuffer\n\ 944A frame's focus redirection can be changed by select-frame. If frame\n\
914window when a frame doesn't have its own minibuffer.") 945FOO is selected, and then a different frame BAR is selected, any\n\
946frames redirecting their focus to FOO are shifted to redirect their\n\
947focus to BAR. This allows focus redirection to work properly when the\n\
948user switches from one frame to another using `select-window'.\n\
949\n\
950This means that a frame whose focus is redirected to itself is treated\n\
951differently from a frame whose focus is redirected to nil; the former\n\
952is affected by select-frame, while the latter is not.\n\
953\n\
954The redirection lasts until `redirect-frame-focus' is called to change it.")
915 (frame, focus_frame) 955 (frame, focus_frame)
916 Lisp_Object frame, focus_frame; 956 Lisp_Object frame, focus_frame;
917{ 957{
918 CHECK_LIVE_FRAME (frame, 0); 958 CHECK_LIVE_FRAME (frame, 0);
919 959
920 if (NILP (focus_frame)) 960 if (! NILP (focus_frame))
921 focus_frame = frame;
922 else
923 CHECK_LIVE_FRAME (focus_frame, 1); 961 CHECK_LIVE_FRAME (focus_frame, 1);
924 962
925 XFRAME (frame)->focus_frame = focus_frame; 963 XFRAME (frame)->focus_frame = focus_frame;
@@ -933,11 +971,13 @@ window when a frame doesn't have its own minibuffer.")
933 971
934DEFUN ("frame-focus", Fframe_focus, Sframe_focus, 1, 1, 0, 972DEFUN ("frame-focus", Fframe_focus, Sframe_focus, 1, 1, 0,
935 "Return the frame to which FRAME's keystrokes are currently being sent.\n\ 973 "Return the frame to which FRAME's keystrokes are currently being sent.\n\
974This returns nil if FRAME's focus is not redirected.\n\
936See `redirect-frame-focus'.") 975See `redirect-frame-focus'.")
937 (frame) 976 (frame)
938 Lisp_Object frame; 977 Lisp_Object frame;
939{ 978{
940 CHECK_LIVE_FRAME (frame, 0); 979 CHECK_LIVE_FRAME (frame, 0);
980
941 return FRAME_FOCUS_FRAME (XFRAME (frame)); 981 return FRAME_FOCUS_FRAME (XFRAME (frame));
942} 982}
943 983