]> code.delx.au - gnu-emacs/blob - man/display.texi
* display.texi (Faces): Write about mode-line-highlight.
[gnu-emacs] / man / display.texi
1 @c This is part of the Emacs manual.
2 @c Copyright (C) 1985, 86, 87, 93, 94, 95, 1997, 2000, 2001, 2002
3 @c Free Software Foundation, Inc.
4 @c See file emacs.texi for copying conditions.
5 @node Display, Search, Registers, Top
6 @chapter Controlling the Display
7
8 Since only part of a large buffer fits in the window, Emacs tries to
9 show a part that is likely to be interesting. Display-control commands
10 allow you to specify which part of the text you want to see, and how to
11 display it.
12
13 @menu
14 * Faces:: How to change the display style using faces.
15 * Font Lock:: Minor mode for syntactic highlighting using faces.
16 * Highlight Changes:: Using colors to show where you changed the buffer.
17 * Highlight Interactively:: Tell Emacs what text to highlight.
18 * Scrolling:: Moving text up and down in a window.
19 * Horizontal Scrolling:: Moving text left and right in a window.
20 * Fringes:: Enabling or disabling window fringes.
21 * Useless Whitespace:: Showing possibly-spurious trailing whitespace.
22 * Follow Mode:: Follow mode lets two windows scroll as one.
23 * Selective Display:: Hiding lines with lots of indentation.
24 * Optional Mode Line:: Optional mode line display features.
25 * Text Display:: How text characters are normally displayed.
26 * Cursor Display:: Features for displaying the cursor.
27 * Display Custom:: Information on variables for customizing display.
28 @end menu
29
30 @node Faces
31 @section Using Multiple Typefaces
32 @cindex faces
33
34 You can specify various styles for displaying text using
35 @dfn{faces}. Each face can specify various @dfn{face attributes},
36 such as the font family, the height, weight and slant of the
37 characters, the foreground and background color, and underlining or
38 overlining. A face does not have to specify all of these attributes;
39 often it inherits most of them from another face.
40
41 On a window system, all the Emacs face attributes are meaningful.
42 On a character terminal, only some of them work. Some character
43 terminals support inverse video, bold, and underline attributes; some
44 support colors. Character terminals generally do not support changing
45 the height and width or the font family.
46
47 Features which rely on text in multiple faces (such as Font Lock mode)
48 will also work on non-windowed terminals that can display more than one
49 face, whether by colors or underlining and emboldening. This includes
50 the console on GNU/Linux, an @code{xterm} which supports colors, the
51 MS-DOS display (@pxref{MS-DOS}), and the MS-Windows version invoked with
52 the @option{-nw} option. Emacs determines automatically whether the
53 terminal has this capability.
54
55 You control the appearance of a part of the text in the buffer by
56 specifying the face or faces to use for it. The style of display used
57 for any given character is determined by combining the attributes of
58 all the applicable faces specified for that character. Any attribute
59 that isn't specified by these faces is taken from the @code{default} face,
60 whose attributes reflect the default settings of the frame itself.
61
62 Enriched mode, the mode for editing formatted text, includes several
63 commands and menus for specifying faces for text in the buffer.
64 @xref{Format Faces}, for how to specify the font for text in the
65 buffer. @xref{Format Colors}, for how to specify the foreground and
66 background color.
67
68 @cindex face colors, setting
69 @findex set-face-foreground
70 @findex set-face-background
71 To alter the appearance of a face, use the customization buffer.
72 @xref{Face Customization}. You can also use X resources to specify
73 attributes of particular faces (@pxref{Resources}). Alternatively,
74 you can change the foreground and background colors of a specific face
75 with @kbd{M-x set-face-foreground} and @kbd{M-x set-face-background}.
76 These commands prompt in the minibuffer for a face name and a color
77 name, with completion, and then set that face to use the specified
78 color. Changing the colors of the @code{default} face also changes
79 the foreground and background colors on all frames, both existing and
80 those to be created in the future. (You can also set foreground and
81 background colors for the current frame only; see @ref{Frame
82 Parameters}.)
83
84 Emacs can correctly display variable-width fonts, but Emacs commands
85 that calculate width and indentation do not know how to calculate
86 variable widths. This can sometimes lead to incorrect results when
87 you use variable-width fonts. In particular, indentation commands can
88 give inconsistent results, so we recommend you avoid variable-width
89 fonts for editing program source code. Filling will sometimes make
90 lines too long or too short. We plan to address these issues in
91 future Emacs versions.
92
93 @findex list-faces-display
94 To see what faces are currently defined, and what they look like, type
95 @kbd{M-x list-faces-display}. It's possible for a given face to look
96 different in different frames; this command shows the appearance in the
97 frame in which you type it. Here's a list of the standard defined
98 faces:
99
100 @table @code
101 @item default
102 This face is used for ordinary text that doesn't specify any other face.
103 @item mode-line
104 This face is used for the mode line of the currently selected window.
105 By default, it's drawn with shadows for a ``raised'' effect on window
106 systems, and drawn as the inverse of the default face on non-windowed
107 terminals. @xref{Display Custom}.
108 @item mode-line-inactive
109 Like @code{mode-line}, but used for mode lines of the windows other
110 than the selected one (if @code{mode-line-in-non-selected-windows} is
111 non-@code{nil}). This face inherits from @code{mode-line}, so changes
112 in that face affect mode lines in all windows.
113 @item header-line
114 Similar to @code{mode-line} for a window's header line. Most modes
115 don't use the header line, but the Info mode does.
116 @item minibuffer-prompt
117 This face is used for the prompt strings displayed in the minibuffer.
118 @item highlight
119 This face is used for highlighting portions of text, in various modes.
120 For example, mouse-sensitive text is highlighted using this face.
121 @item mode-line-highlight
122 Like @code{highlight}, but used for portions of text on mode lines.
123 @item isearch
124 This face is used for highlighting Isearch matches.
125 @item lazy-highlight
126 This face is used for lazy highlighting of Isearch and Query Replace
127 matches other than the current one.
128 @item region
129 This face is used for displaying a selected region (when Transient Mark
130 mode is enabled---see below).
131 @item secondary-selection
132 This face is used for displaying a secondary X selection (@pxref{Secondary
133 Selection}).
134 @item bold
135 This face uses a bold variant of the default font, if it has one.
136 @item italic
137 This face uses an italic variant of the default font, if it has one.
138 @item bold-italic
139 This face uses a bold italic variant of the default font, if it has one.
140 @item underline
141 This face underlines text.
142 @item fixed-pitch
143 The basic fixed-pitch face.
144 @item fringe
145 @cindex fringe
146 The face for the fringes to the left and right of windows on graphic
147 displays. (The fringes are the narrow portions of the Emacs frame
148 between the text area and the window's right and left borders.)
149 @item scroll-bar
150 This face determines the visual appearance of the scroll bar.
151 @item border
152 This face determines the color of the frame border.
153 @item cursor
154 This face determines the color of the cursor.
155 @item mouse
156 This face determines the color of the mouse pointer.
157 @item tool-bar
158 This is the basic tool-bar face. No text appears in the tool bar, but the
159 colors of this face affect the appearance of tool bar icons.
160 @item tooltip
161 This face is used for tooltips.
162 @item menu
163 This face determines the colors and font of Emacs's menus. Setting the
164 font of LessTif/Motif menus is currently not supported; attempts to set
165 the font are ignored in this case.
166 @item trailing-whitespace
167 The face for highlighting trailing whitespace when
168 @code{show-trailing-whitespace} is non-@code{nil}; see @ref{Useless
169 Whitespace}.
170 @item variable-pitch
171 The basic variable-pitch face.
172 @end table
173
174 @cindex @code{region} face
175 When Transient Mark mode is enabled, the text of the region is
176 highlighted when the mark is active. This uses the face named
177 @code{region}; you can control the style of highlighting by changing the
178 style of this face (@pxref{Face Customization}). @xref{Transient Mark},
179 for more information about Transient Mark mode and activation and
180 deactivation of the mark.
181
182 One easy way to use faces is to turn on Font Lock mode. @xref{Font
183 Lock}, for more information about Font Lock mode and syntactic
184 highlighting.
185
186 You can print out the buffer with the highlighting that appears
187 on your screen using the command @code{ps-print-buffer-with-faces}.
188 @xref{PostScript}.
189
190 @node Font Lock
191 @section Font Lock mode
192 @cindex Font Lock mode
193 @cindex mode, Font Lock
194 @cindex syntax highlighting and coloring
195
196 Font Lock mode is a minor mode, always local to a particular buffer,
197 which highlights (or ``fontifies'') the buffer contents according to
198 the syntax of the text you are editing. It can recognize comments and
199 strings in most languages; in several languages, it can also recognize
200 and properly highlight various other important constructs---for
201 example, names of functions being defined or reserved keywords.
202 Some special modes, such as Occur mode and Info mode, have completely
203 specialized ways of assigning fonts for Font Lock mode.
204
205 @findex font-lock-mode
206 @findex turn-on-font-lock
207 The command @kbd{M-x font-lock-mode} turns Font Lock mode on with
208 positive argument, off with negative or zero argument, and toggles the
209 mode when it has no argument. The function @code{turn-on-font-lock}
210 unconditionally enables Font Lock mode. This is useful in mode-hook
211 functions. For example, to enable Font Lock mode whenever you edit a
212 C file, you can do this:
213
214 @example
215 (add-hook 'c-mode-hook 'turn-on-font-lock)
216 @end example
217
218 @findex global-font-lock-mode
219 @vindex global-font-lock-mode
220 To turn on Font Lock mode automatically in all modes which support
221 it, customize the variable @code{global-font-lock-mode} using the
222 Customize interface (@pxref{Easy Customization}) or use the function
223 @code{global-font-lock-mode} in your @file{.emacs} file, like this:
224
225 @example
226 (global-font-lock-mode 1)
227 @end example
228
229 @noindent
230 You can also specify this using the menu bar Options menu, specifying
231 first Syntax Highlighting and then Save Options.
232
233 Font Lock mode uses several specifically named faces to do its job,
234 including @code{font-lock-string-face}, @code{font-lock-comment-face},
235 and others. The easiest way to find them all is to use completion
236 on the face name in @code{set-face-foreground}.
237
238 To change the colors or the fonts used by Font Lock mode to fontify
239 different parts of text, just change these faces. There are
240 two ways to do it:
241
242 @itemize @bullet
243 @item
244 Invoke @kbd{M-x set-face-foreground} or @kbd{M-x set-face-background}
245 to change the colors of a particular face used by Font Lock.
246 @xref{Faces}. The command @kbd{M-x list-faces-display} displays all
247 the faces currently known to Emacs, including those used by Font Lock.
248
249 @item
250 Customize the faces interactively with @kbd{M-x customize-face}, as
251 described in @ref{Face Customization}.
252 @end itemize
253
254 @vindex font-lock-maximum-decoration
255 The variable @code{font-lock-maximum-decoration} specifies the
256 preferred level of fontification, for modes that provide multiple
257 levels. Level 1 is the least amount of fontification; some modes
258 support levels as high as 3. The normal default is ``as high as
259 possible.'' You can specify an integer, which applies to all modes, or
260 you can specify different numbers for particular major modes; for
261 example, to use level 1 for C/C++ modes, and the default level
262 otherwise, use this:
263
264 @example
265 (setq font-lock-maximum-decoration
266 '((c-mode . 1) (c++-mode . 1)))
267 @end example
268
269 @vindex font-lock-maximum-size
270 Fontification can be too slow for large buffers, so you can suppress
271 it. The variable @code{font-lock-maximum-size} specifies a buffer size,
272 beyond which buffer fontification is suppressed.
273
274 @c @w is used below to prevent a bad page-break.
275 @vindex font-lock-beginning-of-syntax-function
276 @cindex incorrect fontification
277 @cindex parenthesis in column zero and fontification
278 @cindex brace in column zero and fontification
279 Comment and string fontification (or ``syntactic'' fontification)
280 relies on analysis of the syntactic structure of the buffer text. For
281 the sake of speed, some modes, including C mode and Lisp mode,
282 rely on a special convention: an open-parenthesis or open-brace in the
283 leftmost column always defines the @w{beginning} of a defun, and is
284 thus always outside any string or comment. (@xref{Left Margin
285 Paren}.) If you don't follow this convention, Font Lock mode can
286 misfontify the text that follows an open-parenthesis or open-brace in
287 the leftmost column that is inside a string or comment.
288
289 @cindex slow display during scrolling
290 The variable @code{font-lock-beginning-of-syntax-function} (always
291 buffer-local) specifies how Font Lock mode can find a position
292 guaranteed to be outside any comment or string. In modes which use the
293 leftmost column parenthesis convention, the default value of the variable
294 is @code{beginning-of-defun}---that tells Font Lock mode to use the
295 convention. If you set this variable to @code{nil}, Font Lock no longer
296 relies on the convention. This avoids incorrect results, but the price
297 is that, in some cases, fontification for a changed text must rescan
298 buffer text from the beginning of the buffer. This can considerably
299 slow down redisplay while scrolling, particularly if you are close to
300 the end of a large buffer.
301
302 @findex font-lock-add-keywords
303 Font Lock highlighting patterns already exist for many modes, but you
304 may want to fontify additional patterns. You can use the function
305 @code{font-lock-add-keywords}, to add your own highlighting patterns for
306 a particular mode. For example, to highlight @samp{FIXME:} words in C
307 comments, use this:
308
309 @example
310 (font-lock-add-keywords
311 'c-mode
312 '(("\\<\\(FIXME\\):" 1 font-lock-warning-face t)))
313 @end example
314
315 @findex font-lock-remove-keywords
316 To remove keywords from the font-lock highlighting patterns, use the
317 function @code{font-lock-remove-keywords}. @xref{Search-based
318 Fontification,,, elisp, The Emacs Lisp Reference Manual}, for
319 documentation of the format of this list.
320
321 @cindex just-in-time (JIT) font-lock
322 @cindex background syntax highlighting
323 Fontifying large buffers can take a long time. To avoid large
324 delays when a file is visited, Emacs fontifies only the visible
325 portion of a buffer. As you scroll through the buffer, each portion
326 that becomes visible is fontified as soon as it is displayed. The
327 parts of the buffer that are not displayed are fontified
328 ``stealthily,'' in the background, i.e.@: when Emacs is idle. You can
329 control this background fontification, also called @dfn{Just-In-Time}
330 (or @dfn{JIT}) Lock, by customizing variables in the customization
331 group @samp{jit-lock}. @xref{Specific Customization}.
332
333 @node Highlight Changes
334 @section Highlight Changes Mode
335
336 @findex highlight-changes-mode
337 Use @kbd{M-x highlight-changes-mode} to enable a minor mode
338 that uses faces (colors, typically) to indicate which parts of
339 the buffer were changed most recently.
340
341 @node Highlight Interactively
342 @section Interactive Highlighting by Matching
343 @cindex highlighting by matching
344 @cindex interactive highlighting
345
346 It is sometimes useful to highlight the strings that match a certain
347 regular expression. For example, you might wish to see all the
348 references to a certain variable in a program source file, or highlight
349 certain parts in a voluminous output of some program, or make certain
350 cliches stand out in an article.
351
352 @findex hi-lock-mode
353 Use the @kbd{M-x hi-lock-mode} command to turn on a minor mode that
354 allows you to specify regular expressions of the text to be
355 highlighted. Hi-lock mode works like Font Lock (@pxref{Font Lock}),
356 except that it lets you specify explicitly what parts of text to
357 highlight. You control Hi-lock mode with these commands:
358
359 @table @kbd
360 @item C-x w h @var{regexp} @key{RET} @var{face} @key{RET}
361 @kindex C-x w h
362 @findex highlight-regexp
363 Highlight text that matches
364 @var{regexp} using face @var{face} (@code{highlight-regexp}).
365 By using this command more than once, you can highlight various
366 parts of the text in different ways.
367
368 @item C-x w r @var{regexp} @key{RET}
369 @kindex C-x w r
370 @findex unhighlight-regexp
371 Unhighlight @var{regexp} (@code{unhighlight-regexp}). You must enter
372 one of the regular expressions currently specified for highlighting.
373 (You can use completion, or choose from a menu, to enter one of them
374 conveniently.)
375
376 @item C-x w l @var{regexp} @key{RET} @var{face} @key{RET}
377 @kindex C-x w l
378 @findex highlight-lines-matching-regexp
379 @cindex lines, highlighting
380 @cindex highlighting lines of text
381 Highlight entire lines containing a match for @var{regexp}, using face
382 @var{face} (@code{highlight-lines-matching-regexp}).
383
384 @item C-x w b
385 @kindex C-x w b
386 @findex hi-lock-write-interactive-patterns
387 Insert all the current highlighting regexp/face pairs into the buffer
388 at point, with comment delimiters to prevent them from changing your
389 program. This key binding runs the
390 @code{hi-lock-write-interactive-patterns} command.
391
392 These patterns will be read the next time you visit the file while
393 Hi-lock mode is enabled, or whenever you use the @kbd{M-x
394 hi-lock-find-patterns} command.
395
396 @item C-x w i
397 @kindex C-x w i
398 @findex hi-lock-find-patterns
399 @vindex hi-lock-exclude-modes
400 Re-read regexp/face pairs in the current buffer
401 (@code{hi-lock-write-interactive-patterns}). The list of pairs is
402 found no matter where in the buffer it may be.
403
404 This command does nothing if the major mode is a member of the list
405 @code{hi-lock-exclude-modes}.
406 @end table
407
408 @node Scrolling
409 @section Scrolling
410
411 If a buffer contains text that is too large to fit entirely within a
412 window that is displaying the buffer, Emacs shows a contiguous portion of
413 the text. The portion shown always contains point.
414
415 @cindex scrolling
416 @dfn{Scrolling} means moving text up or down in the window so that
417 different parts of the text are visible. Scrolling forward means that text
418 moves up, and new text appears at the bottom. Scrolling backward moves
419 text down and new text appears at the top.
420
421 Scrolling happens automatically if you move point past the bottom or top
422 of the window. You can also explicitly request scrolling with the commands
423 in this section.
424
425 @table @kbd
426 @item C-l
427 Clear screen and redisplay, scrolling the selected window to center
428 point vertically within it (@code{recenter}).
429 @item C-v
430 Scroll forward (a windowful or a specified number of lines) (@code{scroll-up}).
431 @item @key{NEXT}
432 @itemx @key{PAGEDOWN}
433 Likewise, scroll forward.
434 @item M-v
435 Scroll backward (@code{scroll-down}).
436 @item @key{PRIOR}
437 @itemx @key{PAGEUP}
438 Likewise, scroll backward.
439 @item @var{arg} C-l
440 Scroll so point is on line @var{arg} (@code{recenter}).
441 @item C-M-l
442 Scroll heuristically to bring useful information onto the screen
443 (@code{reposition-window}).
444 @end table
445
446 @kindex C-l
447 @findex recenter
448 The most basic scrolling command is @kbd{C-l} (@code{recenter}) with
449 no argument. It scrolls the selected window so that point is halfway
450 down from the top of the window. On a text terminal, it also clears
451 the screen and redisplays all windows. That is useful in case the
452 screen is garbled (@pxref{Screen Garbled}).
453
454 @kindex C-v
455 @kindex M-v
456 @kindex NEXT
457 @kindex PRIOR
458 @kindex PAGEDOWN
459 @kindex PAGEUP
460 @findex scroll-up
461 @findex scroll-down
462 @vindex next-screen-context-lines
463 To read the buffer a windowful at a time, use @kbd{C-v}
464 (@code{scroll-up}) with no argument. This scrolls forward by nearly
465 the whole window height. The effect is to take the two lines at the
466 bottom of the window and put them at the top, followed by nearly a
467 whole windowful of lines that were not previously visible. If point
468 was in the text that scrolled off the top, it ends up at the new top
469 of the window.
470
471 @kbd{M-v} (@code{scroll-down}) with no argument scrolls backward in
472 a similar way, also with overlap. The number of lines of overlap
473 across a @kbd{C-v} or @kbd{M-v} is controlled by the variable
474 @code{next-screen-context-lines}; by default, it is 2. The function
475 keys @key{NEXT} and @key{PRIOR}, or @key{PAGEDOWN} and @key{PAGEUP},
476 are equivalent to @kbd{C-v} and @kbd{M-v}.
477
478 The commands @kbd{C-v} and @kbd{M-v} with a numeric argument scroll
479 the text in the selected window up or down a few lines. @kbd{C-v}
480 with an argument moves the text and point up, together, that many
481 lines; it brings the same number of new lines into view at the bottom
482 of the window. @kbd{M-v} with numeric argument scrolls the text
483 downward, bringing that many new lines into view at the top of the
484 window. @kbd{C-v} with a negative argument is like @kbd{M-v} and vice
485 versa.
486
487 The names of scroll commands are based on the direction that the
488 text moves in the window. Thus, the command to scroll forward is
489 called @code{scroll-up} because it moves the text upward on the
490 screen. The keys @key{PAGEDOWN} and @key{PAGEUP} derive their names
491 and customary meanings from a different convention that developed
492 elsewhere; hence the strange result that @key{PAGEDOWN} runs
493 @code{scroll-up}.
494
495 @vindex scroll-preserve-screen-position
496 Some users like the full-screen scroll commands to keep point at the
497 same screen line. To enable this behavior, set the variable
498 @code{scroll-preserve-screen-position} to a non-@code{nil} value. In
499 this mode, when scrolling shifts point off the screen, or into the
500 scrolling margins, Emacs moves point to keep the same vertical
501 position within the window. This mode is convenient for browsing
502 through a file by scrolling by screenfuls; if you come back to the
503 screen where you started, point goes back to the line where it
504 started. However, this mode is inconvenient when you move to the next
505 screen in order to move point to the text there.
506
507 Another way to do scrolling is with @kbd{C-l} with a numeric argument.
508 @kbd{C-l} does not clear the screen when given an argument; it only scrolls
509 the selected window. With a positive argument @var{n}, it repositions text
510 to put point @var{n} lines down from the top. An argument of zero puts
511 point on the very top line. Point does not move with respect to the text;
512 rather, the text and point move rigidly on the screen. @kbd{C-l} with a
513 negative argument puts point that many lines from the bottom of the window.
514 For example, @kbd{C-u - 1 C-l} puts point on the bottom line, and @kbd{C-u
515 - 5 C-l} puts it five lines from the bottom. @kbd{C-u C-l} scrolls to put
516 point at the center (vertically) of the selected window.
517
518 @kindex C-M-l
519 @findex reposition-window
520 The @kbd{C-M-l} command (@code{reposition-window}) scrolls the current
521 window heuristically in a way designed to get useful information onto
522 the screen. For example, in a Lisp file, this command tries to get the
523 entire current defun onto the screen if possible.
524
525 @vindex scroll-conservatively
526 Scrolling happens automatically when point moves out of the visible
527 portion of the text. Normally, automatic scrolling centers point
528 vertically within the window. However, if you set
529 @code{scroll-conservatively} to a small number @var{n}, then if you
530 move point just a little off the screen---less than @var{n}
531 lines---then Emacs scrolls the text just far enough to bring point
532 back on screen. By default, @code{scroll-conservatively} is 0.
533
534 @cindex aggressive scrolling
535 @vindex scroll-up-aggressively
536 @vindex scroll-down-aggressively
537 When the window does scroll by a longer distance, you can control
538 how aggressively it scrolls, by setting the variables
539 @code{scroll-up-aggressively} and @code{scroll-down-aggressively}.
540 The value of @code{scroll-up-aggressively} should be either
541 @code{nil}, or a fraction @var{f} between 0 and 1. A fraction
542 specifies where on the screen to put point when scrolling upward.
543 More precisely, when a window scrolls up because point is above the
544 window start, the new start position is chosen to put point @var{f}
545 part of the window height from the top. The larger @var{f}, the more
546 aggressive the scrolling.
547
548 @code{nil}, which is the default, scrolls to put point at the center.
549 So it is equivalent to .5.
550
551 Likewise, @code{scroll-down-aggressively} is used for scrolling
552 down. The value, @var{f}, specifies how far point should be placed
553 from the bottom of the window; thus, as with
554 @code{scroll-up-aggressively}, a larger value is more aggressive.
555
556 @vindex scroll-margin
557 The variable @code{scroll-margin} restricts how close point can come
558 to the top or bottom of a window. Its value is a number of screen
559 lines; if point comes within that many lines of the top or bottom of the
560 window, Emacs recenters the window. By default, @code{scroll-margin} is
561 0.
562
563 @node Horizontal Scrolling
564 @section Horizontal Scrolling
565 @cindex horizontal scrolling
566
567 @dfn{Horizontal scrolling} means shifting all the lines sideways
568 within a window---so that some of the text near the left margin is not
569 displayed at all. When the text in a window is scrolled horizontally,
570 text lines are truncated rather than continued (@pxref{Display
571 Custom}). Whenever a window shows truncated lines, Emacs
572 automatically updates its horizontal scrolling whenever point moves
573 off the left or right edge of the screen. You can also use these
574 commands to do explicit horizontal scrolling.
575
576 @table @kbd
577 @item C-x <
578 Scroll text in current window to the left (@code{scroll-left}).
579 @item C-x >
580 Scroll to the right (@code{scroll-right}).
581 @end table
582
583 @kindex C-x <
584 @kindex C-x >
585 @findex scroll-left
586 @findex scroll-right
587 The command @kbd{C-x <} (@code{scroll-left}) scrolls the selected
588 window to the left by @var{n} columns with argument @var{n}. This moves
589 part of the beginning of each line off the left edge of the window.
590 With no argument, it scrolls by almost the full width of the window (two
591 columns less, to be precise).
592
593 @kbd{C-x >} (@code{scroll-right}) scrolls similarly to the right. The
594 window cannot be scrolled any farther to the right once it is displayed
595 normally (with each line starting at the window's left margin);
596 attempting to do so has no effect. This means that you don't have to
597 calculate the argument precisely for @w{@kbd{C-x >}}; any sufficiently large
598 argument will restore the normal display.
599
600 If you use those commands to scroll a window horizontally, that sets
601 a lower bound for automatic horizontal scrolling. Automatic scrolling
602 will continue to scroll the window, but never farther to the right
603 than the amount you previously set by @code{scroll-left}.
604
605 @vindex hscroll-margin
606 The value of the variable @code{hscroll-margin} controls how close
607 to the window's edges point is allowed to get before the window will
608 be automatically scrolled. It is measured in columns. If the value
609 is 5, then moving point within 5 columns of the edge causes horizontal
610 scrolling away from that edge.
611
612 @vindex hscroll-step
613 The variable @code{hscroll-step} determines how many columns to
614 scroll the window when point gets too close to the edge. If it's
615 zero, horizontal scrolling centers point horizontally within the
616 window. If it's a positive integer, it specifies the number of
617 columns to scroll by. If it's a floating-point number, it specifies
618 the fraction of the window's width to scroll by. The default is zero.
619
620 @vindex auto-hscroll-mode
621 To disable automatic horizontal scrolling, set the variable
622 @code{auto-hscroll-mode} to @code{nil}.
623
624 @node Fringes
625 @section Window Fringes
626 @cindex fringes
627
628 On a graphical display, each Emacs window normally has narrow
629 @dfn{fringes} on the left and right edges. The fringes display
630 indications about the text in the window.
631
632 The most common use of the fringes is to indicate a continuation
633 line, when one line of text is split into multiple lines on the
634 screen. The left fringe shows a curving arrow for each screen line
635 except the first, indicating that ``this is not the real beginning.''
636 The right fringe shows a curving arrow for each screen line except the
637 last, indicating that ``this is not the real end.''
638
639 The fringes indicate line truncation with short horizontal arrows
640 meaning ``there's more text on this line which is scrolled
641 horizontally out of view;'' clicking the mouse on one of the arrows
642 scrolls the display horizontally in the direction of the arrow. The
643 fringes can also indicate other things, such as empty lines, or where a
644 program you are debugging is executing (@pxref{Debuggers}).
645
646 @findex set-fringe-style
647 @findex fringe-mode
648 You can enable and disable the fringes for all frames using
649 @kbd{M-x fringe-mode}. To enable and disable the fringes
650 for the selected frame, use @kbd{M-x set-fringe-style}.
651
652 @node Useless Whitespace
653 @section Useless Whitespace
654
655 @cindex trailing whitespace
656 @cindex whitespace, trailing
657 @vindex show-trailing-whitespace
658 It is easy to leave unnecessary spaces at the end of a line, or
659 empty lines at the end of a file, without realizing it. In most
660 cases, this @dfn{trailing whitespace} has no effect, but there are
661 special circumstances where it matters.
662
663 You can make trailing whitespace at the end of a line visible on the
664 screen by setting the buffer-local variable
665 @code{show-trailing-whitespace} to @code{t}. Then Emacs displays
666 trailing whitespace in the face @code{trailing-whitespace}.
667
668 This feature does not apply when point is at the end of the line
669 containing the whitespace. Strictly speaking, that is ``trailing
670 whitespace'' nonetheless, but displaying it specially in that case
671 looks ugly while you are typing in new text. In this special case,
672 the location of point is enough to show you that the spaces are
673 present.
674
675 @findex delete-trailing-whitespace
676 To delete all trailing whitespace within the current buffer's
677 accessible portion (@pxref{Narrowing}), type @kbd{M-x
678 delete-trailing-whitespace @key{RET}}. (This command does not remove
679 the form-feed characters.)
680
681 @vindex indicate-empty-lines
682 @vindex default-indicate-empty-lines
683 @cindex unused lines
684 @cindex fringes, and unused line indication
685 Emacs can indicate unused lines at the end of the window with a
686 small image in the left fringe (@pxref{Fringes}). The image appears
687 for window lines that do not correspond to any buffer text. Blank
688 lines at the end of the buffer then stand out because they do not have
689 this image in the fringe.
690
691 To enable this feature, set the buffer-local variable
692 @code{indicate-empty-lines} to a non-@code{nil} value. The default
693 value of this variable is controlled by the variable
694 @code{default-indicate-empty-lines}; by setting that variable, you
695 can enable or disable this feature for all new buffers. (This feature
696 currently doesn't work on character terminals.)
697
698 @node Follow Mode
699 @section Follow Mode
700 @cindex Follow mode
701 @cindex mode, Follow
702 @findex follow-mode
703 @cindex windows, synchronizing
704 @cindex synchronizing windows
705
706 @dfn{Follow mode} is a minor mode that makes two windows, both
707 showing the same buffer, scroll as a single tall ``virtual window.''
708 To use Follow mode, go to a frame with just one window, split it into
709 two side-by-side windows using @kbd{C-x 3}, and then type @kbd{M-x
710 follow-mode}. From then on, you can edit the buffer in either of the
711 two windows, or scroll either one; the other window follows it.
712
713 In Follow mode, if you move point outside the portion visible in one
714 window and into the portion visible in the other window, that selects
715 the other window---again, treating the two as if they were parts of
716 one large window.
717
718 To turn off Follow mode, type @kbd{M-x follow-mode} a second time.
719
720 @node Selective Display
721 @section Selective Display
722 @cindex selective display
723 @findex set-selective-display
724 @kindex C-x $
725
726 Emacs has the ability to hide lines indented more than a certain number
727 of columns (you specify how many columns). You can use this to get an
728 overview of a part of a program.
729
730 To hide lines in the current buffer, type @kbd{C-x $}
731 (@code{set-selective-display}) with a numeric argument @var{n}. Then
732 lines with at least @var{n} columns of indentation disappear from the
733 screen. The only indication of their presence is that three dots
734 (@samp{@dots{}}) appear at the end of each visible line that is
735 followed by one or more hidden ones.
736
737 The commands @kbd{C-n} and @kbd{C-p} move across the hidden lines as
738 if they were not there.
739
740 The hidden lines are still present in the buffer, and most editing
741 commands see them as usual, so you may find point in the middle of the
742 hidden text. When this happens, the cursor appears at the end of the
743 previous line, after the three dots. If point is at the end of the
744 visible line, before the newline that ends it, the cursor appears before
745 the three dots.
746
747 To make all lines visible again, type @kbd{C-x $} with no argument.
748
749 @vindex selective-display-ellipses
750 If you set the variable @code{selective-display-ellipses} to
751 @code{nil}, the three dots do not appear at the end of a line that
752 precedes hidden lines. Then there is no visible indication of the
753 hidden lines. This variable becomes local automatically when set.
754
755 See also @ref{Outline Mode} for another way to hide part of
756 the text in a buffer.
757
758 @node Optional Mode Line
759 @section Optional Mode Line Features
760
761 @cindex buffer size display
762 @cindex display of buffer size
763 @findex size-indication-mode
764 The buffer percentage @var{pos} indicates the percentage of the
765 buffer above the top of the window. You can additionally display the
766 size of the buffer by typing @kbd{M-x size-indication-mode} to turn on
767 Size Indication mode. The size will be displayed immediately
768 following the buffer percentage like this:
769
770 @example
771 @var{POS} of @var{SIZE}
772 @end example
773
774 @noindent
775 Here @var{SIZE} is the human readable representation of the number of
776 characters in the buffer, which means that @samp{k} for 10^3, @samp{M}
777 for 10^6, @samp{G} for 10^9, etc., are used to abbreviate.
778
779 @cindex narrowing, and buffer size display
780 If you have narrowed the buffer (@pxref{Narrowing}), the size of the
781 accessible part of the buffer is shown.
782
783 @cindex line number display
784 @cindex display of line number
785 @findex line-number-mode
786 The current line number of point appears in the mode line when Line
787 Number mode is enabled. Use the command @kbd{M-x line-number-mode} to
788 turn this mode on and off; normally it is on. The line number appears
789 after the buffer percentage @var{pos}, with the letter @samp{L} to
790 indicate what it is. @xref{Minor Modes}, for more information about
791 minor modes and about how to use this command.
792
793 @cindex narrowing, and line number display
794 If you have narrowed the buffer (@pxref{Narrowing}), the displayed
795 line number is relative to the accessible portion of the buffer.
796
797 @vindex line-number-display-limit
798 If the buffer is very large (larger than the value of
799 @code{line-number-display-limit}), then the line number doesn't appear.
800 Emacs doesn't compute the line number when the buffer is large, because
801 that would be too slow. Set it to @code{nil} to remove the limit.
802
803 @vindex line-number-display-limit-width
804 Line-number computation can also be slow if the lines in the buffer
805 are too long. For this reason, Emacs normally doesn't display line
806 numbers if the average width, in characters, of lines near point is
807 larger than the value of the variable
808 @code{line-number-display-limit-width}. The default value is 200
809 characters.
810
811 @cindex Column Number mode
812 @cindex mode, Column Number
813 @findex column-number-mode
814 You can also display the current column number by turning on Column
815 Number mode. It displays the current column number preceded by the
816 letter @samp{C}. Type @kbd{M-x column-number-mode} to toggle this mode.
817
818 @findex display-time
819 @cindex time (on mode line)
820 Emacs can optionally display the time and system load in all mode
821 lines. To enable this feature, type @kbd{M-x display-time} or customize
822 the option @code{display-time-mode}. The information added to the mode
823 line usually appears after the buffer name, before the mode names and
824 their parentheses. It looks like this:
825
826 @example
827 @var{hh}:@var{mm}pm @var{l.ll}
828 @end example
829
830 @noindent
831 @vindex display-time-24hr-format
832 Here @var{hh} and @var{mm} are the hour and minute, followed always by
833 @samp{am} or @samp{pm}. @var{l.ll} is the average number of running
834 processes in the whole system recently. (Some fields may be missing if
835 your operating system cannot support them.) If you prefer time display
836 in 24-hour format, set the variable @code{display-time-24hr-format}
837 to @code{t}.
838
839 @cindex mail (on mode line)
840 @vindex display-time-use-mail-icon
841 @vindex display-time-mail-face
842 @vindex display-time-mail-file
843 @vindex display-time-mail-directory
844 The word @samp{Mail} appears after the load level if there is mail
845 for you that you have not read yet. On a graphical display you can use
846 an icon instead of @samp{Mail} by customizing
847 @code{display-time-use-mail-icon}; this may save some space on the mode
848 line. You can customize @code{display-time-mail-face} to make the mail
849 indicator prominent. Use @code{display-time-mail-file} to specify
850 the mail file to check, or set @code{display-time-mail-directory}
851 to specify the directory to check for incoming mail (any nonempty regular
852 file in the directory is considered as ``newly arrived mail'').
853
854 @cindex mode line, 3D appearance
855 @cindex attributes of mode line, changing
856 @cindex non-integral number of lines in a window
857 By default, the mode line is drawn on graphics displays with
858 3D-style highlighting, like that of a button when it is not being
859 pressed. If you don't like this effect, you can disable the 3D
860 highlighting of the mode line, by customizing the attributes of the
861 @code{mode-line} face in your @file{.emacs} init file, like this:
862
863 @example
864 (set-face-attribute 'mode-line nil :box nil)
865 @end example
866
867 @noindent
868 Alternatively, you can turn off the box attribute in your
869 @file{.Xdefaults} file:
870
871 @example
872 Emacs.mode-line.AttributeBox: off
873 @end example
874
875 @cindex non-selected windows, mode line appearance
876 By default, the mode line of nonselected windows is displayed in a
877 different face, called @code{mode-line-inactive}. Only the selected
878 window is displayed in the @code{mode-line} face. This helps show
879 which window is selected. When the minibuffer is selected, since
880 it has no mode line, the window from which you activated the minibuffer
881 has its mode line displayed using @code{mode-line}; as a result,
882 ordinary entry to the minibuffer does not change any mode lines.
883
884 @vindex mode-line-in-non-selected-windows
885 You can disable use of @code{mode-line-inactive} by setting variable
886 @code{mode-line-in-non-selected-windows} to @code{nil}; then all mode
887 lines are displayed in the @code{mode-line} face.
888
889 @node Text Display
890 @section How Text Is Displayed
891 @cindex characters (in text)
892
893 @acronym{ASCII} printing characters (octal codes 040 through 0176) in Emacs
894 buffers are displayed with their graphics, as are non-ASCII multibyte
895 printing characters (octal codes above 0400).
896
897 Some @acronym{ASCII} control characters are displayed in special ways. The
898 newline character (octal code 012) is displayed by starting a new line.
899 The tab character (octal code 011) is displayed by moving to the next
900 tab stop column (normally every 8 columns).
901
902 Other @acronym{ASCII} control characters are normally displayed as a caret
903 (@samp{^}) followed by the non-control version of the character; thus,
904 control-A is displayed as @samp{^A}.
905
906 Non-@acronym{ASCII} characters 0200 through 0237 (octal) are displayed with
907 octal escape sequences; thus, character code 0230 (octal) is displayed
908 as @samp{\230}. The display of character codes 0240 through 0377
909 (octal) may be either as escape sequences or as graphics. They do not
910 normally occur in multibyte buffers, but if they do, they are displayed
911 as Latin-1 graphics. In unibyte mode, if you enable European display
912 they are displayed using their graphics (assuming your terminal supports
913 them), otherwise as escape sequences. @xref{Single-Byte Character
914 Support}.
915
916 @vindex show-nonbreak-escape
917 @cindex no-break space, display
918 @cindex no-break hyphen, display
919 Some character sets define ``no-break'' versions of the space
920 and hyphen characters, which are used where a line should not be
921 broken. Emacs displays these with an escape character in order to
922 distinguish them from ordinary spaces and hyphens. For example, a
923 non-breaking space is displayed as @samp{\ }. You can turn off this
924 behavior by setting the variable @code{show-nonbreak-escape} to
925 @code{nil}.
926
927 @node Cursor Display
928 @section Displaying the Cursor
929
930 @findex blink-cursor-mode
931 @vindex blink-cursor-alist
932 @cindex cursor, locating visually
933 @cindex cursor, blinking
934 You can customize the cursor's color, and whether it blinks, using
935 the @code{cursor} Custom group (@pxref{Easy Customization}). On
936 graphical terminals, the command @kbd{M-x blink-cursor-mode} enables
937 or disables the blinking of the cursor. (On text terminals, the
938 terminal itself blinks the cursor, and Emacs has no control over it.)
939 You can control how the cursor appears when it blinks off by setting
940 the variable @code{blink-cursor-alist}.
941
942 @cindex cursor in non-selected windows
943 @vindex cursor-in-non-selected-windows
944 Normally, the cursor appears in non-selected windows in the ``off''
945 state, with the same appearance as when the blinking cursor blinks
946 ``off''. For a box cursor, this is a hollow box; for a bar cursor,
947 this is a thinner bar. To turn off cursors in non-selected windows,
948 customize the variable @code{cursor-in-non-selected-windows} and assign
949 it a @code{nil} value.
950
951 @vindex x-stretch-cursor
952 @cindex wide block cursor
953 On graphical terminals, Emacs can optionally draw the block cursor
954 as wide as the character under the cursor---for example, if the cursor
955 is on a tab character, it would cover the full width occupied by that
956 tab character. To enable this feature, set the variable
957 @code{x-stretch-cursor} to a non-@code{nil} value.
958
959 @findex hl-line-mode
960 @findex global-hl-line-mode
961 @cindex highlight current line
962 If you find it hard to see the cursor, you might like HL Line mode,
963 a minor mode that highlights the line containing point. Use @kbd{M-x
964 hl-line-mode} to enable or disable it in the current buffer. @kbd{M-x
965 global-hl-line-mode} enables or disables the same mode globally.
966
967 @node Display Custom
968 @section Customization of Display
969
970 This section contains information for customization only. Beginning
971 users should skip it.
972
973 @vindex mode-line-inverse-video
974 The variable @code{mode-line-inverse-video} is an obsolete way of
975 controlling whether the mode line is displayed in inverse video; the
976 preferred way of doing this is to change the @code{mode-line} face.
977 @xref{Mode Line}. However, if @code{mode-line-inverse-video} has a
978 value of @code{nil}, then the @code{mode-line} face will be ignored,
979 and mode-lines will be drawn using the default text face.
980 @xref{Faces}.
981
982 @vindex inverse-video
983 If the variable @code{inverse-video} is non-@code{nil}, Emacs attempts
984 to invert all the lines of the display from what they normally are.
985
986 @vindex visible-bell
987 If the variable @code{visible-bell} is non-@code{nil}, Emacs attempts
988 to make the whole screen blink when it would normally make an audible bell
989 sound. This variable has no effect if your terminal does not have a way
990 to make the screen blink.
991
992 @vindex no-redraw-on-reenter
993 On a text terminal, when you reenter Emacs after suspending, Emacs
994 normally clears the screen and redraws the entire display. On some
995 terminals with more than one page of memory, it is possible to arrange
996 the termcap entry so that the @samp{ti} and @samp{te} strings (output
997 to the terminal when Emacs is entered and exited, respectively) switch
998 between pages of memory so as to use one page for Emacs and another
999 page for other output. Then you might want to set the variable
1000 @code{no-redraw-on-reenter} non-@code{nil}; this tells Emacs to
1001 assume, when resumed, that the screen page it is using still contains
1002 what Emacs last wrote there.
1003
1004 @vindex echo-keystrokes
1005 The variable @code{echo-keystrokes} controls the echoing of multi-character
1006 keys; its value is the number of seconds of pause required to cause echoing
1007 to start, or zero meaning don't echo at all. @xref{Echo Area}.
1008
1009 @vindex ctl-arrow
1010 If the variable @code{ctl-arrow} is @code{nil}, all control characters in
1011 the buffer are displayed with octal escape sequences, except for newline
1012 and tab. Altering the value of @code{ctl-arrow} makes it local to the
1013 current buffer; until that time, the default value is in effect. The
1014 default is initially @code{t}. @xref{Display Tables,, Display Tables,
1015 elisp, The Emacs Lisp Reference Manual}.
1016
1017 @vindex tab-width
1018 @vindex default-tab-width
1019 Normally, a tab character in the buffer is displayed as whitespace which
1020 extends to the next display tab stop position, and display tab stops come
1021 at intervals equal to eight spaces. The number of spaces per tab is
1022 controlled by the variable @code{tab-width}, which is made local by
1023 changing it, just like @code{ctl-arrow}. Note that how the tab character
1024 in the buffer is displayed has nothing to do with the definition of
1025 @key{TAB} as a command. The variable @code{tab-width} must have an
1026 integer value between 1 and 1000, inclusive. The variable
1027 @code{default-tab-width} controls the default value of this variable
1028 for buffers where you have not set it locally.
1029
1030 @cindex truncation
1031 @cindex line truncation, and fringes
1032 As an alternative to continuation, Emacs can display long lines by
1033 @dfn{truncation}. This means that all the characters that do not fit
1034 in the width of the screen or window do not appear at all. On
1035 graphical terminals, a small straight arrow in the fringe indicates
1036 truncation at either end of the line. On text terminals, @samp{$}
1037 appears in the first column when there is text truncated to the left,
1038 and in the last column when there is text truncated to the right.
1039
1040 @vindex truncate-lines
1041 @findex toggle-truncate-lines
1042 Horizontal scrolling automatically causes line truncation
1043 (@pxref{Horizontal Scrolling}). You can explicitly enable line
1044 truncation for a particular buffer with the command @kbd{M-x
1045 toggle-truncate-lines}. This works by locally changing the variable
1046 @code{truncate-lines}. If that variable is non-@code{nil}, long lines
1047 are truncated; if it is @code{nil}, they are continued onto multiple
1048 screen lines. Setting the variable @code{truncate-lines} in any way
1049 makes it local to the current buffer; until that time, the default
1050 value is in effect. The default value is normally @code{nil}.
1051
1052 @c @vindex truncate-partial-width-windows @c Idx entry is in Split Windows.
1053 If the variable @code{truncate-partial-width-windows} is
1054 non-@code{nil}, it forces truncation rather than continuation in any
1055 window less than the full width of the screen or frame, regardless of
1056 the value of @code{truncate-lines}. For information about side-by-side
1057 windows, see @ref{Split Window}. See also @ref{Display,, Display,
1058 elisp, The Emacs Lisp Reference Manual}.
1059
1060 @vindex overflow-newline-into-fringe
1061 If the variable @code{overflow-newline-into-fringe} is
1062 non-@code{nil} on a window system, it specifies that lines which are
1063 exactly as wide as the window (not counting the final newline
1064 character) shall not be broken into two lines on the display (with
1065 just the newline on the second line). Instead, the newline
1066 overflows into the right fringe, and the cursor will be displayed in
1067 the fringe when positioned on that newline.
1068
1069 @vindex indicate-buffer-boundaries
1070 On a window system, Emacs may indicate the buffer boundaries in the
1071 fringes. The buffer boundaries, i.e. first and last line in the
1072 buffer, can be marked with angle bitmaps in the left or right fringe.
1073 This can be combined with up and down arrow bitmaps shown at the top
1074 and bottom of the left or right fringe if the window can be scrolled
1075 in either direction.
1076
1077 The buffer-local variable @code{indicate-buffer-boundaries} controls
1078 how the buffer boundaries and window scrolling is indicated in the
1079 fringes.
1080
1081 If the value is @code{left} or @code{right}, both angle and arrow
1082 bitmaps are displayed in the left or right fringe, respectively.
1083
1084 If value is an alist, each element @code{(@var{indicator} .
1085 @var{position})} specifies the position of one of the indicators.
1086 The @var{indicator} must be one of @code{top}, @code{bottom},
1087 @code{up}, @code{down}, or @code{t} which specifies the default
1088 position for the indicators not present in the alist.
1089 The @var{position} is one of @code{left}, @code{right}, or @code{nil}
1090 which specifies not to show this indicator.
1091
1092 For example, @code{((top . left) (t . right))} places the top angle
1093 bitmap in left fringe, the bottom angle bitmap in right fringe, and
1094 both arrow bitmaps in right fringe. To show just the angle bitmaps in
1095 the left fringe, but no arrow bitmaps, use @code{((top . left)
1096 (bottom . left))}.
1097
1098 @vindex default-indicate-buffer-boundaries
1099 The value of the variable @code{default-indicate-buffer-boundaries}
1100 is the default value for @code{indicate-buffer-boundaries} in buffers
1101 that do not override it.
1102
1103 @vindex baud-rate
1104 The variable @code{baud-rate} holds the output speed of the
1105 terminal, as far as Emacs knows. Setting this variable does not
1106 change the speed of actual data transmission, but the value is used
1107 for calculations. On terminals, it affects padding, and decisions
1108 about whether to scroll part of the screen or redraw it instead.
1109 It also affects the behavior of incremental search.
1110
1111 On window-systems, @code{baud-rate} is only used to determine how
1112 frequently to look for pending input during display updating. A
1113 higher value of @code{baud-rate} means that check for pending input
1114 will be done less frequently.
1115
1116 You can customize the way any particular character code is displayed
1117 by means of a display table. @xref{Display Tables,, Display Tables,
1118 elisp, The Emacs Lisp Reference Manual}.
1119
1120 @cindex hourglass pointer display
1121 @vindex hourglass-delay
1122 On a window system, Emacs can optionally display the mouse pointer
1123 in a special shape to say that Emacs is busy. To turn this feature on
1124 or off, customize the group @code{cursor}. You can also control the
1125 amount of time Emacs must remain busy before the busy indicator is
1126 displayed, by setting the variable @code{hourglass-delay}.
1127
1128 @findex tty-suppress-bold-inverse-default-colors
1129 On some text-only terminals, bold face and inverse video together
1130 result in text that is hard to read. Call the function
1131 @code{tty-suppress-bold-inverse-default-colors} with a non-@code{nil}
1132 argument to suppress the effect of bold-face in this case.
1133
1134 @ignore
1135 arch-tag: 2219f910-2ff0-4521-b059-1bd231a536c4
1136 @end ignore