mirror of
git://git.sv.gnu.org/emacs.git
synced 2026-02-20 15:10:37 -08:00
* frame.el (frame-notice-user-settings): Rewrite using frame-initial-frame-tool-bar-height. * menu-bar.el (menu-bar-horizontal-scroll-bar) (menu-bar-no-horizontal-scroll-bar): New functions. (menu-bar-showhide-scroll-bar-menu): Add bindings for horizontal scroll bars. * scroll-bar.el (scroll-bar-lines) (set-horizontal-scroll-bar-mode) (get-horizontal-scroll-bar-mode, horizontal-scroll-bar-mode) (scroll-bar-horizontal-drag-1, scroll-bar-horizontal-drag) (scroll-bar-toolkit-horizontal-scroll): New functions. (horizontal-scroll-bar-mode) (previous-horizontal-scroll-bar-mode) (horizontal-scroll-bar-mode-explicit): New variables. (horizontal-scroll-bar-mode): New option. (toggle-horizontal-scroll-bar): Do something. (top-level): Bind horizontal-scroll-bar mouse-1. * startup.el (tool-bar-originally-present): Remove variable. (command-line): Don't set tool-bar-originally-present. * window.el (window-min-height): Update doc-string. (window--dump-frame): Dump horizontal scroll bar values. (window--min-size-1): Handle minibuffer window separately. Count in margins and horizontal scroll bar. Return safe value iff IGNORE equals 'safe. (frame-windows-min-size): New function (used by frame resizing routines). (fit-frame-to-buffer, fit-window-to-buffer): Count in horizontal scroll bars. (window--sanitize-window-sizes): New function. (window-split-min-size): Remove. (split-window): Count divider-width. Don't use `window-split-min-size' any more. Reword error messages. Sanitize windows sizes after splitting. * buffer.h (struct buffer): New fields scroll_bar_height and horizontal_scroll_bar_type. * buffer.c (bset_scroll_bar_height) (bset_horizontal_scroll_bar_type): New functions. (Fbuffer_swap_text): Handle old_pointm field. (init_buffer_once): Set defaults for scroll_bar_height and horizontal_scroll_bar_type. (syms_of_buffer): New variables scroll_bar_height and horizontal_scroll_bar_type. * dispextern.h (window_part): Rename ON_SCROLL_BAR to ON_VERTICAL_SCROLL_BAR. Add ON_HORIZONTAL_SCROLL_BAR. (set_vertical_scroll_bar): Remove prototype. (x_change_tool_bar_height): Add prototype. * dispnew.c (adjust_frame_glyphs_for_frame_redisplay) (window_to_frame_vpos, update_frame_1, scrolling, init_display): Use FRAME_TOTAL_COLS and FRAME_TOTAL_LINES instead of FRAME_COLS and FRAME_LINES. (adjust_frame_glyphs_for_window_redisplay): Rearrange lines. (update_window): Start mode_line_row->y after horizontal scroll bar. (change_frame_size_1): Call adjust_frame_size. (init_display): When changing the size of a tty frame do not pass height of menu bar. (Qframe_windows_min_size): New symbol. * frame.h (struct frame): List tool bar fields after menu bar fields. Add official, total_lines, horizontal_scroll_bars, config_scroll_bar_height and config_scroll_bar_lines fields. (FRAME_HAS_HORIZONTAL_SCROLL_BARS) (FRAME_CONFIG_SCROLL_BAR_HEIGHT, FRAME_CONFIG_SCROLL_BAR_LINES) (FRAME_SCROLL_BAR_AREA_HEIGHT, FRAME_SCROLL_BAR_COLS) (FRAME_SCROLL_BAR_LINES, FRAME_TOTAL_LINES, SET_FRAME_LINES) (FRAME_WINDOWS_HEIGHT): New macros. (SET_FRAME_HEIGHT, FRAME_TEXT_LINES_TO_PIXEL_HEIGHT) (FRAME_PIXEL_Y_TO_LINE, FRAME_PIXEL_HEIGHT_TO_TEXT_LINES) (FRAME_TEXT_TO_PIXEL_HEIGHT): Separately count top margin and horizontal scroll bar. (frame_inhibit_resize, adjust_frame_size) (frame_windows_min_size): Add declarations. (Qscroll_bar_height, Qhorizontal_scroll_bars) (x_set_scroll_bar_default_height, x_set_left_fringe) (x_set_right_fringe, x_set_vertical_scroll_bars) (x_set_horizontal_scroll_bars, x_set_scroll_bar_width) (x_set_scroll_bar_height): Add external declarations. * frame.c: (frame_inhibit_resize, frame_windows_min_size) (adjust_frame_size): New functions. (make_frame): Initial horizontal_scroll_bars field. Use SET_FRAME_LINES. Don't allow horizontal scroll bar in minibuffer window. (make_initial_frame, make_terminal_frame): No horizontal scroll bar in initial and terminal frames. Use adjust_frame_size. (Fframe_total_cols): Fix doc-string. (Fframe_total_lines, Fscroll_bar_height): New Lisp functions. (Fset_frame_height, Fset_frame_width, Fset_frame_size): Rewrite using adjust_frame_size. (Qscroll_bar_height, Qhorizontal_scroll_bars) (Qframe_windows_min_size): New symbols. (x_set_frame_parameters): Remove call of check_frame_size. (x_report_frame_params): Return scroll_bar_height value. (x_set_left_fringe, x_set_right_fringe): New functions. (adjust_frame_height, x_set_internal_border_width) (x_set_fringe_width): Remove. (x_set_internal_border_width, x_set_vertical_scroll_bars) (x_set_scroll_bar_width, x_set_right_divider_width) (x_set_bottom_divider_width): Rewrite using adjust_frame_size. (x_set_horizontal_scroll_bars, x_set_scroll_bar_height): New functions. (x_figure_window_size): Rewrite to make frame display the expected number of lines. (Vdefault_frame_scroll_bars): Rewrite doc-string. (Vdefault_frame_horizontal_scroll_bars) (Vframe_initial_frame_tool_bar_height) (frame_inhibit_implied_resize): New variables. * fringe.c (compute_fringe_widths): Remove. * gtkutil.h (YG_SB_MIN, YG_SB_MAX, YG_SB_RANGE): Define. (xg_create_horizontal_scroll_bar) (xg_update_horizontal_scrollbar_pos) (xg_set_toolkit_horizontal_scroll_bar_thumb) (xg_get_default_scrollbar_height) (xg_clear_under_internal_border): Extern. * gtkutil.c (xg_frame_resized): Don't call do_pending_window_change. (xg_frame_set_char_size): Use adjust_frame_size. (style_changed_cb): Call update_theme_scrollbar_height and x_set_scroll_bar_default_height. (x_wm_set_size_hint): Don't call check_frame_size. (update_theme_scrollbar_height) (xg_get_default_scrollbar_height) (xg_create_horizontal_scroll_bar) (xg_update_horizontal_scrollbar_pos) (xg_set_toolkit_horizontal_scroll_bar_thumb): New functions. (xg_create_scroll_bar): Set horizontal slot of bar. (xg_initialize): Call update_theme_scrollbar_height. (xg_clear_under_internal_border): No more static. * insdel.c (adjust_suspend_auto_hscroll): New function. (adjust_markers_for_delete, adjust_markers_for_insert) (adjust_markers_for_replace): Call adjust_suspend_auto_hscroll. * keyboard.c (readable_events, discard_mouse_events) (make_lispy_event): Handle horizontal scroll bar click events. (Fsuspend_emacs): When changing the size of a tty frame do not pass height of menu bar. (Qbefore_handle, Qhorizontal_handle, Qafter_handle, Qleft) (Qright, Qleftmost, Qrightmost): New symbols. * menu.c (Fx_popup_dialog): Use FRAME_TOTAL_LINES instead of FRAME_LINES. * minibuf.c (read_minibuf): Initialize suspend_auto_hscroll. * nsfns.m (x_set_internal_border_width): New function. * nsterm.m (ns_draw_fringe_bitmap, ns_set_vertical_scroll_bar): Remove extended fringe code. (x_set_window_size, x_new_font): Don't call compute_fringe_widths. * term.c (Fresume_tty): When changing the size of a tty frame do not pass height of menu bar. (clear_tty_hooks, set_tty_hooks): Clear horizontal_scroll_bar_hook. (init_tty): Frame has no horizontal scroll bars. * termhooks.h (enum scroll_bar_part): Add scroll_bar_move_ratio, scroll_bar_before_handle, scroll_bar_horizontal_handle, scroll_bar_after_handle, scroll_bar_left_arrow, scroll_bar_right_arrow, scroll_bar_to_leftmost and scroll_bar_to_rightmost entries. (enum event_kind): Add HORIZONTAL_SCROLL_BAR_CLICK_EVENT (struct terminal): Add set_horizontal_scroll_bar_hook. * w32console.c (initialize_w32_display): Clear horizontal_scroll_bar_hook. * w32fns.c (x_set_mouse_color): Use FRAME_W32_DISPLAY instead of FRAME_X_DISPLAY. (x_clear_under_internal_border, x_set_internal_border_width): New functions. (x_set_menu_bar_lines): Rewrite using frame_inhibit_resize. Set windows_or_buffers_changed when adding the menu bar. (x_set_tool_bar_lines): Rewrite using adjust_frame_size. (x_change_tool_bar_height, x_set_scroll_bar_default_height) (w32_createhscrollbar): New functions. (w32_createscrollbar): Rename to w32_createvscrollbar. (w32_createwindow): Init WND_HSCROLLBAR_INDEX. (w32_name_of_message): Replace WM_EMACS_CREATESCROLLBAR by WM_EMACS_CREATEVSCROLLBAR and WM_EMACS_CREATEHSCROLLBAR. Add WM_EMACS_SHOWCURSOR. (w32_wnd_proc): Handle WM_HSCROLL case. In WM_WINDOWPOSCHANGING case do not artificially impose WM size hints. Handle WM_EMACS_SHOWCURSOR case. Replace WM_EMACS_CREATESCROLLBAR case by WM_EMACS_CREATEVSCROLLBAR and WM_EMACS_CREATEHSCROLLBAR cases. (my_create_tip_window): Replace WND_SCROLLBAR_INDEX by WND_VSCROLLBAR_INDEX and WND_HSCROLLBAR_INDEX. (unwind_create_frame_1): Remove. (Fx_create_frame): Make both scrollbars the system standard width and height. Use official field of frame structure to inhibit running window-configuration-change-hook. (x_create_tip_frame): Call SET_FRAME_LINES and change_frame_size pixelwise. Handle frame's official field. (w32_frame_parm_handlers): Remove x_set_fringe_width entries. Add x_set_scroll_bar_height, x_set_horizontal_scroll_bars, x_set_left_fringe and x_set_right_fringe. * w32inevt.c (resize_event, maybe_generate_resize_event): Do not pass height of menu bar to change_frame_size. * w32menu.c (set_frame_menubar): Rewrite using frame_inhibit_resize. * w32term.h (struct w32_display_info): Add horizontal_scroll_bar_cursor and cursor_display_counter. (struct scroll_bar): Add horizontal. (HORIZONTAL_SCROLL_BAR_INSIDE_HEIGHT) (HORIZONTAL_SCROLL_BAR_LEFT_RANGE) (HORIZONTAL_SCROLL_BAR_INSIDE_WIDTH) (HORIZONTAL_SCROLL_BAR_LEFT_BORDER) (HORIZONTAL_SCROLL_BAR_RIGHT_BORDER) (HORIZONTAL_SCROLL_BAR_TOP_BORDER) (HORIZONTAL_SCROLL_BAR_BOTTOM_BORDER) (HORIZONTAL_SCROLL_BAR_MIN_HANDLE): New macros. (WM_EMACS_CREATEVSCROLLBAR, WM_EMACS_CREATEHSCROLLBAR): Define instead of WM_EMACS_CREATESCROLLBAR. (WND_VSCROLLBAR_INDEX, WND_HSCROLLBAR_INDEX): Define instead of WND_SCROLLBAR_INDEX. * w32term.c (horizontal_scroll_bar_min_handle) (horizontal_scroll_bar_left_border) (horizontal_scroll_bar_right_border): New integers. (x_set_frame_alpha): Replace x_highlight_frame by w32_focus_frame. (x_window_to_scroll_bar): New argument "type". Update callers accordingly. (w32_set_horizontal_scroll_bar_thumb) (x_horizontal_scroll_bar_report_motion) (w32_set_horizontal_scroll_bar) (w32_horizontal_scroll_bar_handle_click) (x_horizontal_scroll_bar_report_motion): New functions. (w32_mouse_position): Discriminate horizontal and vertical scrollbar cases. (my_create_scrollbar): Replace with two new functions my_create_vscrollbar and my_create_hscrollbar. (x_scroll_bar_create): New argument "horizontal". Update callers accordingly. (x_scroll_bar_remove, w32_condemn_scroll_bars) (w32_redeem_scroll_bar, x_scroll_bar_clear): Handle horizontal scroll bar case. (w32_read_socket): Handle WM_HSCROLL cae. (x_new_font): Don't recompute fringe widths. Use frame_inhibit_resize. Calculate new menu bar height iff we build without toolkit. Always clear under internal border. (x_set_window_size): Don't check frame size or recompute fringes. Reset fullscreen status before applying sizes. Always resize as requested by pixelwise argument. Don't call do_pending_window_change. (x_wm_set_size_hint): Add call for FRAME_SCROLL_BAR_AREA_HEIGHT. (w32_initialize_display_info): Initialize dpyinfo's horizontal_scroll_bar_cursor entry. (w32_create_terminal): Add set_horizontal_scroll_bar_hook. (w32_initialize): Init horizontal_scroll_bar_min_handle and horizontal_scroll_bar_left_border. (w32fullscreen_hook): Intermittently resize window to normal when switching from fullscreen to maximized state. (run_window_configuration_change_hook): Don't run it if frame is not official yet. (unwind_change_frame): Remove. (Fset_window_configuration): Rewrite using frame's official field. * widget.c (set_frame_size): Don't call compute_fringe_widths. (EmacsFrameSetCharSize): Obey frame_inhibit_resize. * window.h (struct window): New fields old_pointm, horizontal_scroll_bar, horizontal_scroll_bar_type, hscroll_whole, scroll_bar_height and suspend_auto_hscroll. (wset_horizontal_scroll_bar, wset_horizontal_scroll_bar_type): New functions. (sanitize_window_sizes): Extern. (MINI_NON_ONLY_WINDOW_P, MINI_ONLY_WINDOW_P, WINDOW_PSEUDO_P) (WINDOW_TOPMOST_P, WINDOW_HAS_HORIZONTAL_SCROLL_BAR) (WINDOW_CONFIG_SCROLL_BAR_HEIGHT) (WINDOW_CONFIG_SCROLL_BAR_LINES) (WINDOW_SCROLL_BAR_LINES, WINDOW_SCROLL_BAR_AREA_HEIGHT): New macros. (WINDOW_LEFT_FRINGE_COLS, WINDOW_RIGHT_FRINGE_COLS) (WINDOW_FRINGE_COLS, WINDOW_FRINGE_EXTENDED_P): Remove macros. (WINDOW_VERTICAL_SCROLL_BAR_TYPE) (WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_LEFT) (WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_RIGHT) (WINDOW_HAS_VERTICAL_SCROLL_BAR): Minor rewrite. (WINDOW_BOX_HEIGHT_NO_MODE_LINE, WINDOW_BOX_TEXT_HEIGHT) (WINDOW_SCROLL_BAR_AREA_Y): Count in scroll bar height. * window.c (wset_old_pointm, Fwindow_scroll_bar_height) (Fwindow_old_point, sanitize_window_sizes): New functions. (Qwindow_sanitize_window_sizes): New symbol. (window_body_height): Count in horizontal scroll bar. (set_window_hscroll, Fscroll_left, Fscroll_right): Set suspend_auto_hscroll slot. (Fwindow_inside_edges): Count fringes pixelwise. (coordinates_in_window, Fcoordinates_in_window_p): Consider horizontal scroll bar. (check_frame_size, adjust_window_margins): Remove functions and corresponding calls. (set_window_buffer): Initialize old_pointm and horizontal scroll bars. (temp_output_buffer_show): Reset hscroll related fields. Initialize old_pointm. (make_parent_window): Initialize old_pointm. (make_window): Initialize old_pointm, horizontal scroll bar type, and scroll bar height. (resize_frame_windows): Don't count top margin in new sizes. Don't use safe sizes when shrinking a frame; let the window manager do the clipping. (Fsplit_window_internal): Inherit horizontal scroll bar type and height. (Fdelete_window_internal): Unchain old_pointm marker. (window_scroll_pixel_based, Fscroll_other_window): Adjust old_pointm. (Fwindow_text_width, Fwindow_text_height): New argument "pixelwise". (struct saved_window): New fields, old_pointm, hscroll_whole, suspend_auto_hscroll, scroll_bar_height and horizontal_scroll_bar_type. (Fset_window_configuration, save_window_save): Set new fields of saved_window. (apply_window_adjustment): Don't call adjust_window_margins. (set_window_margins): Don't change margins if new sizes don't fit into window. (set_window_scroll_bars): New argument "horizontal_type". Handle horizontal scroll bars. Don't change scroll bars if they don't fit into window. (Fset_window_scroll_bars): New argument "horizontal_type". (Fwindow_scroll_bars): Return values for horizontal scroll bars. (compare_window_configurations): Compare horizontal scroll bar settings. * xdisp.c (window_text_bottom_y, window_box_height): Count in horizontal scroll bar height. (pixel_to_glyph_coords, init_xdisp): Use FRAME_TOTAL_LINES instead of FRAME_LINES. (remember_mouse_glyph): Case ON_SCROLL_BAR changed to ON_VERTICAL_SCROLL_BAR. (with_echo_area_buffer): Initialize old_pointm. (with_echo_area_buffer_unwind_data): Store old_pointm values in vector. (unwind_with_echo_area_buffer): Handle old_pointm. (update_tool_bar): Set do_update when the tool bar window has at least one line (since this is what the user sets). (MAX_FRAME_TOOL_BAR_HEIGHT): Remove macro. (redisplay_tool_bar): Return early when toolbar has zero lines. Call x_change_tool_bar_height. Don't use max_tool_bar_height. (hscroll_window_tree): Handle suspension of auto_hscroll and old_pointm. (set_horizontal_scroll_bar): New function. (redisplay_window): Set ignore_mouse_drag_p when tool bar has more than one line. Handle horizontal scroll bars. (note_mouse_highlight): Handle horizontal scrol bars. (expose_frame): Set dimensions of XRectangle from frame's text sizes. (Vvoid_text_area_pointer): Update doc-string. * xfns.c (x_set_menu_bar_lines): Use adjust_frame_size. (x_change_tool_bar_height, x_set_scroll_bar_default_height) (x_set_internal_border_width): New functions. (x_set_tool_bar_lines): Call x_change_tool_bar_height. (unwind_create_frame_1): Remove. (Fx_create_frame): Handle horizontal scroll bars. Use official field of frame structure to inhibit running window-configuration-change-hook. (x_create_tip_frame): Call SET_FRAME_LINES and change_frame_size pixelwise. Handle frame's official field. (x_frame_parm_handlers): Add x_set_scroll_bar_height, x_set_horizontal_scroll_bars, x_set_left_fringe, x_set_right_fringe. * xmenu.c (update_frame_menubar, free_frame_menubar): Use adjust_frame_size. * xterm.h (struct x_display_info): Add horizontal_scroll_bar_cursor and Xatom_Horizontal_Scrollbar slots. (struct scroll_bar): Add horizontal slot. (HORIZONTAL_SCROLL_BAR_INSIDE_HEIGHT) (HORIZONTAL_SCROLL_BAR_LEFT_RANGE) (HORIZONTAL_SCROLL_BAR_INSIDE_WIDTH): New macros. (HORIZONTAL_SCROLL_BAR_LEFT_BORDER) (HORIZONTAL_SCROLL_BAR_RIGHT_BORDER) (HORIZONTAL_SCROLL_BAR_TOP_BORDER) (HORIZONTAL_SCROLL_BAR_BOTTOM_BORDER) (HORIZONTAL_SCROLL_BAR_MIN_HANDLE): Define. (x_clear_under_internal_border): Remove. * xterm.c (XTmouse_position): Handle horizontal scroll bars. (x_window_to_scroll_bar): New argument TYPE. Update callers. (x_send_scroll_bar_event, x_scroll_bar_create): New arguments HORIZONTAL. Update callers. (horizontal_action_hook_id): New action hook id. (x_horizontal_scroll_bar_to_input_event) (x_create_horizontal_toolkit_scroll_bar) (xt_horizontal_action_hook) (x_set_toolkit_horizontal_scroll_bar_thumb) (XTset_horizontal_scroll_bar, x_net_wm_state) (x_horizontal_scroll_bar_report_motion): New functions. (xg_scroll_callback, x_scroll_bar_handle_click): Handle horizontal scroll bars. (SCROLL_BAR_HORIZONTAL_NAME): Define. (XTset_vertical_scroll_bar): Attempt to clear areas not covered by scroll bar. (XTcondemn_scroll_bars, XTredeem_scroll_bar): Rewrite. Handle horizontal scroll bars. (handle_one_xevent): Handle horizontal scroll bar events. Call x_net_wm_state. (x_set_window_size_1, x_wm_set_size_hint): Don't call check_frame_size. (x_set_window_size): Don't call check_frame_size and do_pending_window_change. (x_term_init): Init horizontal_scroll_bar_cursor display info. (x_create_terminal): Add set_horizontal_scroll_bar_hook. (x_scroll_bar_set_handle): Add some checks when calling x_clear_area.
1120 lines
40 KiB
C
1120 lines
40 KiB
C
/* Window definitions for GNU Emacs.
|
|
Copyright (C) 1985-1986, 1993, 1995, 1997-2014 Free Software
|
|
Foundation, Inc.
|
|
|
|
This file is part of GNU Emacs.
|
|
|
|
GNU Emacs is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
GNU Emacs is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef WINDOW_H_INCLUDED
|
|
#define WINDOW_H_INCLUDED
|
|
|
|
#include "dispextern.h"
|
|
|
|
INLINE_HEADER_BEGIN
|
|
|
|
/* Windows are allocated as if they were vectors, but then the
|
|
Lisp data type is changed to Lisp_Window. They are garbage
|
|
collected along with the vectors.
|
|
|
|
All windows in use are arranged into a tree, with pointers up and down.
|
|
|
|
Windows that are leaves of the tree are actually displayed
|
|
and show the contents of buffers. Windows that are not leaves
|
|
are used for representing the way groups of leaf windows are
|
|
arranged on the frame. Leaf windows never become non-leaves.
|
|
They are deleted only by calling delete-window on them (but
|
|
this can be done implicitly). Combination windows can be created
|
|
and deleted at any time.
|
|
|
|
A leaf window has a buffer stored in contents field and markers in its start
|
|
and pointm fields. Non-leaf windows have nil in the latter two fields.
|
|
|
|
Non-leaf windows are either vertical or horizontal combinations.
|
|
|
|
A vertical combination window has children that are arranged on the frame
|
|
one above the next. Its contents field points to the uppermost child.
|
|
The parent field of each of the children points to the vertical
|
|
combination window. The next field of each child points to the
|
|
child below it, or is nil for the lowest child. The prev field
|
|
of each child points to the child above it, or is nil for the
|
|
highest child.
|
|
|
|
A horizontal combination window has children that are side by side.
|
|
Its contents field points to the leftmost child. In each child
|
|
the next field points to the child to the right and the prev field
|
|
points to the child to the left.
|
|
|
|
The children of a vertical combination window may be leaf windows
|
|
or horizontal combination windows. The children of a horizontal
|
|
combination window may be leaf windows or vertical combination windows.
|
|
|
|
At the top of the tree are two windows which have nil as parent.
|
|
The second of these is minibuf_window. The first one manages all
|
|
the frame area that is not minibuffer, and is called the root window.
|
|
Different windows can be the root at different times;
|
|
initially the root window is a leaf window, but if more windows
|
|
are created then that leaf window ceases to be root and a newly
|
|
made combination window becomes root instead.
|
|
|
|
In any case, on screens which have an ordinary window and a
|
|
minibuffer, prev of the minibuf window is the root window and next of
|
|
the root window is the minibuf window. On minibufferless screens or
|
|
minibuffer-only screens, the root window and the minibuffer window are
|
|
one and the same, so its prev and next members are nil.
|
|
|
|
A dead window has its contents field set to nil. */
|
|
|
|
struct cursor_pos
|
|
{
|
|
/* Pixel position. These are always window relative. */
|
|
int x, y;
|
|
|
|
/* Glyph matrix position. */
|
|
int hpos, vpos;
|
|
};
|
|
|
|
struct window
|
|
{
|
|
/* This is for Lisp; the terminal code does not refer to it. */
|
|
struct vectorlike_header header;
|
|
|
|
/* The frame this window is on. */
|
|
Lisp_Object frame;
|
|
|
|
/* Following (to right or down) and preceding (to left or up) child
|
|
at same level of tree. */
|
|
Lisp_Object next;
|
|
Lisp_Object prev;
|
|
|
|
/* The window this one is a child of. */
|
|
Lisp_Object parent;
|
|
|
|
/* The normal size of the window. These are fractions, but we do
|
|
not use C doubles to avoid creating new Lisp_Float objects while
|
|
interfacing Lisp in Fwindow_normal_size. */
|
|
Lisp_Object normal_lines;
|
|
Lisp_Object normal_cols;
|
|
|
|
/* New sizes of the window. Note that Lisp code may set new_normal
|
|
to something beyond an integer, so C int can't be used here. */
|
|
Lisp_Object new_total;
|
|
Lisp_Object new_normal;
|
|
Lisp_Object new_pixel;
|
|
|
|
/* May be buffer, window, or nil. */
|
|
Lisp_Object contents;
|
|
|
|
/* A marker pointing to where in the text to start displaying.
|
|
BIDI Note: This is the _logical-order_ start, i.e. the smallest
|
|
buffer position visible in the window, not necessarily the
|
|
character displayed in the top left corner of the window. */
|
|
Lisp_Object start;
|
|
|
|
/* A marker pointing to where in the text point is in this window,
|
|
used only when the window is not selected.
|
|
This exists so that when multiple windows show one buffer
|
|
each one can have its own value of point. */
|
|
Lisp_Object pointm;
|
|
|
|
/* A marker pointing to where in the text point was in this window
|
|
at the time of last redisplay. The value is saved for the
|
|
selected window too. */
|
|
Lisp_Object old_pointm;
|
|
|
|
/* No permanent meaning; used by save-window-excursion's
|
|
bookkeeping. */
|
|
Lisp_Object temslot;
|
|
|
|
/* This window's vertical scroll bar. This field is only for use by
|
|
the window-system-dependent code which implements the scroll
|
|
bars; it can store anything it likes here. If this window is
|
|
newly created and we haven't displayed a scroll bar in it yet, or
|
|
if the frame doesn't have any scroll bars, this is nil. */
|
|
Lisp_Object vertical_scroll_bar;
|
|
|
|
/* Type of vertical scroll bar. A value of nil means
|
|
no scroll bar. A value of t means use frame value. */
|
|
Lisp_Object vertical_scroll_bar_type;
|
|
|
|
/* This window's horizontal scroll bar. This field is only for use
|
|
by the window-system-dependent code which implements the scroll
|
|
bars; it can store anything it likes here. If this window is
|
|
newly created and we haven't displayed a scroll bar in it yet, or
|
|
if the frame doesn't have any scroll bars, this is nil. */
|
|
Lisp_Object horizontal_scroll_bar;
|
|
|
|
/* Type of horizontal scroll bar. A value of nil means
|
|
no scroll bar. A value of t means use frame value. */
|
|
Lisp_Object horizontal_scroll_bar_type;
|
|
|
|
/* Display-table to use for displaying chars in this window.
|
|
Nil means use the buffer's own display-table. */
|
|
Lisp_Object display_table;
|
|
|
|
/* Non-nil usually means window is marked as dedicated.
|
|
Note Lisp code may set this to something beyond Qnil
|
|
and Qt, so bitfield can't be used here. */
|
|
Lisp_Object dedicated;
|
|
|
|
/* If redisplay in this window goes beyond this buffer position,
|
|
must run the redisplay-end-trigger-hook. */
|
|
Lisp_Object redisplay_end_trigger;
|
|
|
|
/* t means this window's child windows are not (re-)combined. */
|
|
Lisp_Object combination_limit;
|
|
|
|
/* An alist with parameters. */
|
|
Lisp_Object window_parameters;
|
|
|
|
/* No Lisp data may follow below this point without changing
|
|
mark_object in alloc.c. The member current_matrix must be the
|
|
first non-Lisp member. */
|
|
|
|
/* Glyph matrices. */
|
|
struct glyph_matrix *current_matrix;
|
|
struct glyph_matrix *desired_matrix;
|
|
|
|
/* The two Lisp_Object fields below are marked in a special way,
|
|
which is why they're placed after `current_matrix'. */
|
|
/* Alist of <buffer, window-start, window-point> triples listing
|
|
buffers previously shown in this window. */
|
|
Lisp_Object prev_buffers;
|
|
/* List of buffers re-shown in this window. */
|
|
Lisp_Object next_buffers;
|
|
|
|
/* Number saying how recently window was selected. */
|
|
int use_time;
|
|
|
|
/* Unique number of window assigned when it was created. */
|
|
int sequence_number;
|
|
|
|
/* The upper left corner pixel coordinates of this window, as
|
|
integers relative to upper left corner of frame = 0, 0. */
|
|
int pixel_left;
|
|
int pixel_top;
|
|
|
|
/* The upper left corner coordinates of this window,
|
|
relative to upper left corner of frame = 0, 0. */
|
|
int left_col;
|
|
int top_line;
|
|
|
|
/* The pixel size of the window. */
|
|
int pixel_width;
|
|
int pixel_height;
|
|
|
|
/* The size of the window. */
|
|
int total_cols;
|
|
int total_lines;
|
|
|
|
/* Number of columns display within the window is scrolled to the left. */
|
|
ptrdiff_t hscroll;
|
|
|
|
/* Minimum hscroll for automatic hscrolling. This is the value
|
|
the user has set, by set-window-hscroll for example. */
|
|
ptrdiff_t min_hscroll;
|
|
|
|
/* Maximum line length in pixels within window bound by size of
|
|
window (set up by set_horizontal_scroll_bar). */
|
|
ptrdiff_t hscroll_whole;
|
|
|
|
/* Displayed buffer's text modification events counter as of last time
|
|
display completed. */
|
|
EMACS_INT last_modified;
|
|
|
|
/* Displayed buffer's overlays modification events counter as of last
|
|
complete update. */
|
|
EMACS_INT last_overlay_modified;
|
|
|
|
/* Value of point at that time. Since this is a position in a buffer,
|
|
it should be positive. */
|
|
ptrdiff_t last_point;
|
|
|
|
/* Line number and position of a line somewhere above the top of the
|
|
screen. If this field is zero, it means we don't have a base line. */
|
|
ptrdiff_t base_line_number;
|
|
|
|
/* If this field is zero, it means we don't have a base line.
|
|
If it is -1, it means don't display the line number as long
|
|
as the window shows its buffer. */
|
|
ptrdiff_t base_line_pos;
|
|
|
|
/* The column number currently displayed in this window's mode
|
|
line, or -1 if column numbers are not being displayed. */
|
|
ptrdiff_t column_number_displayed;
|
|
|
|
/* Scaling factor for the glyph_matrix size calculation in this window.
|
|
Used if window contains many small images or uses proportional fonts,
|
|
as the normal may yield a matrix which is too small. */
|
|
int nrows_scale_factor, ncols_scale_factor;
|
|
|
|
/* Intended cursor position. This is a position within the
|
|
glyph matrix. */
|
|
struct cursor_pos cursor;
|
|
|
|
/* Where the cursor actually is. */
|
|
struct cursor_pos phys_cursor;
|
|
|
|
/* Internally used for redisplay purposes. */
|
|
struct cursor_pos output_cursor;
|
|
|
|
/* Vertical cursor position as of last update that completed
|
|
without pause. This is the position of last_point. */
|
|
int last_cursor_vpos;
|
|
|
|
#ifdef HAVE_WINDOW_SYSTEM
|
|
|
|
/* Cursor type of last cursor drawn on the window. */
|
|
enum text_cursor_kinds phys_cursor_type;
|
|
|
|
/* Width of the cursor above. */
|
|
int phys_cursor_width;
|
|
|
|
/* This is handy for undrawing the cursor. */
|
|
int phys_cursor_ascent, phys_cursor_height;
|
|
|
|
#endif /* HAVE_WINDOW_SYSTEM */
|
|
|
|
/* Width of left and right fringes, in pixels.
|
|
A value of -1 means use frame values. */
|
|
int left_fringe_width;
|
|
int right_fringe_width;
|
|
|
|
/* Requested width of left and right marginal areas in columns. A
|
|
value of 0 means no margin. The actual values are recorded in
|
|
the window's glyph matrix, in the left_margin_glyphs and
|
|
right_margin_glyphs members. */
|
|
int left_margin_cols;
|
|
int right_margin_cols;
|
|
|
|
/* Pixel width of scroll bars.
|
|
A value of -1 means use frame values. */
|
|
int scroll_bar_width;
|
|
|
|
/* Pixel height of scroll bars.
|
|
A value of -1 means use frame values. */
|
|
int scroll_bar_height;
|
|
|
|
/* Effective height of the mode line, or -1 if not known. */
|
|
int mode_line_height;
|
|
|
|
/* Effective height of the header line, or -1 if not known. */
|
|
int header_line_height;
|
|
|
|
/* Z - the buffer position of the last glyph in the current
|
|
matrix of W. Only valid if window_end_valid is true. */
|
|
ptrdiff_t window_end_pos;
|
|
|
|
/* Glyph matrix row of the last glyph in the current matrix
|
|
of W. Only valid if window_end_valid is true. */
|
|
int window_end_vpos;
|
|
|
|
/* True if this window is a minibuffer window. */
|
|
bool_bf mini : 1;
|
|
|
|
/* Meaningful only if contents is a window, non-zero if this
|
|
internal window is used in horizontal combination. */
|
|
bool_bf horizontal : 1;
|
|
|
|
/* True means must regenerate mode line of this window. */
|
|
bool_bf update_mode_line : 1;
|
|
|
|
/* True if the buffer was "modified" when the window
|
|
was last updated. */
|
|
bool_bf last_had_star : 1;
|
|
|
|
/* True means current value of `start'
|
|
was the beginning of a line when it was chosen. */
|
|
bool_bf start_at_line_beg : 1;
|
|
|
|
/* True means next redisplay must use the value of start
|
|
set up for it in advance. Set by scrolling commands. */
|
|
bool_bf force_start : 1;
|
|
|
|
/* True means we have explicitly changed the value of start,
|
|
but that the next redisplay is not obliged to use the new value.
|
|
This is used in Fdelete_other_windows to force a call to
|
|
Vwindow_scroll_functions; also by Frecenter with argument. */
|
|
bool_bf optional_new_start : 1;
|
|
|
|
/* True means the cursor is currently displayed. This can be
|
|
set to zero by functions overpainting the cursor image. */
|
|
bool_bf phys_cursor_on_p : 1;
|
|
|
|
/* False means cursor is logically on, true means it's off. Used for
|
|
blinking cursor. */
|
|
bool_bf cursor_off_p : 1;
|
|
|
|
/* Value of cursor_off_p as of the last redisplay. */
|
|
bool_bf last_cursor_off_p : 1;
|
|
|
|
/* True means desired matrix has been build and window must be
|
|
updated in update_frame. */
|
|
bool_bf must_be_updated_p : 1;
|
|
|
|
/* Flag indicating that this window is not a real one.
|
|
Currently only used for menu bar windows of frames. */
|
|
bool_bf pseudo_window_p : 1;
|
|
|
|
/* True means fringes are drawn outside display margins.
|
|
Otherwise draw them between margin areas and text. */
|
|
bool_bf fringes_outside_margins : 1;
|
|
|
|
/* True if window_end_pos and window_end_vpos are truly valid.
|
|
This is false if nontrivial redisplay is preempted since in that case
|
|
the frame image that window_end_pos did not get onto the frame. */
|
|
bool_bf window_end_valid : 1;
|
|
|
|
/* True if it needs to be redisplayed. */
|
|
bool_bf redisplay : 1;
|
|
|
|
/* True if auto hscrolling is currently suspended in this
|
|
window. */
|
|
bool_bf suspend_auto_hscroll : 1;
|
|
|
|
/* Amount by which lines of this window are scrolled in
|
|
y-direction (smooth scrolling). */
|
|
int vscroll;
|
|
|
|
/* Z_BYTE - buffer position of the last glyph in the current matrix of W.
|
|
Should be nonnegative, and only valid if window_end_valid is true. */
|
|
ptrdiff_t window_end_bytepos;
|
|
};
|
|
|
|
/* Most code should use these functions to set Lisp fields in struct
|
|
window. */
|
|
INLINE void
|
|
wset_frame (struct window *w, Lisp_Object val)
|
|
{
|
|
w->frame = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_next (struct window *w, Lisp_Object val)
|
|
{
|
|
w->next = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_prev (struct window *w, Lisp_Object val)
|
|
{
|
|
w->prev = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_redisplay_end_trigger (struct window *w, Lisp_Object val)
|
|
{
|
|
w->redisplay_end_trigger = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_new_pixel (struct window *w, Lisp_Object val)
|
|
{
|
|
w->new_pixel = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_vertical_scroll_bar (struct window *w, Lisp_Object val)
|
|
{
|
|
w->vertical_scroll_bar = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_horizontal_scroll_bar (struct window *w, Lisp_Object val)
|
|
{
|
|
w->horizontal_scroll_bar = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_horizontal_scroll_bar_type (struct window *w, Lisp_Object val)
|
|
{
|
|
w->horizontal_scroll_bar_type = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_prev_buffers (struct window *w, Lisp_Object val)
|
|
{
|
|
w->prev_buffers = val;
|
|
}
|
|
|
|
INLINE void
|
|
wset_next_buffers (struct window *w, Lisp_Object val)
|
|
{
|
|
w->next_buffers = val;
|
|
}
|
|
|
|
/* True if W is a minibuffer window. */
|
|
#define MINI_WINDOW_P(W) ((W)->mini)
|
|
|
|
/* 1 if W is a non-only minibuffer window. */
|
|
/* The first check is redundant and the second overly complicated. */
|
|
#define MINI_NON_ONLY_WINDOW_P(W) \
|
|
(MINI_WINDOW_P (W) \
|
|
&& (EQ (W->prev, FRAME_ROOT_WINDOW (WINDOW_XFRAME (W)))))
|
|
|
|
/* 1 if W is a minibuffer-only window. */
|
|
#define MINI_ONLY_WINDOW_P(W) \
|
|
(MINI_WINDOW_P (W) && NILP (W->prev))
|
|
|
|
/* General window layout:
|
|
|
|
LEFT_EDGE_COL RIGHT_EDGE_COL
|
|
| |
|
|
| |
|
|
| BOX_LEFT_EDGE_COL |
|
|
| | BOX_RIGHT_EDGE_COL |
|
|
| | | |
|
|
v v v v
|
|
<-><-><---><-----------><---><-><->
|
|
^ ^ ^ ^ ^ ^ ^
|
|
| | | | | | |
|
|
| | | | | | +-- RIGHT_SCROLL_BAR_COLS
|
|
| | | | | +----- RIGHT_FRINGE_WIDTH
|
|
| | | | +--------- RIGHT_MARGIN_COLS
|
|
| | | |
|
|
| | | +------------------ TEXT_AREA_COLS
|
|
| | |
|
|
| | +--------------------------- LEFT_MARGIN_COLS
|
|
| +------------------------------- LEFT_FRINGE_WIDTH
|
|
+---------------------------------- LEFT_SCROLL_BAR_COLS
|
|
|
|
*/
|
|
|
|
|
|
/* A handy macro. */
|
|
|
|
/* Non-nil if W is leaf (carry the buffer). */
|
|
|
|
#define WINDOW_LEAF_P(W) \
|
|
(BUFFERP ((W)->contents))
|
|
|
|
/* True if W is a member of horizontal combination. */
|
|
|
|
#define WINDOW_HORIZONTAL_COMBINATION_P(W) \
|
|
(WINDOWP ((W)->contents) && (W)->horizontal)
|
|
|
|
/* True if W is a member of vertical combination. */
|
|
|
|
#define WINDOW_VERTICAL_COMBINATION_P(W) \
|
|
(WINDOWP ((W)->contents) && !(W)->horizontal)
|
|
|
|
/* WINDOW's XFRAME. */
|
|
#define WINDOW_XFRAME(W) (XFRAME (WINDOW_FRAME ((W))))
|
|
|
|
/* Whether WINDOW is a pseudo window. */
|
|
#define WINDOW_PSEUDO_P(W) ((W)->pseudo_window_p)
|
|
|
|
/* Return the canonical column width of the frame of window W. */
|
|
#define WINDOW_FRAME_COLUMN_WIDTH(W) \
|
|
(FRAME_COLUMN_WIDTH (WINDOW_XFRAME ((W))))
|
|
|
|
/* Return the canonical column width of the frame of window W. */
|
|
#define WINDOW_FRAME_LINE_HEIGHT(W) \
|
|
(FRAME_LINE_HEIGHT (WINDOW_XFRAME ((W))))
|
|
|
|
/* Return the pixel width of window W.
|
|
This includes scroll bars and fringes. */
|
|
#define WINDOW_PIXEL_WIDTH(W) (W)->pixel_width
|
|
|
|
/* Return the pixel height of window W.
|
|
This includes header and mode lines, if any. */
|
|
#define WINDOW_PIXEL_HEIGHT(W) (W)->pixel_height
|
|
|
|
/* Return the width of window W in canonical column units.
|
|
This includes scroll bars and fringes.
|
|
This value is adjusted such that the sum of the widths of all child
|
|
windows equals the width of their parent window. */
|
|
#define WINDOW_TOTAL_COLS(W) (W)->total_cols
|
|
|
|
/* Return the height of window W in canonical line units.
|
|
This includes header and mode lines, if any.
|
|
This value is adjusted such that the sum of the heights of all child
|
|
windows equals the height of their parent window. */
|
|
#define WINDOW_TOTAL_LINES(W) (W)->total_lines
|
|
|
|
/* The smallest acceptable dimensions for a window. Anything smaller
|
|
might crash Emacs. */
|
|
#define MIN_SAFE_WINDOW_WIDTH (2)
|
|
|
|
#define MIN_SAFE_WINDOW_PIXEL_WIDTH(W) \
|
|
(2 * WINDOW_FRAME_COLUMN_WIDTH (W))
|
|
|
|
#define MIN_SAFE_WINDOW_HEIGHT (1)
|
|
|
|
#define MIN_SAFE_WINDOW_PIXEL_HEIGHT(W) \
|
|
(WINDOW_FRAME_LINE_HEIGHT (W))
|
|
|
|
/* Width of right divider of window W. */
|
|
#define WINDOW_RIGHT_DIVIDER_WIDTH(W) \
|
|
((WINDOW_RIGHTMOST_P (W) || MINI_WINDOW_P (W)) \
|
|
? 0 \
|
|
: FRAME_RIGHT_DIVIDER_WIDTH (WINDOW_XFRAME (W)))
|
|
|
|
/* Return the canonical frame column at which window W starts.
|
|
This includes a left-hand scroll bar, if any. */
|
|
|
|
#define WINDOW_LEFT_EDGE_COL(W) (W)->left_col
|
|
|
|
/* Return the canonical frame column before which window W ends.
|
|
This includes a right-hand scroll bar, if any. */
|
|
|
|
#define WINDOW_RIGHT_EDGE_COL(W) \
|
|
(WINDOW_LEFT_EDGE_COL (W) + WINDOW_TOTAL_COLS (W))
|
|
|
|
/* Return the canonical frame line at which window W starts.
|
|
This includes a header line, if any. */
|
|
|
|
#define WINDOW_TOP_EDGE_LINE(W) (W)->top_line
|
|
|
|
/* Return the canonical frame line before which window W ends.
|
|
This includes a mode line, if any. */
|
|
|
|
#define WINDOW_BOTTOM_EDGE_LINE(W) \
|
|
(WINDOW_TOP_EDGE_LINE (W) + WINDOW_TOTAL_LINES (W))
|
|
|
|
/* Return the left pixel edge at which window W starts.
|
|
This includes a left-hand scroll bar, if any. */
|
|
#define WINDOW_LEFT_PIXEL_EDGE(W) (W)->pixel_left
|
|
|
|
/* Return the right pixel edge before which window W ends.
|
|
This includes a right-hand scroll bar, if any. */
|
|
#define WINDOW_RIGHT_PIXEL_EDGE(W) \
|
|
(WINDOW_LEFT_PIXEL_EDGE (W) + WINDOW_PIXEL_WIDTH (W))
|
|
|
|
/* Return the top pixel edge at which window W starts.
|
|
This includes a header line, if any. */
|
|
#define WINDOW_TOP_PIXEL_EDGE(W) (W)->pixel_top
|
|
|
|
/* Return the bottom pixel edge before which window W ends.
|
|
This includes a mode line, if any. */
|
|
#define WINDOW_BOTTOM_PIXEL_EDGE(W) \
|
|
(WINDOW_TOP_PIXEL_EDGE (W) + WINDOW_PIXEL_HEIGHT (W))
|
|
|
|
/* Return the frame x-position at which window W starts.
|
|
This includes a left-hand scroll bar, if any. */
|
|
|
|
#define WINDOW_LEFT_EDGE_X(W) \
|
|
(FRAME_INTERNAL_BORDER_WIDTH (WINDOW_XFRAME (W)) \
|
|
+ WINDOW_LEFT_PIXEL_EDGE (W))
|
|
|
|
/* Return the frame x- position before which window W ends.
|
|
This includes a right-hand scroll bar, if any. */
|
|
|
|
#define WINDOW_RIGHT_EDGE_X(W) \
|
|
(FRAME_INTERNAL_BORDER_WIDTH (WINDOW_XFRAME (W)) \
|
|
+ WINDOW_RIGHT_PIXEL_EDGE (W))
|
|
|
|
/* True if W is a menu bar window. */
|
|
|
|
#if defined (HAVE_X_WINDOWS) && ! defined (USE_X_TOOLKIT) && ! defined (USE_GTK)
|
|
#define WINDOW_MENU_BAR_P(W) \
|
|
(WINDOWP (WINDOW_XFRAME (W)->menu_bar_window) \
|
|
&& (W) == XWINDOW (WINDOW_XFRAME (W)->menu_bar_window))
|
|
#else
|
|
/* No menu bar windows if X toolkit is in use. */
|
|
#define WINDOW_MENU_BAR_P(W) false
|
|
#endif
|
|
|
|
/* True if W is a tool bar window. */
|
|
#if defined (HAVE_WINDOW_SYSTEM) && ! defined (USE_GTK) && ! defined (HAVE_NS)
|
|
#define WINDOW_TOOL_BAR_P(W) \
|
|
(WINDOWP (WINDOW_XFRAME (W)->tool_bar_window) \
|
|
&& (W) == XWINDOW (WINDOW_XFRAME (W)->tool_bar_window))
|
|
#else
|
|
#define WINDOW_TOOL_BAR_P(W) false
|
|
#endif
|
|
|
|
/* Return the frame y-position at which window W starts.
|
|
This includes a header line, if any.
|
|
|
|
PXW: With a menu or tool bar this is not symmetric to the _X values
|
|
since it _does_ include the internal border width. */
|
|
#define WINDOW_TOP_EDGE_Y(W) \
|
|
(((WINDOW_MENU_BAR_P (W) || WINDOW_TOOL_BAR_P (W)) \
|
|
? 0 : FRAME_INTERNAL_BORDER_WIDTH (WINDOW_XFRAME (W))) \
|
|
+ WINDOW_TOP_PIXEL_EDGE (W))
|
|
|
|
/* Return the frame y-position before which window W ends.
|
|
This includes a mode line, if any. */
|
|
#define WINDOW_BOTTOM_EDGE_Y(W) \
|
|
(((WINDOW_MENU_BAR_P (W) || WINDOW_TOOL_BAR_P (W)) \
|
|
? 0 : FRAME_INTERNAL_BORDER_WIDTH (WINDOW_XFRAME (W))) \
|
|
+ WINDOW_BOTTOM_PIXEL_EDGE (W))
|
|
|
|
/* True if window W takes up the full width of its frame. */
|
|
#define WINDOW_FULL_WIDTH_P(W) \
|
|
(WINDOW_PIXEL_WIDTH (W) \
|
|
== (WINDOW_PIXEL_WIDTH \
|
|
(XWINDOW (FRAME_ROOT_WINDOW (WINDOW_XFRAME (W)))))) \
|
|
|
|
/* True if window W's has no other windows to its left in its frame. */
|
|
|
|
#define WINDOW_LEFTMOST_P(W) \
|
|
(WINDOW_LEFT_PIXEL_EDGE (W) == 0)
|
|
|
|
/* True if window W's has no other windows above in its frame. */
|
|
#define WINDOW_TOPMOST_P(W) \
|
|
(WINDOW_TOP_PIXEL_EDGE (W) == 0)
|
|
|
|
/* True if window W's has no other windows to its right in its frame. */
|
|
#define WINDOW_RIGHTMOST_P(W) \
|
|
(WINDOW_RIGHT_PIXEL_EDGE (W) \
|
|
== (WINDOW_RIGHT_PIXEL_EDGE \
|
|
(XWINDOW (FRAME_ROOT_WINDOW (WINDOW_XFRAME (W)))))) \
|
|
|
|
/* True if window W's has no other windows below it in its frame
|
|
(the minibuffer window is not counted in this respect). */
|
|
#define WINDOW_BOTTOMMOST_P(W) \
|
|
(WINDOW_BOTTOM_PIXEL_EDGE (W) \
|
|
== (WINDOW_BOTTOM_PIXEL_EDGE \
|
|
(XWINDOW (FRAME_ROOT_WINDOW (WINDOW_XFRAME (W)))))) \
|
|
|
|
/* Return the frame column at which the text (or left fringe) in
|
|
window W starts. This is different from the `LEFT_EDGE' because it
|
|
does not include a left-hand scroll bar if any. */
|
|
#define WINDOW_BOX_LEFT_EDGE_COL(W) \
|
|
(WINDOW_LEFT_EDGE_COL (W) \
|
|
+ WINDOW_LEFT_SCROLL_BAR_COLS (W))
|
|
|
|
/* Return the pixel value where the text (or left fringe) in
|
|
window W starts. This is different from the `LEFT_EDGE' because it
|
|
does not include a left-hand scroll bar if any. */
|
|
#define WINDOW_BOX_LEFT_PIXEL_EDGE(W) \
|
|
(WINDOW_LEFT_PIXEL_EDGE (W) \
|
|
+ WINDOW_LEFT_SCROLL_BAR_AREA_WIDTH (W))
|
|
|
|
/* Return the window column before which the text in window W ends.
|
|
This is different from WINDOW_RIGHT_EDGE_COL because it does not
|
|
include a scroll bar or window-separating line on the right edge. */
|
|
#define WINDOW_BOX_RIGHT_EDGE_COL(W) \
|
|
(WINDOW_RIGHT_EDGE_COL (W) \
|
|
- WINDOW_RIGHT_SCROLL_BAR_COLS (W))
|
|
|
|
/* Return the pixel value before which the text in window W ends. This
|
|
is different from the `RIGHT_EDGE' because it does not include a
|
|
right-hand scroll bar or window-separating line on the right
|
|
edge. */
|
|
#define WINDOW_BOX_RIGHT_PIXEL_EDGE(W) \
|
|
(WINDOW_RIGHT_PIXEL_EDGE (W) \
|
|
- WINDOW_RIGHT_DIVIDER_WIDTH (W) \
|
|
- WINDOW_RIGHT_SCROLL_BAR_AREA_WIDTH (W))
|
|
|
|
/* Return the frame position at which the text (or left fringe) in
|
|
window W starts. This is different from the `LEFT_EDGE' because it
|
|
does not include a left-hand scroll bar if any. */
|
|
#define WINDOW_BOX_LEFT_EDGE_X(W) \
|
|
(FRAME_INTERNAL_BORDER_WIDTH (WINDOW_XFRAME (W)) \
|
|
+ WINDOW_BOX_LEFT_PIXEL_EDGE (W))
|
|
|
|
/* Return the window column before which the text in window W ends.
|
|
This is different from WINDOW_RIGHT_EDGE_COL because it does not
|
|
include a scroll bar or window-separating line on the right edge. */
|
|
#define WINDOW_BOX_RIGHT_EDGE_X(W) \
|
|
(FRAME_INTERNAL_BORDER_WIDTH (WINDOW_XFRAME (W)) \
|
|
+ WINDOW_BOX_RIGHT_PIXEL_EDGE (W))
|
|
|
|
/* Widths of marginal areas in columns. */
|
|
#define WINDOW_LEFT_MARGIN_COLS(W) (W->left_margin_cols)
|
|
|
|
#define WINDOW_RIGHT_MARGIN_COLS(W) (W->right_margin_cols)
|
|
|
|
#define WINDOW_MARGINS_COLS(W) \
|
|
(WINDOW_LEFT_MARGIN_COLS (W) \
|
|
+ WINDOW_RIGHT_MARGIN_COLS (W))
|
|
|
|
/* Widths of marginal areas in pixels. */
|
|
#define WINDOW_LEFT_MARGIN_WIDTH(W) \
|
|
(W->left_margin_cols * WINDOW_FRAME_COLUMN_WIDTH (W))
|
|
|
|
#define WINDOW_RIGHT_MARGIN_WIDTH(W) \
|
|
(W->right_margin_cols * WINDOW_FRAME_COLUMN_WIDTH (W))
|
|
|
|
#define WINDOW_MARGINS_WIDTH(W) \
|
|
(WINDOW_LEFT_MARGIN_WIDTH (W) \
|
|
+ WINDOW_RIGHT_MARGIN_WIDTH (W))
|
|
|
|
/* Pixel-widths of fringes. */
|
|
#define WINDOW_LEFT_FRINGE_WIDTH(W) \
|
|
(W->left_fringe_width >= 0 \
|
|
? W->left_fringe_width \
|
|
: FRAME_LEFT_FRINGE_WIDTH (WINDOW_XFRAME (W)))
|
|
|
|
#define WINDOW_RIGHT_FRINGE_WIDTH(W) \
|
|
(W->right_fringe_width >= 0 \
|
|
? W->right_fringe_width \
|
|
: FRAME_RIGHT_FRINGE_WIDTH (WINDOW_XFRAME (W)))
|
|
|
|
#define WINDOW_FRINGES_WIDTH(W) \
|
|
(WINDOW_LEFT_FRINGE_WIDTH (W) + WINDOW_RIGHT_FRINGE_WIDTH (W))
|
|
|
|
/* Are fringes outside display margins in window W. */
|
|
#define WINDOW_HAS_FRINGES_OUTSIDE_MARGINS(W) \
|
|
((W)->fringes_outside_margins)
|
|
|
|
/* Say whether vertical scroll bars are currently enabled for window W,
|
|
and which side they are on. */
|
|
#define WINDOW_VERTICAL_SCROLL_BAR_TYPE(W) \
|
|
(WINDOW_PSEUDO_P (W) \
|
|
? vertical_scroll_bar_none \
|
|
: EQ (W->vertical_scroll_bar_type, Qt) \
|
|
? FRAME_VERTICAL_SCROLL_BAR_TYPE (WINDOW_XFRAME (W)) \
|
|
: EQ (W->vertical_scroll_bar_type, Qleft) \
|
|
? vertical_scroll_bar_left \
|
|
: EQ (W->vertical_scroll_bar_type, Qright) \
|
|
? vertical_scroll_bar_right \
|
|
: vertical_scroll_bar_none)
|
|
|
|
#define WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_LEFT(W) \
|
|
(WINDOW_VERTICAL_SCROLL_BAR_TYPE (W) == vertical_scroll_bar_left)
|
|
|
|
#define WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_RIGHT(W) \
|
|
(WINDOW_VERTICAL_SCROLL_BAR_TYPE (W) == vertical_scroll_bar_right)
|
|
|
|
#define WINDOW_HAS_VERTICAL_SCROLL_BAR(W) \
|
|
(WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_LEFT (W) \
|
|
|| WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_RIGHT (W))
|
|
|
|
/* Say whether horizontal scroll bars are currently enabled for window
|
|
W. Horizontal scrollbars exist for toolkit versions only. */
|
|
#if defined (USE_X_TOOLKIT) || defined (USE_GTK) || defined (HAVE_NTGUI)
|
|
#define WINDOW_HAS_HORIZONTAL_SCROLL_BAR(W) \
|
|
((WINDOW_PSEUDO_P (W) || MINI_NON_ONLY_WINDOW_P (W)) \
|
|
? false \
|
|
: EQ (W->horizontal_scroll_bar_type, Qt) \
|
|
? FRAME_HAS_HORIZONTAL_SCROLL_BARS (WINDOW_XFRAME (W)) \
|
|
: EQ (W->horizontal_scroll_bar_type, Qbottom) \
|
|
? true \
|
|
: false)
|
|
#else
|
|
#define WINDOW_HAS_HORIZONTAL_SCROLL_BAR(W) false
|
|
#endif
|
|
|
|
/* Width that a scroll bar in window W should have, if there is one.
|
|
Measured in pixels. If scroll bars are turned off, this is still
|
|
nonzero. */
|
|
#define WINDOW_CONFIG_SCROLL_BAR_WIDTH(W) \
|
|
(W->scroll_bar_width >= 0 \
|
|
? W->scroll_bar_width \
|
|
: FRAME_CONFIG_SCROLL_BAR_WIDTH (WINDOW_XFRAME (W)))
|
|
|
|
/* Width that a scroll bar in window W should have, if there is one.
|
|
Measured in columns (characters). If scroll bars are turned off,
|
|
this is still nonzero. */
|
|
#define WINDOW_CONFIG_SCROLL_BAR_COLS(W) \
|
|
(W->scroll_bar_width >= 0 \
|
|
? ((W->scroll_bar_width \
|
|
+ WINDOW_FRAME_COLUMN_WIDTH (W) - 1) \
|
|
/ WINDOW_FRAME_COLUMN_WIDTH (W)) \
|
|
: FRAME_CONFIG_SCROLL_BAR_COLS (WINDOW_XFRAME (W)))
|
|
|
|
/* Width of left scroll bar in window W, measured in columns
|
|
(characters). If scroll bars are on the right in this frame, or
|
|
there are no scroll bars, value is 0. */
|
|
#define WINDOW_LEFT_SCROLL_BAR_COLS(W) \
|
|
(WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_LEFT (W) \
|
|
? (WINDOW_CONFIG_SCROLL_BAR_COLS (W)) \
|
|
: 0)
|
|
|
|
/* Width of right scroll bar in window W, measured in columns
|
|
(characters). If scroll bars are on the left in this frame, or there
|
|
are no scroll bars, value is 0. */
|
|
#define WINDOW_RIGHT_SCROLL_BAR_COLS(W) \
|
|
(WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_RIGHT (W) \
|
|
? WINDOW_CONFIG_SCROLL_BAR_COLS (W) \
|
|
: 0)
|
|
|
|
/* Width of a scroll bar in window W, measured in columns. */
|
|
#define WINDOW_SCROLL_BAR_COLS(W) \
|
|
(WINDOW_HAS_VERTICAL_SCROLL_BAR (W) \
|
|
? WINDOW_CONFIG_SCROLL_BAR_COLS (W) \
|
|
: 0)
|
|
|
|
/* Width of a left scroll bar area in window W, measured in pixels. */
|
|
#define WINDOW_LEFT_SCROLL_BAR_AREA_WIDTH(W) \
|
|
(WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_LEFT (W) \
|
|
? WINDOW_CONFIG_SCROLL_BAR_WIDTH (W) \
|
|
: 0)
|
|
|
|
/* Width of a right scroll bar area in window W, measured in pixels. */
|
|
#define WINDOW_RIGHT_SCROLL_BAR_AREA_WIDTH(W) \
|
|
(WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_RIGHT (W) \
|
|
? WINDOW_CONFIG_SCROLL_BAR_WIDTH (W) \
|
|
: 0)
|
|
|
|
/* Width of scroll bar area in window W, measured in pixels. */
|
|
#define WINDOW_SCROLL_BAR_AREA_WIDTH(W) \
|
|
(WINDOW_HAS_VERTICAL_SCROLL_BAR (W) \
|
|
? WINDOW_CONFIG_SCROLL_BAR_WIDTH (W) \
|
|
: 0)
|
|
|
|
/* Return the frame position where the vertical scroll bar of window W
|
|
starts. */
|
|
#define WINDOW_SCROLL_BAR_AREA_X(W) \
|
|
(WINDOW_HAS_VERTICAL_SCROLL_BAR_ON_RIGHT (W) \
|
|
? WINDOW_BOX_RIGHT_EDGE_X (W) \
|
|
: WINDOW_LEFT_EDGE_X (W))
|
|
|
|
/* Width of bottom divider of window W. */
|
|
#define WINDOW_BOTTOM_DIVIDER_WIDTH(W) \
|
|
(((WINDOW_BOTTOMMOST_P (W) \
|
|
&& NILP ((XWINDOW (FRAME_ROOT_WINDOW \
|
|
(WINDOW_XFRAME (W))))->next)) \
|
|
|| EQ ((W)->prev, FRAME_ROOT_WINDOW (WINDOW_XFRAME (W))) \
|
|
|| (W)->pseudo_window_p) \
|
|
? 0 \
|
|
: FRAME_BOTTOM_DIVIDER_WIDTH (WINDOW_XFRAME (W)))
|
|
|
|
/* Height that a scroll bar in window W should have, if there is one.
|
|
Measured in pixels. If scroll bars are turned off, this is still
|
|
nonzero. */
|
|
#define WINDOW_CONFIG_SCROLL_BAR_HEIGHT(W) \
|
|
(W->scroll_bar_height >= 0 \
|
|
? W->scroll_bar_height \
|
|
: FRAME_CONFIG_SCROLL_BAR_HEIGHT (WINDOW_XFRAME (W)))
|
|
|
|
/* Height that a scroll bar in window W should have, if there is one.
|
|
Measured in lines (characters). If scroll bars are turned off, this
|
|
is still nonzero. */
|
|
#define WINDOW_CONFIG_SCROLL_BAR_LINES(W) \
|
|
(W->scroll_bar_height >= 0 \
|
|
? ((W->scroll_bar_height \
|
|
+ WINDOW_FRAME_LINE_HEIGHT (W) - 1) \
|
|
/ WINDOW_FRAME_LINE_HEIGHT (W)) \
|
|
: FRAME_CONFIG_SCROLL_BAR_LINES (WINDOW_XFRAME (W)))
|
|
|
|
/* Height of a scroll bar in window W, measured in columns. */
|
|
#define WINDOW_SCROLL_BAR_LINES(W) \
|
|
(WINDOW_HAS_HORIZONTAL_SCROLL_BAR (W) \
|
|
? WINDOW_CONFIG_SCROLL_BAR_LINES (W) \
|
|
: 0)
|
|
|
|
/* Height of scroll bar area in window W, measured in pixels. */
|
|
#define WINDOW_SCROLL_BAR_AREA_HEIGHT(W) \
|
|
(WINDOW_HAS_HORIZONTAL_SCROLL_BAR (W) \
|
|
? WINDOW_CONFIG_SCROLL_BAR_HEIGHT (W) \
|
|
: 0)
|
|
|
|
/* Height in pixels, and in lines, of the mode line.
|
|
May be zero if W doesn't have a mode line. */
|
|
#define WINDOW_MODE_LINE_HEIGHT(W) \
|
|
(WINDOW_WANTS_MODELINE_P ((W)) \
|
|
? CURRENT_MODE_LINE_HEIGHT (W) \
|
|
: 0)
|
|
|
|
#define WINDOW_MODE_LINE_LINES(W) \
|
|
(!! WINDOW_WANTS_MODELINE_P (W))
|
|
|
|
/* Height in pixels, and in lines, of the header line.
|
|
Zero if W doesn't have a header line. */
|
|
#define WINDOW_HEADER_LINE_HEIGHT(W) \
|
|
(WINDOW_WANTS_HEADER_LINE_P (W) \
|
|
? CURRENT_HEADER_LINE_HEIGHT (W) \
|
|
: 0)
|
|
|
|
#define WINDOW_HEADER_LINE_LINES(W) \
|
|
(!! WINDOW_WANTS_HEADER_LINE_P (W))
|
|
|
|
/* Pixel height of window W without mode line, bottom scroll bar and
|
|
bottom divider. */
|
|
#define WINDOW_BOX_HEIGHT_NO_MODE_LINE(W) \
|
|
(WINDOW_PIXEL_HEIGHT (W) \
|
|
- WINDOW_BOTTOM_DIVIDER_WIDTH (W) \
|
|
- WINDOW_SCROLL_BAR_AREA_HEIGHT (W) \
|
|
- WINDOW_MODE_LINE_HEIGHT (W))
|
|
|
|
/* Pixel height of window W without mode and header line and bottom
|
|
divider. */
|
|
#define WINDOW_BOX_TEXT_HEIGHT(W) \
|
|
(WINDOW_PIXEL_HEIGHT ((W)) \
|
|
- WINDOW_BOTTOM_DIVIDER_WIDTH (W) \
|
|
- WINDOW_SCROLL_BAR_AREA_HEIGHT (W) \
|
|
- WINDOW_MODE_LINE_HEIGHT (W) \
|
|
- WINDOW_HEADER_LINE_HEIGHT (W))
|
|
|
|
/* Return the frame position where the horizontal scroll bar of window W
|
|
starts. */
|
|
#define WINDOW_SCROLL_BAR_AREA_Y(W) \
|
|
(WINDOW_TOP_EDGE_Y (W) \
|
|
+ (WINDOW_HAS_HORIZONTAL_SCROLL_BAR (W) \
|
|
? WINDOW_BOX_HEIGHT_NO_MODE_LINE (W) : 0))
|
|
|
|
/* Convert window W relative pixel X to frame pixel coordinates. */
|
|
#define WINDOW_TO_FRAME_PIXEL_X(W, X) \
|
|
((X) + WINDOW_BOX_LEFT_EDGE_X ((W)))
|
|
|
|
/* Convert window W relative pixel Y to frame pixel coordinates. */
|
|
#define WINDOW_TO_FRAME_PIXEL_Y(W, Y) \
|
|
((Y) + WINDOW_TOP_EDGE_Y (W))
|
|
|
|
/* Convert frame relative pixel X to window relative pixel X. */
|
|
#define FRAME_TO_WINDOW_PIXEL_X(W, X) \
|
|
((X) - WINDOW_BOX_LEFT_EDGE_X ((W)))
|
|
|
|
/* Convert frame relative pixel Y to window relative pixel Y. */
|
|
#define FRAME_TO_WINDOW_PIXEL_Y(W, Y) \
|
|
((Y) - WINDOW_TOP_EDGE_Y (W))
|
|
|
|
/* Convert a text area relative x-position in window W to frame X
|
|
pixel coordinates. */
|
|
#define WINDOW_TEXT_TO_FRAME_PIXEL_X(W, X) \
|
|
(window_box_left ((W), TEXT_AREA) + (X))
|
|
|
|
/* This is the window in which the terminal's cursor should be left when
|
|
nothing is being done with it. This must always be a leaf window, and its
|
|
buffer is selected by the top level editing loop at the end of each command.
|
|
|
|
This value is always the same as FRAME_SELECTED_WINDOW (selected_frame). */
|
|
|
|
extern Lisp_Object selected_window;
|
|
|
|
/* This is a time stamp for window selection, so we can find the least
|
|
recently used window. Its only users are Fselect_window,
|
|
init_window_once, and make_frame. */
|
|
|
|
extern int window_select_count;
|
|
|
|
/* The minibuffer window of the selected frame.
|
|
Note that you cannot test for minibufferness of an arbitrary window
|
|
by comparing against this; use the MINI_WINDOW_P macro instead. */
|
|
|
|
extern Lisp_Object minibuf_window;
|
|
|
|
/* Non-nil means it is the window whose mode line should be
|
|
shown as the selected window when the minibuffer is selected. */
|
|
|
|
extern Lisp_Object minibuf_selected_window;
|
|
|
|
extern Lisp_Object make_window (void);
|
|
extern Lisp_Object window_from_coordinates (struct frame *, int, int,
|
|
enum window_part *, bool);
|
|
extern void resize_frame_windows (struct frame *, int, bool, bool);
|
|
extern void restore_window_configuration (Lisp_Object);
|
|
extern void delete_all_child_windows (Lisp_Object);
|
|
extern void grow_mini_window (struct window *, int, bool);
|
|
extern void shrink_mini_window (struct window *, bool);
|
|
extern int window_relative_x_coord (struct window *, enum window_part, int);
|
|
|
|
void run_window_configuration_change_hook (struct frame *f);
|
|
|
|
/* Make WINDOW display BUFFER. RUN_HOOKS_P non-zero means it's allowed
|
|
to run hooks. See make_frame for a case where it's not allowed. */
|
|
|
|
void set_window_buffer (Lisp_Object window, Lisp_Object buffer,
|
|
bool run_hooks_p, bool keep_margins_p);
|
|
|
|
/* This is the window where the echo area message was displayed. It
|
|
is always a minibuffer window, but it may not be the same window
|
|
currently active as a minibuffer. */
|
|
|
|
extern Lisp_Object echo_area_window;
|
|
|
|
/* Depth in recursive edits. */
|
|
|
|
extern EMACS_INT command_loop_level;
|
|
|
|
/* Depth in minibuffer invocations. */
|
|
|
|
extern EMACS_INT minibuf_level;
|
|
|
|
/* Non-zero if we should redraw the mode lines on the next redisplay.
|
|
Usually set to a unique small integer so we can track the main causes of
|
|
full redisplays in `redisplay--mode-lines-cause'. */
|
|
|
|
extern int update_mode_lines;
|
|
|
|
/* Nonzero if window sizes or contents have changed since last
|
|
redisplay that finished. Usually set to a unique small integer so
|
|
we can track the main causes of full redisplays in
|
|
`redisplay--all-windows-cause'. */
|
|
|
|
extern int windows_or_buffers_changed;
|
|
|
|
/* The main redisplay routine usually only redisplays the selected-window,
|
|
so when something's changed elsewhere, we call one of the functions below
|
|
to indicate which other windows might also need to be redisplayed. */
|
|
|
|
extern void wset_redisplay (struct window *w);
|
|
extern void fset_redisplay (struct frame *f);
|
|
extern void bset_redisplay (struct buffer *b);
|
|
extern void bset_update_mode_line (struct buffer *b);
|
|
/* Call this to tell redisplay to look for other windows than selected-window
|
|
that need to be redisplayed. Calling one of the *set_redisplay functions
|
|
above already does it, so it's only needed in unusual cases. */
|
|
extern void redisplay_other_windows (void);
|
|
|
|
/* Return a pointer to the glyph W's physical cursor is on. Value is
|
|
null if W's current matrix is invalid, so that no meaningful glyph
|
|
can be returned. */
|
|
|
|
struct glyph *get_phys_cursor_glyph (struct window *w);
|
|
|
|
/* Value is non-zero if WINDOW is a valid window. */
|
|
#define WINDOW_VALID_P(WINDOW) \
|
|
(WINDOWP (WINDOW) && !NILP (XWINDOW (WINDOW)->contents)) \
|
|
|
|
/* A window of any sort, leaf or interior, is "valid" if its
|
|
contents slot is non-nil. */
|
|
#define CHECK_VALID_WINDOW(WINDOW) \
|
|
CHECK_TYPE (WINDOW_VALID_P (WINDOW), Qwindow_valid_p, WINDOW)
|
|
|
|
/* Value is non-zero if WINDOW is a live window. */
|
|
#define WINDOW_LIVE_P(WINDOW) \
|
|
(WINDOWP (WINDOW) && BUFFERP (XWINDOW (WINDOW)->contents))
|
|
|
|
/* A window is "live" if and only if it shows a buffer. */
|
|
#define CHECK_LIVE_WINDOW(WINDOW) \
|
|
CHECK_TYPE (WINDOW_LIVE_P (WINDOW), Qwindow_live_p, WINDOW)
|
|
|
|
/* These used to be in lisp.h. */
|
|
extern Lisp_Object Qwindow_live_p;
|
|
extern Lisp_Object Vwindow_list;
|
|
|
|
extern Lisp_Object window_list (void);
|
|
extern struct window *decode_live_window (Lisp_Object);
|
|
extern struct window *decode_any_window (Lisp_Object);
|
|
extern bool compare_window_configurations (Lisp_Object, Lisp_Object, bool);
|
|
extern void mark_window_cursors_off (struct window *);
|
|
extern int window_internal_height (struct window *);
|
|
extern int window_body_width (struct window *w, bool);
|
|
extern void temp_output_buffer_show (Lisp_Object);
|
|
extern void replace_buffer_in_windows (Lisp_Object);
|
|
extern void replace_buffer_in_windows_safely (Lisp_Object);
|
|
extern Lisp_Object sanitize_window_sizes (Lisp_Object, Lisp_Object);
|
|
/* This looks like a setter, but it is a bit special. */
|
|
extern void wset_buffer (struct window *, Lisp_Object);
|
|
extern bool window_outdated (struct window *);
|
|
extern void init_window_once (void);
|
|
extern void init_window (void);
|
|
extern void syms_of_window (void);
|
|
extern void keys_of_window (void);
|
|
|
|
/* Move cursor to row/column position VPOS/HPOS, pixel coordinates
|
|
Y/X. HPOS/VPOS are window-relative row and column numbers and X/Y
|
|
are window-relative pixel positions. This is always done during
|
|
window update, so the position is the future output cursor position
|
|
for currently updated window W. */
|
|
|
|
INLINE void
|
|
output_cursor_to (struct window *w, int vpos, int hpos, int y, int x)
|
|
{
|
|
eassert (w);
|
|
w->output_cursor.hpos = hpos;
|
|
w->output_cursor.vpos = vpos;
|
|
w->output_cursor.x = x;
|
|
w->output_cursor.y = y;
|
|
}
|
|
|
|
INLINE_HEADER_END
|
|
|
|
#endif /* not WINDOW_H_INCLUDED */
|