- {
- /* Everything before the `name' slot must be of a non-Lisp_Object type,
- and every slot after `name' must be a Lisp_Object.
-
- Check out mark_buffer (alloc.c) to see why. */
-
- EMACS_INT size;
-
- /* Next buffer, in chain of all buffers including killed buffers.
- This chain is used only for garbage collection, in order to
- collect killed buffers properly.
- Note that vectors and most pseudovectors are all on one chain,
- but buffers are on a separate chain of their own. */
- struct buffer *next;
-
- /* This structure holds the coordinates of the buffer contents
- in ordinary buffers. In indirect buffers, this is not used. */
- struct buffer_text own_text;
-
- /* This points to the `struct buffer_text' that used for this buffer.
- In an ordinary buffer, this is the own_text field above.
- In an indirect buffer, this is the own_text field of another buffer. */
- struct buffer_text *text;
-
- /* Position of point in buffer. */
- int pt;
- /* Index of beginning of accessible range. */
- int begv;
- /* Index of end of accessible range. */
- int zv;
-
- /* In an indirect buffer, this points to the base buffer.
- In an ordinary buffer, it is 0. */
- struct buffer *base_buffer;
-
- /* Flags saying which DEFVAR_PER_BUFFER variables
- are local to this buffer. */
- int local_var_flags;
- /* Set to the modtime of the visited file when read or written.
- -1 means visited file was nonexistent.
- 0 means visited file modtime unknown; in no case complain
- about any mismatch on next save attempt. */
- int modtime;
- /* the value of text->modiff at the last auto-save. */
- int auto_save_modified;
- /* The time at which we detected a failure to auto-save,
- Or -1 if we didn't have a failure. */
- int auto_save_failure_time;
- /* Position in buffer at which display started
- the last time this buffer was displayed. */
- int last_window_start;
-
- /* If the long line scan cache is enabled (i.e. the buffer-local
- variable cache-long-line-scans is non-nil), newline_cache
- points to the newline cache, and width_run_cache points to the
- width run cache.
-
- The newline cache records which stretches of the buffer are
- known *not* to contain newlines, so that they can be skipped
- quickly when we search for newlines.
-
- The width run cache records which stretches of the buffer are
- known to contain characters whose widths are all the same. If
- the width run cache maps a character to a value > 0, that value is
- the character's width; if it maps a character to zero, we don't
- know what its width is. This allows compute_motion to process
- such regions very quickly, using algebra instead of inspecting
- each character. See also width_table, below. */
- struct region_cache *newline_cache;
- struct region_cache *width_run_cache;
-
- /* Everything from here down must be a Lisp_Object */
-
-
- /* The name of this buffer. */
- Lisp_Object name;
- /* The name of the file visited in this buffer, or nil. */
- Lisp_Object filename;
- /* Dir for expanding relative file names. */
- Lisp_Object directory;
- /* True iff this buffer has been backed up (if you write to the
- visited file and it hasn't been backed up, then a backup will
- be made). */
- /* This isn't really used by the C code, so could be deleted. */
- Lisp_Object backed_up;
- /* Length of file when last read or saved.
- This is not in the struct buffer_text
- because it's not used in indirect buffers at all. */
- Lisp_Object save_length;
- /* File name used for auto-saving this buffer.
- This is not in the struct buffer_text
- because it's not used in indirect buffers at all. */
- Lisp_Object auto_save_file_name;
-
- /* Non-nil if buffer read-only. */
- Lisp_Object read_only;
- /* "The mark". This is a marker which may
- point into this buffer or may point nowhere. */
- Lisp_Object mark;
-
- /* Alist of elements (SYMBOL . VALUE-IN-THIS-BUFFER)
- for all per-buffer variables of this buffer. */
- Lisp_Object local_var_alist;
-
- /* Symbol naming major mode (eg, lisp-mode). */
- Lisp_Object major_mode;
- /* Pretty name of major mode (eg, "Lisp"). */
- Lisp_Object mode_name;
- /* Mode line element that controls format of mode line. */
- Lisp_Object mode_line_format;
-
- /* Keys that are bound local to this buffer. */
- Lisp_Object keymap;
- /* This buffer's local abbrev table. */
- Lisp_Object abbrev_table;
- /* This buffer's syntax table. */
- Lisp_Object syntax_table;
-
- /* Values of several buffer-local variables */
- /* tab-width is buffer-local so that redisplay can find it
- in buffers that are not current */
- Lisp_Object case_fold_search;
- Lisp_Object tab_width;
- Lisp_Object fill_column;
- Lisp_Object left_margin;
- /* Function to call when insert space past fill column. */
- Lisp_Object auto_fill_function;
- /* nil: text, t: binary.
- This value is meaningful only on certain operating systems. */
- Lisp_Object buffer_file_type;
-
- /* String of length 256 mapping each char to its lower-case version. */
- Lisp_Object downcase_table;
- /* String of length 256 mapping each char to its upper-case version. */
- Lisp_Object upcase_table;
- /* Translate table for case-folding search. */
- Lisp_Object case_canon_table;
- /* Inverse translate (equivalence class) table for case-folding search. */
- Lisp_Object case_eqv_table;
-
- /* Non-nil means do not display continuation lines. */
- Lisp_Object truncate_lines;
- /* Non-nil means display ctl chars with uparrow. */
- Lisp_Object ctl_arrow;
- /* Non-nil means do selective display;
- see doc string in syms_of_buffer (buffer.c) for details. */
- Lisp_Object selective_display;
+{
+ /* Everything before the `name' slot must be of a non-Lisp_Object type,
+ and every slot after `name' must be a Lisp_Object.
+
+ Check out mark_buffer (alloc.c) to see why. */
+
+ EMACS_INT size;
+
+ /* Next buffer, in chain of all buffers including killed buffers.
+ This chain is used only for garbage collection, in order to
+ collect killed buffers properly.
+ Note that vectors and most pseudovectors are all on one chain,
+ but buffers are on a separate chain of their own. */
+ struct buffer *next;
+
+ /* This structure holds the coordinates of the buffer contents
+ in ordinary buffers. In indirect buffers, this is not used. */
+ struct buffer_text own_text;
+
+ /* This points to the `struct buffer_text' that used for this buffer.
+ In an ordinary buffer, this is the own_text field above.
+ In an indirect buffer, this is the own_text field of another buffer. */
+ struct buffer_text *text;
+
+ /* Char position of point in buffer. */
+ EMACS_INT pt;
+ /* Byte position of point in buffer. */
+ EMACS_INT pt_byte;
+ /* Char position of beginning of accessible range. */
+ EMACS_INT begv;
+ /* Byte position of beginning of accessible range. */
+ EMACS_INT begv_byte;
+ /* Char position of end of accessible range. */
+ EMACS_INT zv;
+ /* Byte position of end of accessible range. */
+ EMACS_INT zv_byte;
+
+ /* In an indirect buffer, this points to the base buffer.
+ In an ordinary buffer, it is 0. */
+ struct buffer *base_buffer;
+
+ /* A non-zero value in slot IDX means that per-buffer variable
+ with index IDX has a local value in this buffer. The index IDX
+ for a buffer-local variable is stored in that variable's slot
+ in buffer_local_flags as a Lisp integer. If the index is -1,
+ this means the variable is always local in all buffers. */
+#define MAX_PER_BUFFER_VARS 50
+ char local_flags[MAX_PER_BUFFER_VARS];
+
+ /* Set to the modtime of the visited file when read or written.
+ -1 means visited file was nonexistent.
+ 0 means visited file modtime unknown; in no case complain
+ about any mismatch on next save attempt. */
+ int modtime;
+ /* The value of text->modiff at the last auto-save. */
+ int auto_save_modified;
+ /* The value of text->modiff at the last display error.
+ Redisplay of this buffer is inhibited until it changes again. */
+ int display_error_modiff;
+ /* The time at which we detected a failure to auto-save,
+ Or -1 if we didn't have a failure. */
+ int auto_save_failure_time;
+ /* Position in buffer at which display started
+ the last time this buffer was displayed. */
+ EMACS_INT last_window_start;
+
+ /* Set nonzero whenever the narrowing is changed in this buffer. */
+ int clip_changed;
+
+ /* If the long line scan cache is enabled (i.e. the buffer-local
+ variable cache-long-line-scans is non-nil), newline_cache
+ points to the newline cache, and width_run_cache points to the
+ width run cache.
+
+ The newline cache records which stretches of the buffer are
+ known *not* to contain newlines, so that they can be skipped
+ quickly when we search for newlines.
+
+ The width run cache records which stretches of the buffer are
+ known to contain characters whose widths are all the same. If
+ the width run cache maps a character to a value > 0, that value is
+ the character's width; if it maps a character to zero, we don't
+ know what its width is. This allows compute_motion to process
+ such regions very quickly, using algebra instead of inspecting
+ each character. See also width_table, below. */
+ struct region_cache *newline_cache;
+ struct region_cache *width_run_cache;
+
+ /* Non-zero means don't use redisplay optimizations for
+ displaying this buffer. */
+ unsigned prevent_redisplay_optimizations_p : 1;
+
+ /* List of overlays that end at or before the current center,
+ in order of end-position. */
+ struct Lisp_Overlay *overlays_before;
+
+ /* List of overlays that end after the current center,
+ in order of start-position. */
+ struct Lisp_Overlay *overlays_after;
+
+ /* Position where the overlay lists are centered. */
+ EMACS_INT overlay_center;
+
+ /* Everything from here down must be a Lisp_Object. */
+
+ /* The name of this buffer. */
+ Lisp_Object name;
+
+ /* The name of the file visited in this buffer, or nil. */
+ Lisp_Object filename;
+ /* Dir for expanding relative file names. */
+ Lisp_Object directory;
+ /* True iff this buffer has been backed up (if you write to the
+ visited file and it hasn't been backed up, then a backup will
+ be made). */
+ /* This isn't really used by the C code, so could be deleted. */
+ Lisp_Object backed_up;
+ /* Length of file when last read or saved.
+ This is not in the struct buffer_text
+ because it's not used in indirect buffers at all. */
+ Lisp_Object save_length;
+ /* File name used for auto-saving this buffer.
+ This is not in the struct buffer_text
+ because it's not used in indirect buffers at all. */
+ Lisp_Object auto_save_file_name;
+
+ /* Non-nil if buffer read-only. */
+ Lisp_Object read_only;
+ /* "The mark". This is a marker which may
+ point into this buffer or may point nowhere. */
+ Lisp_Object mark;
+
+ /* Alist of elements (SYMBOL . VALUE-IN-THIS-BUFFER)
+ for all per-buffer variables of this buffer. */
+ Lisp_Object local_var_alist;
+
+ /* Symbol naming major mode (eg, lisp-mode). */
+ Lisp_Object major_mode;
+ /* Pretty name of major mode (eg, "Lisp"). */
+ Lisp_Object mode_name;
+ /* Mode line element that controls format of mode line. */
+ Lisp_Object mode_line_format;
+
+ /* Changes in the buffer are recorded here for undo.
+ t means don't record anything.
+ This information belongs to the base buffer of an indirect buffer,
+ But we can't store it in the struct buffer_text
+ because local variables have to be right in the struct buffer.
+ So we copy it around in set_buffer_internal.
+ This comes before `name' because it is marked in a special way. */
+ Lisp_Object undo_list;
+
+ /* Analogous to mode_line_format for the line displayed at the top
+ of windows. Nil means don't display that line. */
+ Lisp_Object header_line_format;
+
+ /* Keys that are bound local to this buffer. */
+ Lisp_Object keymap;
+ /* This buffer's local abbrev table. */
+ Lisp_Object abbrev_table;
+ /* This buffer's syntax table. */
+ Lisp_Object syntax_table;
+ /* This buffer's category table. */
+ Lisp_Object category_table;
+
+ /* Values of several buffer-local variables. */
+ /* tab-width is buffer-local so that redisplay can find it
+ in buffers that are not current. */
+ Lisp_Object case_fold_search;
+ Lisp_Object tab_width;
+ Lisp_Object fill_column;
+ Lisp_Object left_margin;
+ /* Function to call when insert space past fill column. */
+ Lisp_Object auto_fill_function;
+ /* nil: text, t: binary.
+ This value is meaningful only on certain operating systems. */
+ /* Actually, we don't need this flag any more because end-of-line
+ is handled correctly according to the buffer-file-coding-system
+ of the buffer. Just keeping it for backward compatibility. */
+ Lisp_Object buffer_file_type;
+
+ /* Case table for case-conversion in this buffer.
+ This char-table maps each char into its lower-case version. */
+ Lisp_Object downcase_table;
+ /* Char-table mapping each char to its upper-case version. */
+ Lisp_Object upcase_table;
+ /* Char-table for conversion for case-folding search. */
+ Lisp_Object case_canon_table;
+ /* Char-table of equivalences for case-folding search. */
+ Lisp_Object case_eqv_table;
+
+ /* Non-nil means do not display continuation lines. */
+ Lisp_Object truncate_lines;
+ /* Non-nil means display ctl chars with uparrow. */
+ Lisp_Object ctl_arrow;
+ /* Non-nil means display text from right to left. */
+ Lisp_Object direction_reversed;
+ /* Non-nil means do selective display;
+ see doc string in syms_of_buffer (buffer.c) for details. */
+ Lisp_Object selective_display;