summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJason Rumney <jasonr@gnu.org>2009-02-24 13:33:58 +0000
committerJason Rumney <jasonr@gnu.org>2009-02-24 13:33:58 +0000
commitb545ff9ce2fd57d11e0d70c5a3581739529ac28b (patch)
tree6129e4d4517430d8e6592df14637472402f858f6
parentf097e22350db31631c3cbda77f50e98400c89512 (diff)
downloademacs-b545ff9ce2fd57d11e0d70c5a3581739529ac28b.tar.gz
(Fontsets): Mention fontset-default, font specs and fallback fontsets.
(Defining Fontsets): Mention ns and w32 variants of standard-fontset-spec. Update description of startup fontset to match Emacs 23 behavior. (Modifying Fontsets): New section.
-rw-r--r--doc/emacs/ChangeLog9
-rw-r--r--doc/emacs/mule.texi86
2 files changed, 78 insertions, 17 deletions
diff --git a/doc/emacs/ChangeLog b/doc/emacs/ChangeLog
index 0a670cdf26a..093eb775138 100644
--- a/doc/emacs/ChangeLog
+++ b/doc/emacs/ChangeLog
@@ -1,3 +1,12 @@
+2009-02-24 Jason Rumney <jasonr@gnu.org>
+
+ * mule.texi (Fontsets): Mention fontset-default, font specs and
+ fallback fontsets.
+ (Defining Fontsets): Mention ns and w32 variants of
+ standard-fontset-spec. Update description of startup fontset to match
+ Emacs 23 behavior.
+ (Modifying Fontsets): New section.
+
2009-02-23 Adrian Robert <Adrian.B.Robert@gmail.com>
* macos.texi (Mac / GNUstep Basics, Mac / GNUstep Customization):
diff --git a/doc/emacs/mule.texi b/doc/emacs/mule.texi
index 6502e9b1d6a..7b3cb9d3e0f 100644
--- a/doc/emacs/mule.texi
+++ b/doc/emacs/mule.texi
@@ -1333,8 +1333,10 @@ non-graphic characters.
A font typically defines shapes for a single alphabet or script.
Therefore, displaying the entire range of scripts that Emacs supports
requires a collection of many fonts. In Emacs, such a collection is
-called a @dfn{fontset}. A fontset is defined by a list of fonts, each
-assigned to handle a range of character codes.
+called a @dfn{fontset}. A fontset is defined by a list of font specs,
+each assigned to handle a range of character codes, and may fall back
+on another fontset for characters which are not covered by the fonts
+it specifies.
Each fontset has a name, like a font. However, while fonts are
stored in the system and the available font names are defined by the
@@ -1347,11 +1349,15 @@ use for them has no font for those characters.@footnote{The Emacs
installation instructions have information on additional font
support.}
- Emacs creates two fontsets automatically: the @dfn{standard fontset}
-and the @dfn{startup fontset}. The standard fontset is most likely to
-have fonts for a wide variety of non-@acronym{ASCII} characters;
-however, this is not the default for Emacs to use. (By default, Emacs
-tries to find a font that has bold and italic variants.) You can
+ Emacs creates three fontsets automatically: the @dfn{standard
+fontset}, the @dfn{startup fontset} and the @dfn{default fontset}.
+The default fontset is most likely to have fonts for a wide variety of
+non-@acronym{ASCII} characters and is the default fallback for the
+other two fontsets, and if you set a default font rather than fontset.
+However it does not specify font family names, so results can be
+somewhat random if you use it directly. The standard fontset merely
+falls back on the default fontset without defining any modifications
+of its own, and is defined for backwards compatibility. You can
specify use of the standard fontset with the @samp{-fn} option. For
example,
@@ -1373,8 +1379,10 @@ empty box instead.
@section Defining fontsets
@vindex standard-fontset-spec
+@vindex w32-standard-fontset-spec
+@vindex ns-standard-fontset-spec
@cindex standard fontset
- Emacs creates a standard fontset automatically according to the value
+ When running on X, Emacs creates a standard fontset automatically according to the value
of @code{standard-fontset-spec}. This fontset's name is
@example
@@ -1384,19 +1392,23 @@ of @code{standard-fontset-spec}. This fontset's name is
@noindent
or just @samp{fontset-standard} for short.
+ On GNUstep and Mac, fontset-standard is created using the value of
+@code{ns-standard-fontset-spec}, and on Windows it is
+created using the value of @code{w32-standard-fontset-spec}.
+
Bold, italic, and bold-italic variants of the standard fontset are
created automatically. Their names have @samp{bold} instead of
@samp{medium}, or @samp{i} instead of @samp{r}, or both.
@cindex startup fontset
- If you specify a default @acronym{ASCII} font with the @samp{Font} resource or
-the @samp{-fn} argument, Emacs generates a fontset from it
-automatically. This is the @dfn{startup fontset} and its name is
-@code{fontset-startup}. It does this by replacing the @var{foundry},
-@var{family}, @var{add_style}, and @var{average_width} fields of the
-font name with @samp{*}, replacing @var{charset_registry} field with
-@samp{fontset}, and replacing @var{charset_encoding} field with
-@samp{startup}, then using the resulting string to specify a fontset.
+ Emacs generates a fontset automatically, based on any default
+@acronym{ASCII} font that you specify with the @samp{Font} resource or
+the @samp{-fn} argument, or the default font that Emacs found when it
+started. This is the @dfn{startup fontset} and its name is
+@code{fontset-startup}. It does this by replacing the
+@var{charset_registry} field with @samp{fontset}, and replacing
+@var{charset_encoding} field with @samp{startup}, then using the
+resulting string to specify a fontset.
For instance, if you start Emacs this way,
@@ -1409,9 +1421,14 @@ Emacs generates the following fontset and uses it for the initial X
window frame:
@example
--*-*-medium-r-normal-*-14-140-*-*-*-*-fontset-startup
+-*-courier-medium-r-normal-*-14-140-*-*-*-*-fontset-startup
@end example
+ The startup fontset will use the font that you specify or a variant
+with a different registry and encoding for all the characters which
+are supported by that font, and fallback on @samp{fontset-default} for
+other characters.
+
With the X resource @samp{Emacs.Font}, you can specify a fontset name
just like an actual font name. But be careful not to specify a fontset
name in a wildcard resource like @samp{Emacs*Font}---that wildcard
@@ -1496,6 +1513,41 @@ call this function explicitly to create a fontset.
@xref{Font X}, for more information about font naming in X.
+@node Modifying Fontsets
+@section Modifying Fontsets
+@cindex fontsets, modifying
+@findex set-fontset-font
+
+ Fontsets do not always have to be created from scratch. If only
+minor changes are required it may be easier to modify an existing
+fontset. Modifying @samp{fontset-default} will also affect other
+fontsets that use it as a fallback, so can be an effective way of
+fixing problems with the fonts that Emacs chooses for a particular
+script.
+
+Fontsets can be modified using the function @code{set-fontset-font},
+specifying a character, a charset, a script, or a range of characters
+to modify the font for, and a font-spec for the font to be used. Some
+examples are:
+
+@example
+;; Use Liberation Mono for latin-3 charset.
+(set-fontset-font "fontset-default" 'iso-8859-3 "Liberation Mono")
+
+;; Prefer a big5 font for han characters
+(set-fontset-font "fontset-default" 'han (font-spec :registry "big5")
+ nil 'prepend)
+
+;; Use DejaVu Sans Mono as a fallback in fontset-startup before
+;; resorting to fontset-default.
+(set-fontset-font "fontset-startup" nil "DejaVu Sans Mono" nil 'append)
+
+;; Use MyPrivateFont for the Unicode private use area.
+(set-fontset-font "fontset-default" '(#xe000 . #xf8ff) "MyPrivateFont")
+
+@end example
+
+
@node Undisplayable Characters
@section Undisplayable Characters