]> code.delx.au - gnu-emacs/blobdiff - man/display.texi
(Trailing Whitespace): Add index entry for fringe usage.
[gnu-emacs] / man / display.texi
index 02e9bc0af270b46f6911e0fbe2c2c47a4c44a564..aa9678a22835905d7a7352926968c7184dbbac72 100644 (file)
@@ -30,11 +30,18 @@ display it.
 @section Using Multiple Typefaces
 @cindex faces
 
-  When using Emacs with a window system, you can set up multiple
-styles of displaying characters.  Each style is called a @dfn{face}.
-Each face can specify various attributes, such as the height, weight
-and slant of the characters, the foreground and background color, and
-underlining.  But it does not have to specify all of them.
+  Emacs supports using multiple styles of displaying characters.  Each
+style is called a @dfn{face}.  Each face can specify various @dfn{face
+attributes}, such as the font family, the height, weight and slant of
+the characters, the foreground and background color, and underlining
+or overlining.  A face does not have to specify all of these
+attributes; often it inherits many of them from another face.
+
+  On a window system, all the Emacs face attributes are meaningful.
+On a character terminal, only some of them work.  Some character
+terminals support inverse video, bold, and underline attributes; some
+support colors.  Character terminals generally do not support changing
+the height and width or the font family.
 
   Features which rely on text in multiple faces (such as Font Lock mode)
 will also work on non-windowed terminals that can display more than one
@@ -62,7 +69,7 @@ background color.
 @findex set-face-background
   To alter the appearance of a face, use the customization buffer.
 @xref{Face Customization}.  You can also use X resources to specify
-attributes of particular faces (@pxref{Resources X}).  Alternatively,
+attributes of particular faces (@pxref{Resources}).  Alternatively,
 you can change the foreground and background colors of a specific face
 with @kbd{M-x set-face-foreground} and @kbd{M-x set-face-background}.
 These commands prompt in the minibuffer for a face name and a color
@@ -147,7 +154,7 @@ font of LessTif/Motif menus is currently not supported; attempts to set
 the font are ignored in this case.
 @item trailing-whitespace
 The face for highlighting trailing whitespace when
-@code{show-trailing-whitespace} is non-nil.
+@code{show-trailing-whitespace} is non-nil; see @ref{Trailing Whitespace}.
 @item variable-pitch
 The basic variable-pitch face.
 @end table
@@ -256,6 +263,9 @@ beyond which buffer fontification is suppressed.
 
 @c @w is used below to prevent a bad page-break.
 @vindex font-lock-beginning-of-syntax-function
+@cindex incorrect fontification
+@cindex parenthesis in column zero and fontification
+@cindex brace in column zero and fontification
   Comment and string fontification (or ``syntactic'' fontification)
 relies on analysis of the syntactic structure of the buffer text.  For
 the sake of speed, some modes, including C mode and Lisp mode,
@@ -292,6 +302,22 @@ comments, use this:
  '(("\\<\\(FIXME\\):" 1 font-lock-warning-face t)))
 @end example
 
+@findex font-lock-remove-keywords
+  To remove keywords from the font-lock highlighting patterns, use the
+function @code{font-lock-remove-keywords}.
+
+@cindex just-in-time (JIT) font-lock
+@cindex background syntax highlighting
+  Fontifying large buffers can take a long time.  To avoid large
+delays when a file is visited, Emacs fontifies only the visible
+portion of a buffer.  As you scroll through the buffer, each portion
+that becomes visible is fontified as soon as it is displayed.  The
+parts of the buffer that are not displayed are fontified
+``stealthily'', in the background, i.e.@: when Emacs is idle.  You can
+control this background fontification, called @dfn{Just-In-Time}, or
+@dfn{JIT} Font Lock, by customizing various options in the
+customization group @samp{jit-lock}.  @xref{Specific Customization}.
+
 @node Highlight Changes
 @section Highlight Changes Mode
 
@@ -377,9 +403,10 @@ This command does nothing if the major mode is a member of the list
 realizing it.  In most cases, this @dfn{trailing whitespace} has no
 effect, but there are special circumstances where it matters.
 
-  You can make trailing whitespace visible on the screen by setting
-the variable @code{show-trailing-whitespace} to @code{t}.  Then Emacs
-displays trailing whitespace in the face @code{trailing-whitespace}.
+  You can make trailing whitespace visible on the screen by setting the
+buffer-local variable @code{show-trailing-whitespace} to @code{t}.  Then
+Emacs displays trailing whitespace in the face
+@code{trailing-whitespace}.
 
   Trailing whitespace is defined as spaces or tabs at the end of a
 line.  But trailing whitespace is not displayed specially if point is
@@ -387,16 +414,24 @@ at the end of the line containing the whitespace.  (Doing that looks
 ugly while you are typing in new text, and the location of point is
 enough in that case to show you that the spaces are present.)
 
+@findex delete-trailing-whitespace
+  To delete all trailing whitespace within the current buffer's
+restriction (@pxref{Narrowing}), type @kbd{M-x
+delete-trailing-whitespace @key{RET}}.  (This command does not remove
+the form-feed characters.)
+
 @vindex indicate-empty-lines
 @vindex default-indicate-empty-lines
 @cindex empty lines
+@cindex fringes, and empty line indication
   Emacs can indicate empty lines at the end of the buffer with a
 special bitmap on the left fringe of the window.  To enable this
 feature, set the buffer-local variable @code{indicate-empty-lines} to
 a non-@code{nil} value.  The default value of this variable is
 controlled by the variable @code{default-indicate-empty-lines};
 by setting that variable, you can enable or disable this feature
-for all new buffers.
+for all new buffers.  (This feature currently doesn't work on
+character terminals.)
 
 @node Scrolling
 @section Scrolling
@@ -726,7 +761,7 @@ an icon instead of @samp{Mail} by customizing
 line.  You can customize @code{display-time-mail-face} to make the mail
 indicator prominent.
 
-@cindex mode line, 3D appearence
+@cindex mode line, 3D appearance
 @cindex attributes of mode line, changing
 @cindex non-integral number of lines in a window
   By default, the mode line is drawn on graphics displays with
@@ -784,10 +819,10 @@ users should skip it.
   The variable @code{mode-line-inverse-video} is an obsolete way of
 controlling whether the mode line is displayed in inverse video; the
 preferred way of doing this is to change the @code{mode-line} face.
-@xref{Mode Line}.  If you specify the foreground color for the
-@code{mode-line} face, and @code{mode-line-inverse-video} is
-non-@code{nil}, then the default background color for that face is the
-usual foreground color.  @xref{Faces}.
+@xref{Mode Line}.  However, if @code{mode-line-inverse-video} has a
+value of @code{nil}, then the @code{mode-line} face will be ignored,
+and mode-lines will be drawn using the default text face.
+@xref{Faces}.
 
 @vindex inverse-video
   If the variable @code{inverse-video} is non-@code{nil}, Emacs attempts
@@ -877,17 +912,25 @@ or off, customize the group @code{cursor}.  You can also control the
 amount of time Emacs must remain busy before the busy indicator is
 displayed, by setting the variable @code{hourglass-delay}.
 
+@findex tty-suppress-bold-inverse-default-colors
+  On some text-only terminals, bold face and inverse video together
+result in text that is hard to read.  Call the function
+@code{tty-suppress-bold-inverse-default-colors} with a non-@code{nil}
+argument to suppress the effect of bold-face in this case.
+
 @node Cursor Display
 @section Displaying the Cursor
 
 @findex hl-line-mode
+@findex global-hl-line-mode
 @cindex highlight current line
 @findex blink-cursor-mode
 @cindex cursor, locating visually
 @cindex cursor, blinking
   There are a number of ways to customize the display of the cursor.
-@kbd{M-x hl-line-mode} enables or disables a global minor mode which
-highlights the line containing point.  On window systems, the command
+@kbd{M-x hl-line-mode} enables or disables a minor mode which
+highlights the line containing point.  @kbd{M-x global-hl-line-mode}
+enables the minor mode globally.  On window systems, the command
 @kbd{M-x blink-cursor-mode} turns on or off the blinking of the
 cursor.  (On terminals, the terminal itself blinks the cursor, and
 Emacs has no control over it.)