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