such as U+200C (ZWNJ), U+200E (LRM), but
excluding characters that have graphic images,
such as U+00AD (SHY).
- `variation-selectors': U+FE00..U+FE0F, used for choosing between
- glyph variations (e.g. Emoji vs Text
- presentation).
- `no-font': characters for which no suitable font is found.
- For character terminals, characters that cannot
- be encoded by `terminal-coding-system' or those
- for which the terminal has no glyphs.
+ `bidi-control': A subset of `format-control', but only characters
+ that are relevant for bidirectional formatting control,
+ like U+2069 (PDI) and U+202B (RLE).
+ `variation-selectors':
+ Characters in the range U+FE00..U+FE0F and
- U+E0100..U+E01EF, used for selecting alternate glyph
- presentations, such as Emoji vs Text presentation, of
- the preceding character(s).
- `no-font': For GUI frames, characters for which no suitable
- font is found; for text-mode frames, characters
- that cannot be encoded by `terminal-coding-system'.
++ U+E0100..U+E01EF, used for choosing between
++ glyph variations, such as Emoji vs Text
++ presentation, of the preceding character(s).
++ `no-font': For GUI frames, characters for which no
++ suitable font is found; for text-mode frames,
++ characters that cannot be encoded by
++ `terminal-coding-system' or those for which
++ the terminal has no glyphs.
METHOD must be one of these symbols:
`zero-width': don't display.
&& CHAR_TABLE_EXTRA_SLOTS (XCHAR_TABLE (Vglyphless_char_display)) >= 1)
{
if (c >= 0)
- glyphless_method = CHAR_TABLE_REF (Vglyphless_char_display, c);
+ {
+ glyphless_method = CHAR_TABLE_REF (Vglyphless_char_display, c);
+ if (CONSP (glyphless_method))
+ glyphless_method = FRAME_WINDOW_P (it->f)
+ ? XCAR (glyphless_method)
+ : XCDR (glyphless_method);
+ }
else
glyphless_method = XCHAR_TABLE (Vglyphless_char_display)->extras[0];
+
+ if (CONSP (glyphless_method))
+ glyphless_method = FRAME_WINDOW_P (it->f)
+ ? XCAR (glyphless_method)
+ : XCDR (glyphless_method);
}
retry:
display method for graphical terminals and text terminals respectively.
GRAPHICAL and TEXT should each have one of the values listed above.
- The char-table has one extra slot to control the display of a character for
- which no font is found. This slot only takes effect on graphical terminals.
- Its value should be an ASCII acronym string, `hex-code', `empty-box', or
- `thin-space'. It could also be a cons cell of any two of these, to specify
- separate values for graphical and text terminals.
- The default is `empty-box'.
-The char-table has one extra slot to control the display of characters for
-which no font is found on graphical terminals, and characters that cannot
-be displayed by text-mode terminals. Its value should be an ASCII acronym
-string, `hex-code', `empty-box', or `thin-space'. The default is `hex-code'.
++The char-table has one extra slot to control the display of characters
++for which no font is found on graphical terminals, and characters that
++cannot be displayed by text-mode terminals. Its value should be an
++ASCII acronym string, `hex-code', `empty-box', or `thin-space'. It
++could also be a cons cell of any two of these, to specify separate
++values for graphical and text terminals. The default is `empty-box'.
+
+ With the obvious exception of `zero-width', all the other representations
+ are displayed using the face `glyphless-char'.
If a character has a non-nil entry in an active display table, the
display table takes effect; in this case, Emacs does not consult