annotate src/fontset.c @ 105124:ff7266798210

(bookmark-write-file): Avoid calling `pp' with large list, to workaround performance problem (bug#4485).
author Stefan Monnier <monnier@iro.umontreal.ca>
date Sun, 20 Sep 2009 14:54:17 +0000
parents 8f1c018c050c
children cc5bde43f76d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1 /* Fontset handler.
100951
e038c1a8307c Add 2009 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 100168
diff changeset
2 Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
75227
e90d04cd455a Update copyright for years from Emacs 21 to present (mainly adding
Glenn Morris <rgm@gnu.org>
parents: 74605
diff changeset
3 Free Software Foundation, Inc.
74605
6ee41fdd69ff Update AIST copyright years.
Kenichi Handa <handa@m17n.org>
parents: 71605
diff changeset
4 Copyright (C) 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
100951
e038c1a8307c Add 2009 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 100168
diff changeset
5 2005, 2006, 2007, 2008, 2009
67658
547f2b420666 Copyright fixed
Kenichi Handa <handa@m17n.org>
parents: 64770
diff changeset
6 National Institute of Advanced Industrial Science and Technology (AIST)
547f2b420666 Copyright fixed
Kenichi Handa <handa@m17n.org>
parents: 64770
diff changeset
7 Registration Number H14PRO021
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
8 Copyright (C) 2003, 2006
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
9 National Institute of Advanced Industrial Science and Technology (AIST)
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
10 Registration Number H13PRO009
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
11
17071
70194012fb3a Fix FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 17052
diff changeset
12 This file is part of GNU Emacs.
70194012fb3a Fix FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 17052
diff changeset
13
94963
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94928
diff changeset
14 GNU Emacs is free software: you can redistribute it and/or modify
17071
70194012fb3a Fix FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 17052
diff changeset
15 it under the terms of the GNU General Public License as published by
94963
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94928
diff changeset
16 the Free Software Foundation, either version 3 of the License, or
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94928
diff changeset
17 (at your option) any later version.
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
18
17071
70194012fb3a Fix FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 17052
diff changeset
19 GNU Emacs is distributed in the hope that it will be useful,
70194012fb3a Fix FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 17052
diff changeset
20 but WITHOUT ANY WARRANTY; without even the implied warranty of
70194012fb3a Fix FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 17052
diff changeset
21 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
70194012fb3a Fix FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 17052
diff changeset
22 GNU General Public License for more details.
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
23
17071
70194012fb3a Fix FSF address in comment.
Karl Heuer <kwzh@gnu.org>
parents: 17052
diff changeset
24 You should have received a copy of the GNU General Public License
94963
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94928
diff changeset
25 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
26
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
27 /* #define FONTSET_DEBUG */
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
28
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
29 #include <config.h>
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
30 #include <stdio.h>
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
31
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
32 #include "lisp.h"
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
33 #include "blockinput.h"
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
34 #include "buffer.h"
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
35 #include "character.h"
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
36 #include "charset.h"
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
37 #include "ccl.h"
31102
6a0caa788013 Include keyboard.h before frame.h.
Andrew Innes <andrewi@gnu.org>
parents: 30941
diff changeset
38 #include "keyboard.h"
23517
73f09e7bc96e Include frame.h before fontset.h.
Kenichi Handa <handa@m17n.org>
parents: 22719
diff changeset
39 #include "frame.h"
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
40 #include "dispextern.h"
89865
d2b1cc2ef7f1 Include "intervals.h".
Kenichi Handa <handa@m17n.org>
parents: 89826
diff changeset
41 #include "intervals.h"
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
42 #include "fontset.h"
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
43 #include "window.h"
52654
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
44 #ifdef HAVE_X_WINDOWS
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
45 #include "xterm.h"
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
46 #endif
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
47 #ifdef WINDOWSNT
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
48 #include "w32term.h"
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
49 #endif
96675
d45acf0c8d23 merging Emacs.app (NeXTstep port)
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 96655
diff changeset
50 #ifdef HAVE_NS
d45acf0c8d23 merging Emacs.app (NeXTstep port)
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 96655
diff changeset
51 #include "nsterm.h"
d45acf0c8d23 merging Emacs.app (NeXTstep port)
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 96655
diff changeset
52 #endif
82992
5de4189e659d Got rid of the rif (window-based redisplay interface) global variable.
Karoly Lorentey <lorentey@elte.hu>
parents: 53353
diff changeset
53 #include "termhooks.h"
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
54
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
55 #include "font.h"
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
56
89483
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
57 #undef xassert
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
58 #ifdef FONTSET_DEBUG
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
59 #define xassert(X) do {if (!(X)) abort ();} while (0)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
60 #undef INLINE
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
61 #define INLINE
89483
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
62 #else /* not FONTSET_DEBUG */
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
63 #define xassert(X) (void) 0
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
64 #endif /* not FONTSET_DEBUG */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
65
88546
7471723e43b0 (Fclear_face_cache): Declare.
Dave Love <fx@gnu.org>
parents: 88500
diff changeset
66 EXFUN (Fclear_face_cache, 1);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
67
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
68 /* FONTSET
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
69
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
70 A fontset is a collection of font related information to give
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
71 similar appearance (style, etc) of characters. A fontset has two
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
72 roles. One is to use for the frame parameter `font' as if it is an
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
73 ASCII font. In that case, Emacs uses the font specified for
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
74 `ascii' script for the frame's default font.
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
75
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
76 Another role, the more important one, is to provide information
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
77 about which font to use for each non-ASCII character.
41987
34952771ae85 Fix typos, remove unnecessary space.
Pavel Janík <Pavel@Janik.cz>
parents: 41052
diff changeset
78
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
79 There are two kinds of fontsets; base and realized. A base fontset
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
80 is created by `new-fontset' from Emacs Lisp explicitly. A realized
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
81 fontset is created implicitly when a face is realized for ASCII
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
82 characters. A face is also realized for non-ASCII characters based
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
83 on an ASCII face. All of non-ASCII faces based on the same ASCII
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
84 face share the same realized fontset.
89483
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
85
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
86 A fontset object is implemented by a char-table whose default value
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
87 and parent are always nil.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
88
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
89 An element of a base fontset is a vector of FONT-DEFs which itself
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
90 is a vector [ FONT-SPEC ENCODING REPERTORY ].
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
91
101605
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
92 An element of a realized fontset is nil, t, 0, or a vector of this
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
93 form:
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
94
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
95 [ CHARSET-ORDERED-LIST-TICK PREFERRED-RFONT-DEF
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
96 RFONT-DEF0 RFONT-DEF1 ... ]
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
97
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
98 RFONT-DEFn (i.e. Realized FONT-DEF) has this form:
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
99
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
100 [ FACE-ID FONT-DEF FONT-OBJECT SORTING-SCORE ]
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
101
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
102 RFONT-DEFn are automatically reordered by the current charset
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
103 priority list.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
104
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
105 The value nil means that we have not yet generated the above vector
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
106 from the base of the fontset.
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
107
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
108 The value t means that no font is available for the corresponding
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
109 range of characters.
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
110
101605
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
111 The value 0 means that no font is available for the corresponding
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
112 range of characters in this fontset, but may be available in the
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
113 default fontset.
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
114
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
115
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
116 A fontset has 9 extra slots.
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
117
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
118 The 1st slot: the ID number of the fontset
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
119
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
120 The 2nd slot:
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
121 base: the name of the fontset
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
122 realized: nil
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
123
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
124 The 3rd slot:
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
125 base: nil
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
126 realized: the base fontset
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
127
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
128 The 4th slot:
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
129 base: nil
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
130 realized: the frame that the fontset belongs to
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
131
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
132 The 5th slot:
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
133 base: the font name for ASCII characters
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
134 realized: nil
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
135
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
136 The 6th slot:
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
137 base: nil
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
138 realized: the ID number of a face to use for characters that
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
139 has no font in a realized fontset.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
140
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
141 The 7th slot:
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
142 base: nil
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
143 realized: Alist of font index vs the corresponding repertory
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
144 char-table.
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
145
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
146 The 8th slot:
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
147 base: nil
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
148 realized: If the base is not the default fontset, a fontset
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
149 realized from the default fontset, else nil.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
150
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
151 The 9th slot:
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
152 base: Same as element value (but for fallback fonts).
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
153 realized: Likewise.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
154
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
155 All fontsets are recorded in the vector Vfontset_table.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
156
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
157
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
158 DEFAULT FONTSET
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
159
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
160 There's a special base fontset named `default fontset' which
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
161 defines the default font specifications. When a base fontset
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
162 doesn't specify a font for a specific character, the corresponding
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
163 value in the default fontset is used.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
164
30398
dde5ab185aad (fontset_ref): Remove INLINE declaration.
Kenichi Handa <handa@m17n.org>
parents: 30172
diff changeset
165 The parent of a realized fontset created for such a face that has
dde5ab185aad (fontset_ref): Remove INLINE declaration.
Kenichi Handa <handa@m17n.org>
parents: 30172
diff changeset
166 no fontset is the default fontset.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
167
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
168
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
169 These structures are hidden from the other codes than this file.
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
170 The other codes handle fontsets only by their ID numbers. They
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
171 usually use the variable name `fontset' for IDs. But, in this
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
172 file, we always use varialbe name `id' for IDs, and name `fontset'
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
173 for an actual fontset object, i.e., char-table.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
174
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
175 */
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
176
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
177 /********** VARIABLES and FUNCTION PROTOTYPES **********/
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
178
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
179 extern Lisp_Object Qfont;
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
180 static Lisp_Object Qfontset;
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
181 static Lisp_Object Qfontset_info;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
182 static Lisp_Object Qprepend, Qappend;
103271
f3d9124c9d27 (Qlatin): Don't make it static.
Kenichi Handa <handa@m17n.org>
parents: 103115
diff changeset
183 Lisp_Object Qlatin;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
184
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
185 /* Vector containing all fontsets. */
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
186 static Lisp_Object Vfontset_table;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
187
41987
34952771ae85 Fix typos, remove unnecessary space.
Pavel Janík <Pavel@Janik.cz>
parents: 41052
diff changeset
188 /* Next possibly free fontset ID. Usually this keeps the minimum
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
189 fontset ID not yet used. */
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
190 static int next_fontset_id;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
191
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
192 /* The default fontset. This gives default FAMILY and REGISTRY of
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
193 font for each character. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
194 static Lisp_Object Vdefault_fontset;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
195
91266
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
196 Lisp_Object Vfont_encoding_charset_alist;
17112
5c48ff325655 (syms_of_fontset): Intern Qfontset. Declare new lisp
Kenichi Handa <handa@m17n.org>
parents: 17071
diff changeset
197 Lisp_Object Vuse_default_ascent;
19282
09a1536debb4 (Vignore_relative_composition): New variable.
Kenichi Handa <handa@m17n.org>
parents: 19172
diff changeset
198 Lisp_Object Vignore_relative_composition;
19450
895dc2520755 (Valternate_fontname_alist): Name changed from
Kenichi Handa <handa@m17n.org>
parents: 19282
diff changeset
199 Lisp_Object Valternate_fontname_alist;
17730
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
200 Lisp_Object Vfontset_alias_alist;
26858
7cc081b4e084 (Vvertical_centering_font_regexp): New variable.
Kenichi Handa <handa@m17n.org>
parents: 26164
diff changeset
201 Lisp_Object Vvertical_centering_font_regexp;
90509
c1ec6b950928 (Votf_script_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90475
diff changeset
202 Lisp_Object Votf_script_alist;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
203
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
204 /* Check if any window system is used now. */
20315
931b4ddf7966 Protoize functions declarations.
Andreas Schwab <schwab@suse.de>
parents: 19450
diff changeset
205 void (*check_window_system_func) P_ ((void));
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
206
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
207
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
208 /* Prototype declarations for static functions. */
89069
c2201502f37e (fontset_add): Return Lisp_Object.
Dave Love <fx@gnu.org>
parents: 89006
diff changeset
209 static Lisp_Object fontset_add P_ ((Lisp_Object, Lisp_Object, Lisp_Object,
c2201502f37e (fontset_add): Return Lisp_Object.
Dave Love <fx@gnu.org>
parents: 89006
diff changeset
210 Lisp_Object));
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
211 static Lisp_Object fontset_find_font P_ ((Lisp_Object, int, struct face *,
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
212 int, int));
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
213 static void reorder_font_vector P_ ((Lisp_Object, struct font *));
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
214 static Lisp_Object fontset_font P_ ((Lisp_Object, int, struct face *, int));
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
215 static Lisp_Object make_fontset P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
216 static Lisp_Object fontset_pattern_regexp P_ ((Lisp_Object));
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
217 static void accumulate_script_ranges P_ ((Lisp_Object, Lisp_Object,
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
218 Lisp_Object));
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
219 Lisp_Object find_font_encoding P_ ((Lisp_Object));
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
220
89614
355fc0282e50 (set_fontset_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 89610
diff changeset
221 static void set_fontset_font P_ ((Lisp_Object, Lisp_Object));
355fc0282e50 (set_fontset_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 89610
diff changeset
222
88982
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
223 #ifdef FONTSET_DEBUG
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
224
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
225 /* Return 1 if ID is a valid fontset id, else return 0. */
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
226
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
227 static int
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
228 fontset_id_valid_p (id)
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
229 int id;
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
230 {
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
231 return (id >= 0 && id < ASIZE (Vfontset_table) - 1);
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
232 }
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
233
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
234 #endif
d50b0a9ea97a (fontset_add): Make the type `int'.
Kenichi Handa <handa@m17n.org>
parents: 88968
diff changeset
235
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
236
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
237
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
238 /********** MACROS AND FUNCTIONS TO HANDLE FONTSET **********/
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
239
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
240 /* Return the fontset with ID. No check of ID's validness. */
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
241 #define FONTSET_FROM_ID(id) AREF (Vfontset_table, id)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
242
30398
dde5ab185aad (fontset_ref): Remove INLINE declaration.
Kenichi Handa <handa@m17n.org>
parents: 30172
diff changeset
243 /* Macros to access special values of FONTSET. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
244 #define FONTSET_ID(fontset) XCHAR_TABLE (fontset)->extras[0]
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
245
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
246 /* Macros to access special values of (base) FONTSET. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
247 #define FONTSET_NAME(fontset) XCHAR_TABLE (fontset)->extras[1]
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
248 #define FONTSET_ASCII(fontset) XCHAR_TABLE (fontset)->extras[4]
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
249 #define FONTSET_SPEC(fontset) XCHAR_TABLE (fontset)->extras[5]
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
250
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
251 /* Macros to access special values of (realized) FONTSET. */
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
252 #define FONTSET_BASE(fontset) XCHAR_TABLE (fontset)->extras[2]
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
253 #define FONTSET_FRAME(fontset) XCHAR_TABLE (fontset)->extras[3]
91908
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
254 #define FONTSET_OBJLIST(fontset) XCHAR_TABLE (fontset)->extras[4]
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
255 #define FONTSET_NOFONT_FACE(fontset) XCHAR_TABLE (fontset)->extras[5]
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
256 #define FONTSET_REPERTORY(fontset) XCHAR_TABLE (fontset)->extras[6]
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
257 #define FONTSET_DEFAULT(fontset) XCHAR_TABLE (fontset)->extras[7]
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
258
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
259 /* For both base and realized fontset. */
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
260 #define FONTSET_FALLBACK(fontset) XCHAR_TABLE (fontset)->extras[8]
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
261
89428
eed327e0bad3 (BASE_FONTSET_P): Check FONTSET_BASE, not
Kenichi Handa <handa@m17n.org>
parents: 89349
diff changeset
262 #define BASE_FONTSET_P(fontset) (NILP (FONTSET_BASE (fontset)))
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
263
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
264
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
265 /* Macros for FONT-DEF and RFONT-DEF of fontset. */
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
266 #define FONT_DEF_NEW(font_def, font_spec, encoding, repertory) \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
267 do { \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
268 (font_def) = Fmake_vector (make_number (3), (font_spec)); \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
269 ASET ((font_def), 1, encoding); \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
270 ASET ((font_def), 2, repertory); \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
271 } while (0)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
272
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
273 #define FONT_DEF_SPEC(font_def) AREF (font_def, 0)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
274 #define FONT_DEF_ENCODING(font_def) AREF (font_def, 1)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
275 #define FONT_DEF_REPERTORY(font_def) AREF (font_def, 2)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
276
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
277 #define RFONT_DEF_FACE(rfont_def) AREF (rfont_def, 0)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
278 #define RFONT_DEF_SET_FACE(rfont_def, face_id) \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
279 ASET ((rfont_def), 0, make_number (face_id))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
280 #define RFONT_DEF_FONT_DEF(rfont_def) AREF (rfont_def, 1)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
281 #define RFONT_DEF_SPEC(rfont_def) FONT_DEF_SPEC (AREF (rfont_def, 1))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
282 #define RFONT_DEF_REPERTORY(rfont_def) FONT_DEF_REPERTORY (AREF (rfont_def, 1))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
283 #define RFONT_DEF_OBJECT(rfont_def) AREF (rfont_def, 2)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
284 #define RFONT_DEF_SET_OBJECT(rfont_def, object) \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
285 ASET ((rfont_def), 2, (object))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
286 #define RFONT_DEF_SCORE(rfont_def) XINT (AREF (rfont_def, 3))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
287 #define RFONT_DEF_SET_SCORE(rfont_def, score) \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
288 ASET ((rfont_def), 3, make_number (score))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
289 #define RFONT_DEF_NEW(rfont_def, font_def) \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
290 do { \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
291 (rfont_def) = Fmake_vector (make_number (4), Qnil); \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
292 ASET ((rfont_def), 1, (font_def)); \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
293 RFONT_DEF_SET_SCORE ((rfont_def), 0); \
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
294 } while (0)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
295
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
296
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
297 /* Return the element of FONTSET for the character C. If FONTSET is a
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
298 base fontset other then the default fontset and FONTSET doesn't
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
299 contain information for C, return the information in the default
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
300 fontset. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
301
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
302 #define FONTSET_REF(fontset, c) \
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
303 (EQ (fontset, Vdefault_fontset) \
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
304 ? CHAR_TABLE_REF (fontset, c) \
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
305 : fontset_ref ((fontset), (c)))
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
306
30398
dde5ab185aad (fontset_ref): Remove INLINE declaration.
Kenichi Handa <handa@m17n.org>
parents: 30172
diff changeset
307 static Lisp_Object
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
308 fontset_ref (fontset, c)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
309 Lisp_Object fontset;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
310 int c;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
311 {
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
312 Lisp_Object elt;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
313
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
314 elt = CHAR_TABLE_REF (fontset, c);
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
315 if (NILP (elt) && ! EQ (fontset, Vdefault_fontset)
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
316 /* Don't check Vdefault_fontset for a realized fontset. */
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
317 && NILP (FONTSET_BASE (fontset)))
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
318 elt = CHAR_TABLE_REF (Vdefault_fontset, c);
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
319 return elt;
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
320 }
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
321
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
322 /* Set elements of FONTSET for characters in RANGE to the value ELT.
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
323 RANGE is a cons (FROM . TO), where FROM and TO are character codes
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
324 specifying a range. */
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
325
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
326 #define FONTSET_SET(fontset, range, elt) \
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
327 Fset_char_table_range ((fontset), (range), (elt))
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
328
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
329
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
330 /* Modify the elements of FONTSET for characters in RANGE by replacing
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
331 with ELT or adding ELT. RANGE is a cons (FROM . TO), where FROM
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
332 and TO are character codes specifying a range. If ADD is nil,
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
333 replace with ELT, if ADD is `prepend', prepend ELT, otherwise,
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
334 append ELT. */
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
335
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
336 #define FONTSET_ADD(fontset, range, elt, add) \
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
337 (NILP (add) \
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
338 ? (NILP (range) \
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
339 ? (FONTSET_FALLBACK (fontset) = Fmake_vector (make_number (1), (elt))) \
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
340 : Fset_char_table_range ((fontset), (range), \
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
341 Fmake_vector (make_number (1), (elt)))) \
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
342 : fontset_add ((fontset), (range), (elt), (add)))
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
343
89069
c2201502f37e (fontset_add): Return Lisp_Object.
Dave Love <fx@gnu.org>
parents: 89006
diff changeset
344 static Lisp_Object
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
345 fontset_add (fontset, range, elt, add)
88931
74d18470865c (fontset_add): Declare args. Call make_number
Dave Love <fx@gnu.org>
parents: 88903
diff changeset
346 Lisp_Object fontset, range, elt, add;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
347 {
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
348 Lisp_Object args[2];
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
349 int idx = (EQ (add, Qappend) ? 0 : 1);
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
350
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
351 args[1 - idx] = Fmake_vector (make_number (1), elt);
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
352
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
353 if (CONSP (range))
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
354 {
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
355 int from = XINT (XCAR (range));
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
356 int to = XINT (XCDR (range));
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
357 int from1, to1;
89483
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
358
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
359 do {
99980
0a43374c0145 (fontset_add): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 98582
diff changeset
360 from1 = from, to1 = to;
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
361 args[idx] = char_table_ref_and_range (fontset, from, &from1, &to1);
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
362 char_table_set_range (fontset, from, to1,
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
363 NILP (args[idx]) ? args[1 - idx]
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
364 : Fvconcat (2, args));
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
365 from = to1 + 1;
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
366 } while (from < to);
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
367 }
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
368 else
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
369 {
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
370 args[idx] = FONTSET_FALLBACK (fontset);
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
371 FONTSET_FALLBACK (fontset)
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
372 = NILP (args[idx]) ? args[1 - idx] : Fvconcat (2, args);
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
373 }
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
374 return Qnil;
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
375 }
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
376
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
377 static int
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
378 fontset_compare_rfontdef (val1, val2)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
379 const void *val1, *val2;
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
380 {
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
381 return (RFONT_DEF_SCORE (*(Lisp_Object *) val1)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
382 - RFONT_DEF_SCORE (*(Lisp_Object *) val2));
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
383 }
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
384
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
385 /* Update FONT-GROUP which has this form:
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
386 [ CHARSET-ORDERED-LIST-TICK PREFERRED-RFONT-DEF
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
387 RFONT-DEF0 RFONT-DEF1 ... ]
95256
993b2f1f702e *** empty log message ***
Juanma Barranquero <lekktu@gmail.com>
parents: 95230
diff changeset
388 Reorder RFONT-DEFs according to the current language, and update
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
389 CHARSET-ORDERED-LIST-TICK.
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
390
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
391 If PREFERRED_FAMILY is not nil, that family has the higher priority
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
392 if the encoding charsets or languages in font-specs are the same. */
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
393
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
394 extern Lisp_Object Fassoc_string ();
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
395
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
396 static void
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
397 reorder_font_vector (font_group, font)
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
398 Lisp_Object font_group;
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
399 struct font *font;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
400 {
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
401 Lisp_Object vec, font_object;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
402 int size;
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
403 int i;
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
404 int score_changed = 0;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
405
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
406 if (font)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
407 XSETFONT (font_object, font);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
408 else
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
409 font_object = Qnil;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
410
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
411 vec = XCDR (font_group);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
412 size = ASIZE (vec);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
413 /* Exclude the tailing nil element from the reordering. */
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
414 if (NILP (AREF (vec, size - 1)))
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
415 size--;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
416
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
417 for (i = 0; i < size; i++)
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
418 {
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
419 Lisp_Object rfont_def = AREF (vec, i);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
420 Lisp_Object font_def = RFONT_DEF_FONT_DEF (rfont_def);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
421 Lisp_Object font_spec = FONT_DEF_SPEC (font_def);
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
422 int score = RFONT_DEF_SCORE (rfont_def) & 0xFF;
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
423
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
424 if (! font_match_p (font_spec, font_object))
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
425 {
97556
0fc47f017980 (reorder_font_vector): Use encoding charset of fonts
Kenichi Handa <handa@m17n.org>
parents: 97539
diff changeset
426 Lisp_Object encoding = FONT_DEF_ENCODING (font_def);
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
427
97556
0fc47f017980 (reorder_font_vector): Use encoding charset of fonts
Kenichi Handa <handa@m17n.org>
parents: 97539
diff changeset
428 if (! NILP (encoding))
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
429 {
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
430 Lisp_Object tail;
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
431
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
432 for (tail = Vcharset_ordered_list;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
433 ! EQ (tail, Vcharset_non_preferred_head) && CONSP (tail);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
434 score += 0x100, tail = XCDR (tail))
97556
0fc47f017980 (reorder_font_vector): Use encoding charset of fonts
Kenichi Handa <handa@m17n.org>
parents: 97539
diff changeset
435 if (EQ (encoding, XCAR (tail)))
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
436 break;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
437 }
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
438 else
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
439 {
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
440 Lisp_Object lang = Ffont_get (font_spec, QClang);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
441
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
442 if (! NILP (lang)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
443 && ! EQ (lang, Vcurrent_iso639_language)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
444 && (! CONSP (Vcurrent_iso639_language)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
445 || NILP (Fmemq (lang, Vcurrent_iso639_language))))
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
446 score |= 0x100;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
447 }
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
448 }
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
449 if (RFONT_DEF_SCORE (rfont_def) != score)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
450 {
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
451 RFONT_DEF_SET_SCORE (rfont_def, score);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
452 score_changed = 1;
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
453 }
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
454 }
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
455
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
456 if (score_changed)
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
457 qsort (XVECTOR (vec)->contents, size, sizeof (Lisp_Object),
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
458 fontset_compare_rfontdef);
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
459 XSETCAR (font_group, make_number (charset_ordered_list_tick));
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
460 }
91266
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
461
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
462 /* Return a font-group (actually a cons (-1 . FONT-GROUP-VECTOR)) for
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
463 character C in FONTSET. If C is -1, return a fallback font-group.
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
464 If C is not -1, the value may be Qt (FONTSET doesn't have a font
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
465 for C even in the fallback group, or 0 (a font for C may be found
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
466 only in the fallback group). */
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
467
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
468 static Lisp_Object
96573
3de01ebe30b7 * fontset.c (fontset_get_font_group):
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 96556
diff changeset
469 fontset_get_font_group (Lisp_Object fontset, int c)
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
470 {
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
471 Lisp_Object font_group;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
472 Lisp_Object base_fontset;
99980
0a43374c0145 (fontset_add): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 98582
diff changeset
473 int from = 0, to = MAX_CHAR, i;
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
474
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
475 xassert (! BASE_FONTSET_P (fontset));
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
476 if (c >= 0)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
477 font_group = CHAR_TABLE_REF (fontset, c);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
478 else
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
479 font_group = FONTSET_FALLBACK (fontset);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
480 if (! NILP (font_group))
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
481 return font_group;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
482 base_fontset = FONTSET_BASE (fontset);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
483 if (c >= 0)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
484 font_group = char_table_ref_and_range (base_fontset, c, &from, &to);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
485 else
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
486 font_group = FONTSET_FALLBACK (base_fontset);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
487 if (NILP (font_group))
101605
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
488 {
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
489 font_group = make_number (0);
101605
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
490 if (c >= 0)
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
491 char_table_set_range (fontset, from, to, font_group);
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
492 return font_group;
101605
b37403eedfa9 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101601
diff changeset
493 }
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
494 font_group = Fcopy_sequence (font_group);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
495 for (i = 0; i < ASIZE (font_group); i++)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
496 if (! NILP (AREF (font_group, i)))
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
497 {
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
498 Lisp_Object rfont_def;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
499
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
500 RFONT_DEF_NEW (rfont_def, AREF (font_group, i));
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
501 /* Remember the original order. */
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
502 RFONT_DEF_SET_SCORE (rfont_def, i);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
503 ASET (font_group, i, rfont_def);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
504 }
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
505 font_group = Fcons (make_number (-1), font_group);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
506 if (c >= 0)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
507 char_table_set_range (fontset, from, to, font_group);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
508 else
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
509 FONTSET_FALLBACK (fontset) = font_group;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
510 return font_group;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
511 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
512
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
513 /* Return RFONT-DEF (vector) in the realized fontset FONTSET for the
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
514 character C. If no font is found, return Qnil if there's a
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
515 possibility that the default fontset or the fallback font groups
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
516 have a proper font, and return Qt if not.
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
517
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
518 If a font is found but is not yet opened, open it (if FACE is not
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
519 NULL) or return Qnil (if FACE is NULL).
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
520
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
521 ID is a charset-id that must be preferred, or -1 meaning no
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
522 preference.
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
523
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
524 If FALLBACK is nonzero, search only fallback fonts. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
525
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
526 static Lisp_Object
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
527 fontset_find_font (fontset, c, face, id, fallback)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
528 Lisp_Object fontset;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
529 int c;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
530 struct face *face;
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
531 int id, fallback;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
532 {
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
533 Lisp_Object vec, font_group;
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
534 int i, charset_matched = 0, found_index;
98575
7e4ece224094 (fontset_find_font): Check frame validity.
Chong Yidong <cyd@stupidchicken.com>
parents: 97824
diff changeset
535 FRAME_PTR f = (FRAMEP (FONTSET_FRAME (fontset)))
7e4ece224094 (fontset_find_font): Check frame validity.
Chong Yidong <cyd@stupidchicken.com>
parents: 97824
diff changeset
536 ? XFRAME (selected_frame) : XFRAME (FONTSET_FRAME (fontset));
103587
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
537 Lisp_Object rfont_def;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
538
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
539 font_group = fontset_get_font_group (fontset, fallback ? -1 : c);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
540 if (! CONSP (font_group))
101522
561d416172d0 (fontset_find_font): Fix handling of non-cons return
Chong Yidong <cyd@stupidchicken.com>
parents: 101447
diff changeset
541 return font_group;
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
542 vec = XCDR (font_group);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
543 if (ASIZE (vec) == 0)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
544 return Qnil;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
545
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
546 if (ASIZE (vec) > 1)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
547 {
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
548 if (XINT (XCAR (font_group)) != charset_ordered_list_tick)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
549 /* We have just created the font-group,
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
550 or the charset priorities were changed. */
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
551 reorder_font_vector (font_group, face->ascii_face->font);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
552 if (id >= 0)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
553 /* Find a spec matching with the charset ID to try at
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
554 first. */
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
555 for (i = 0; i < ASIZE (vec); i++)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
556 {
103112
35792077cc20 (fontset_find_font): Check if rfont_def is Qnil or not.
Kenichi Handa <handa@m17n.org>
parents: 103098
diff changeset
557 Lisp_Object repertory;
35792077cc20 (fontset_find_font): Check if rfont_def is Qnil or not.
Kenichi Handa <handa@m17n.org>
parents: 103098
diff changeset
558
103587
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
559 rfont_def = AREF (vec, i);
103112
35792077cc20 (fontset_find_font): Check if rfont_def is Qnil or not.
Kenichi Handa <handa@m17n.org>
parents: 103098
diff changeset
560 if (NILP (rfont_def))
35792077cc20 (fontset_find_font): Check if rfont_def is Qnil or not.
Kenichi Handa <handa@m17n.org>
parents: 103098
diff changeset
561 break;
35792077cc20 (fontset_find_font): Check if rfont_def is Qnil or not.
Kenichi Handa <handa@m17n.org>
parents: 103098
diff changeset
562 repertory = FONT_DEF_REPERTORY (RFONT_DEF_FONT_DEF (rfont_def));
91364
1e43b74bf9e5 (reorder_font_vector): Exclude nil elements from the
Kenichi Handa <handa@m17n.org>
parents: 91352
diff changeset
563
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
564 if (XINT (repertory) == id)
91364
1e43b74bf9e5 (reorder_font_vector): Exclude nil elements from the
Kenichi Handa <handa@m17n.org>
parents: 91352
diff changeset
565 {
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
566 charset_matched = i;
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
567 break;
91364
1e43b74bf9e5 (reorder_font_vector): Exclude nil elements from the
Kenichi Handa <handa@m17n.org>
parents: 91352
diff changeset
568 }
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
569 }
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
570 }
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
571
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
572 /* Find the first available font in the vector of RFONT-DEF. */
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
573 for (i = 0; i < ASIZE (vec); i++)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
574 {
103587
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
575 Lisp_Object font_def;
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
576 Lisp_Object font_entity, font_object;
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
577
103788
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
578 found_index = i;
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
579 if (i == 0)
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
580 {
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
581 if (charset_matched > 0)
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
582 {
103788
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
583 /* Try the element matching with the charset ID at first. */
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
584 found_index = charset_matched;
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
585 /* Make this negative so that we don't come here in the
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
586 next loop. */
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
587 charset_matched = - charset_matched;
103788
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
588 /* We must try the first element in the next loop. */
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
589 i--;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
590 }
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
591 }
103788
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
592 else if (i == - charset_matched)
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
593 {
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
594 /* We have already tried this element and the followings
103788
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
595 that have the same font specifications in the first
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
596 iteration. So, skip them all. */
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
597 rfont_def = AREF (vec, i);
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
598 font_def = RFONT_DEF_FONT_DEF (rfont_def);
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
599 for (; i + 1 < ASIZE (vec); i++)
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
600 {
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
601 rfont_def = AREF (vec, i + 1);
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
602 if (NILP (rfont_def))
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
603 break;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
604 if (! EQ (RFONT_DEF_FONT_DEF (rfont_def), font_def))
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
605 break;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
606 }
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
607 continue;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
608 }
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
609
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
610 rfont_def = AREF (vec, found_index);
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
611 if (NILP (rfont_def))
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
612 {
103788
b4588e2be166 (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 103775
diff changeset
613 if (i < 0)
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
614 continue;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
615 /* This is a sign of not to try the other fonts. */
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
616 return Qt;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
617 }
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
618 if (INTEGERP (RFONT_DEF_FACE (rfont_def))
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
619 && XINT (RFONT_DEF_FACE (rfont_def)) < 0)
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
620 /* We couldn't open this font last time. */
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
621 continue;
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
622
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
623 font_object = RFONT_DEF_OBJECT (rfont_def);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
624 if (NILP (font_object))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
625 {
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
626 font_def = RFONT_DEF_FONT_DEF (rfont_def);
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
627
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
628 if (! face)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
629 /* We have not yet opened the font. */
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
630 return Qnil;
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
631 /* Find a font best-matching with the spec without checking
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
632 the support of the character C. That checking is costly,
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
633 and even without the checking, the found font supports C
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
634 in high possibility. */
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
635 font_entity = font_find_for_lface (f, face->lface,
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
636 FONT_DEF_SPEC (font_def), -1);
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
637 if (NILP (font_entity))
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
638 {
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
639 /* Record that no font matches the spec. */
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
640 RFONT_DEF_SET_FACE (rfont_def, -1);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
641 continue;
91136
d54684fee154 (fontset_find_font) [USE_FONT_BACKEND]: Try multiple
Kenichi Handa <handa@m17n.org>
parents: 91053
diff changeset
642 }
95570
b18ab5e0d568 (fontset_find_font): Call font_open_for_lface with the
Kenichi Handa <handa@m17n.org>
parents: 95457
diff changeset
643 font_object = font_open_for_lface (f, font_entity, face->lface,
b18ab5e0d568 (fontset_find_font): Call font_open_for_lface with the
Kenichi Handa <handa@m17n.org>
parents: 95457
diff changeset
644 FONT_DEF_SPEC (font_def));
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
645 if (NILP (font_object))
91136
d54684fee154 (fontset_find_font) [USE_FONT_BACKEND]: Try multiple
Kenichi Handa <handa@m17n.org>
parents: 91053
diff changeset
646 {
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
647 /* Something strange happened, perhaps because of a
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
648 Font-backend problem. Too avoid crashing, record
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
649 that this spec is unsable. It may be better to find
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
650 another font of the same spec, but currently we don't
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
651 have such an API. */
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
652 RFONT_DEF_SET_FACE (rfont_def, -1);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
653 continue;
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
654 }
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
655 RFONT_DEF_SET_OBJECT (rfont_def, font_object);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
656 }
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
657
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
658 if (font_has_char (f, font_object, c))
103587
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
659 goto found;
91364
1e43b74bf9e5 (reorder_font_vector): Exclude nil elements from the
Kenichi Handa <handa@m17n.org>
parents: 91352
diff changeset
660
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
661 /* Find a font already opened, maching with the current spec,
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
662 and supporting C. */
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
663 font_def = RFONT_DEF_FONT_DEF (rfont_def);
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
664 for (; found_index + 1 < ASIZE (vec); found_index++)
61736
e3221787f899 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 60511
diff changeset
665 {
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
666 rfont_def = AREF (vec, found_index + 1);
103115
d6b2b717f098 (fontset_find_font): Check if rfont_def is Qnil or not.
Kenichi Handa <handa@m17n.org>
parents: 103114
diff changeset
667 if (NILP (rfont_def))
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
668 break;
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
669 if (! EQ (RFONT_DEF_FONT_DEF (rfont_def), font_def))
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
670 break;
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
671 font_object = RFONT_DEF_OBJECT (rfont_def);
102417
5a5d05398f9e (fontset_find_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 102414
diff changeset
672 if (! NILP (font_object) && font_has_char (f, font_object, c))
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
673 {
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
674 found_index++;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
675 goto found;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
676 }
89826
b17725d55ba2 (Fset_fontset_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 89811
diff changeset
677 }
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
678
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
679 /* Find a font-entity with the current spec and supporting C. */
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
680 font_entity = font_find_for_lface (f, face->lface,
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
681 FONT_DEF_SPEC (font_def), c);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
682 if (! NILP (font_entity))
61736
e3221787f899 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 60511
diff changeset
683 {
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
684 /* We found a font. Open it and insert a new element for
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
685 that font in VEC. */
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
686 Lisp_Object new_vec;
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
687 int j;
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
688
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
689 font_object = font_open_for_lface (f, font_entity, face->lface,
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
690 Qnil);
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
691 if (NILP (font_object))
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
692 continue;
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
693 RFONT_DEF_NEW (rfont_def, font_def);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
694 RFONT_DEF_SET_OBJECT (rfont_def, font_object);
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
695 RFONT_DEF_SET_SCORE (rfont_def, RFONT_DEF_SCORE (rfont_def));
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
696 new_vec = Fmake_vector (make_number (ASIZE (vec) + 1), Qnil);
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
697 found_index++;
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
698 for (j = 0; j < found_index; j++)
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
699 ASET (new_vec, j, AREF (vec, j));
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
700 ASET (new_vec, j, rfont_def);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
701 for (j++; j < ASIZE (new_vec); j++)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
702 ASET (new_vec, j, AREF (vec, j - 1));
102414
5988cd89cf0b (fontset_find_font): If a font found without
Kenichi Handa <handa@m17n.org>
parents: 102241
diff changeset
703 XSETCDR (font_group, new_vec);
103587
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
704 vec = new_vec;
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
705 goto found;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
706 }
103775
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
707 if (i >= 0)
9bc67103bc1d (fontset_find_font): Fix the logic of handling
Kenichi Handa <handa@m17n.org>
parents: 103587
diff changeset
708 i = found_index;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
709 }
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
710
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
711 FONTSET_SET (fontset, make_number (c), make_number (0));
91364
1e43b74bf9e5 (reorder_font_vector): Exclude nil elements from the
Kenichi Handa <handa@m17n.org>
parents: 91352
diff changeset
712 return Qnil;
103587
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
713
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
714 found:
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
715 if (fallback && found_index > 0)
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
716 {
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
717 /* The order of fonts in the fallback font-group is not that
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
718 important, and it is better to move the found font to the
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
719 first of the group so that the next try will find it
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
720 quickly. */
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
721 for (i = found_index; i > 0; i--)
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
722 ASET (vec, i, AREF (vec, i - 1));
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
723 ASET (vec, 0, rfont_def);
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
724 }
1db851c2440a (fontset_find_font): When a usable rfont_def is found
Kenichi Handa <handa@m17n.org>
parents: 103573
diff changeset
725 return rfont_def;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
726 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
727
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
728
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
729 static Lisp_Object
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
730 fontset_font (fontset, c, face, id)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
731 Lisp_Object fontset;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
732 int c;
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
733 struct face *face;
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
734 int id;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
735 {
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
736 Lisp_Object rfont_def, default_rfont_def;
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
737 Lisp_Object base_fontset;
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
738
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
739 /* Try a font-group of FONTSET. */
103541
1a80fde577a8 (fontset_font): Call FONT_DEFERRED_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103342
diff changeset
740 FONT_DEFERRED_LOG ("current fontset: font for", make_number (c), Qnil);
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
741 rfont_def = fontset_find_font (fontset, c, face, id, 0);
91364
1e43b74bf9e5 (reorder_font_vector): Exclude nil elements from the
Kenichi Handa <handa@m17n.org>
parents: 91352
diff changeset
742 if (VECTORP (rfont_def))
1e43b74bf9e5 (reorder_font_vector): Exclude nil elements from the
Kenichi Handa <handa@m17n.org>
parents: 91352
diff changeset
743 return rfont_def;
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
744 if (NILP (rfont_def))
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
745 FONTSET_SET (fontset, make_number (c), make_number (0));
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
746
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
747 /* Try a font-group of the default fontset. */
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
748 base_fontset = FONTSET_BASE (fontset);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
749 if (! EQ (base_fontset, Vdefault_fontset))
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
750 {
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
751 if (NILP (FONTSET_DEFAULT (fontset)))
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
752 FONTSET_DEFAULT (fontset)
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
753 = make_fontset (FONTSET_FRAME (fontset), Qnil, Vdefault_fontset);
103541
1a80fde577a8 (fontset_font): Call FONT_DEFERRED_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103342
diff changeset
754 FONT_DEFERRED_LOG ("default fontset: font for", make_number (c), Qnil);
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
755 default_rfont_def
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
756 = fontset_find_font (FONTSET_DEFAULT (fontset), c, face, id, 0);
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
757 if (VECTORP (default_rfont_def))
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
758 return default_rfont_def;
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
759 if (NILP (default_rfont_def))
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
760 FONTSET_SET (FONTSET_DEFAULT (fontset), make_number (c),
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
761 make_number (0));
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
762 }
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
763
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
764 /* Try a fallback font-group of FONTSET. */
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
765 if (! EQ (rfont_def, Qt))
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
766 {
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
767 FONT_DEFERRED_LOG ("current fallback: font for", make_number (c), Qnil);
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
768 rfont_def = fontset_find_font (fontset, c, face, id, 1);
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
769 if (VECTORP (rfont_def))
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
770 return rfont_def;
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
771 /* Remember that FONTSET has no font for C. */
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
772 FONTSET_SET (fontset, make_number (c), Qt);
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
773 }
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
774
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
775 /* Try a fallback font-group of the default fontset. */
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
776 if (! EQ (base_fontset, Vdefault_fontset)
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
777 && ! EQ (default_rfont_def, Qt))
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
778 {
103541
1a80fde577a8 (fontset_font): Call FONT_DEFERRED_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103342
diff changeset
779 FONT_DEFERRED_LOG ("default fallback: font for", make_number (c), Qnil);
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
780 rfont_def = fontset_find_font (FONTSET_DEFAULT (fontset), c, face, id, 1);
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
781 if (VECTORP (rfont_def))
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
782 return rfont_def;
103573
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
783 /* Remember that the default fontset has no font for C. */
67e242fdd3e1 (fontset_get_font_group): Return 0 if no font-group is
Kenichi Handa <handa@m17n.org>
parents: 103541
diff changeset
784 FONTSET_SET (FONTSET_DEFAULT (fontset), make_number (c), Qt);
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
785 }
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
786
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
787 return Qnil;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
788 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
789
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
790 /* Return a newly created fontset with NAME. If BASE is nil, make a
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
791 base fontset. Otherwise make a realized fontset whose base is
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
792 BASE. */
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
793
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
794 static Lisp_Object
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
795 make_fontset (frame, name, base)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
796 Lisp_Object frame, name, base;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
797 {
34975
0d69e2d2724e (fontset_ref): Remove unused variable `i'.
Eli Zaretskii <eliz@gnu.org>
parents: 32978
diff changeset
798 Lisp_Object fontset;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
799 int size = ASIZE (Vfontset_table);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
800 int id = next_fontset_id;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
801
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
802 /* Find a free slot in Vfontset_table. Usually, next_fontset_id is
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
803 the next available fontset ID. So it is expected that this loop
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
804 terminates quickly. In addition, as the last element of
41987
34952771ae85 Fix typos, remove unnecessary space.
Pavel Janík <Pavel@Janik.cz>
parents: 41052
diff changeset
805 Vfontset_table is always nil, we don't have to check the range of
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
806 id. */
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
807 while (!NILP (AREF (Vfontset_table, id))) id++;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
808
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
809 if (id + 1 == size)
91053
a0e466c4d599 Merge from emacs--devo--0
Miles Bader <miles@gnu.org>
parents: 91046 85244
diff changeset
810 Vfontset_table = larger_vector (Vfontset_table, size + 32, Qnil);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
811
29767
c8e5453dc85d (FONTSET_ASCII): Use the first element of char table
Kenichi Handa <handa@m17n.org>
parents: 29501
diff changeset
812 fontset = Fmake_char_table (Qfontset, Qnil);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
813
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
814 FONTSET_ID (fontset) = make_number (id);
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
815 if (NILP (base))
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
816 {
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
817 FONTSET_NAME (fontset) = name;
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
818 }
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
819 else
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
820 {
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
821 FONTSET_NAME (fontset) = Qnil;
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
822 FONTSET_FRAME (fontset) = frame;
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
823 FONTSET_BASE (fontset) = base;
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
824 }
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
825
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
826 ASET (Vfontset_table, id, fontset);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
827 next_fontset_id = id + 1;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
828 return fontset;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
829 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
830
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
831
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
832 /********** INTERFACES TO xfaces.c, xfns.c, and dispextern.h **********/
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
833
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
834 /* Return the name of the fontset who has ID. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
835
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
836 Lisp_Object
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
837 fontset_name (id)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
838 int id;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
839 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
840 Lisp_Object fontset;
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
841
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
842 fontset = FONTSET_FROM_ID (id);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
843 return FONTSET_NAME (fontset);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
844 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
845
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
846
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
847 /* Return the ASCII font name of the fontset who has ID. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
848
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
849 Lisp_Object
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
850 fontset_ascii (id)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
851 int id;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
852 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
853 Lisp_Object fontset, elt;
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
854
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
855 fontset= FONTSET_FROM_ID (id);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
856 elt = FONTSET_ASCII (fontset);
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
857 if (CONSP (elt))
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
858 elt = XCAR (elt);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
859 return elt;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
860 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
861
91908
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
862 void
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
863 free_realized_fontset (f, fontset)
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
864 FRAME_PTR f;
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
865 Lisp_Object fontset;
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
866 {
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
867 Lisp_Object tail;
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
868
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
869 return;
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
870 for (tail = FONTSET_OBJLIST (fontset); CONSP (tail); tail = XCDR (tail))
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
871 {
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
872 xassert (FONT_OBJECT_P (XCAR (tail)));
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
873 font_close_object (f, XCAR (tail));
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
874 }
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
875 }
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
876
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
877 /* Free fontset of FACE defined on frame F. Called from
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
878 free_realized_face. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
879
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
880 void
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
881 free_face_fontset (f, face)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
882 FRAME_PTR f;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
883 struct face *face;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
884 {
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
885 Lisp_Object fontset;
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
886
91668
aeadaa72f7b1 (free_face_fontset): Use FONTSET_FROM_ID.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91513
diff changeset
887 fontset = FONTSET_FROM_ID (face->fontset);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
888 if (NILP (fontset))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
889 return;
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
890 xassert (! BASE_FONTSET_P (fontset));
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
891 xassert (f == XFRAME (FONTSET_FRAME (fontset)));
91908
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
892 free_realized_fontset (f, fontset);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
893 ASET (Vfontset_table, face->fontset, Qnil);
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
894 if (face->fontset < next_fontset_id)
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
895 next_fontset_id = face->fontset;
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
896 if (! NILP (FONTSET_DEFAULT (fontset)))
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
897 {
89865
d2b1cc2ef7f1 Include "intervals.h".
Kenichi Handa <handa@m17n.org>
parents: 89826
diff changeset
898 int id = XINT (FONTSET_ID (FONTSET_DEFAULT (fontset)));
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
899
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
900 fontset = AREF (Vfontset_table, id);
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
901 xassert (!NILP (fontset) && ! BASE_FONTSET_P (fontset));
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
902 xassert (f == XFRAME (FONTSET_FRAME (fontset)));
91908
6916adc8df33 (FONTSET_OBJLIST): New macro.
Kenichi Handa <handa@m17n.org>
parents: 91887
diff changeset
903 free_realized_fontset (f, fontset);
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
904 ASET (Vfontset_table, id, Qnil);
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
905 if (id < next_fontset_id)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
906 next_fontset_id = face->fontset;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
907 }
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
908 face->fontset = -1;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
909 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
910
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
911
78501
1677cf1c2509 Replace `iff' in comments.
Glenn Morris <rgm@gnu.org>
parents: 78313
diff changeset
912 /* Return 1 if FACE is suitable for displaying character C.
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
913 Otherwise return 0. Called from the macro FACE_SUITABLE_FOR_CHAR_P
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
914 when C is not an ASCII character. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
915
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
916 int
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
917 face_suitable_for_char_p (face, c)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
918 struct face *face;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
919 int c;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
920 {
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
921 Lisp_Object fontset, rfont_def;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
922
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
923 fontset = FONTSET_FROM_ID (face->fontset);
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
924 rfont_def = fontset_font (fontset, c, NULL, -1);
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
925 return (VECTORP (rfont_def)
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
926 && INTEGERP (RFONT_DEF_FACE (rfont_def))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
927 && face->id == XINT (RFONT_DEF_FACE (rfont_def)));
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
928 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
929
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
930
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
931 /* Return ID of face suitable for displaying character C on frame F.
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
932 FACE must be reazlied for ASCII characters in advance. Called from
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
933 the macro FACE_FOR_CHAR. */
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
934
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
935 int
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
936 face_for_char (f, face, c, pos, object)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
937 FRAME_PTR f;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
938 struct face *face;
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
939 int c, pos;
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
940 Lisp_Object object;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
941 {
97539
cc7d396b5612 (face_for_char): Add font log.
Kenichi Handa <handa@m17n.org>
parents: 97043
diff changeset
942 Lisp_Object fontset, rfont_def, charset;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
943 int face_id;
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
944 int id;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
945
98582
13af2a2ff3db (face_for_char): If face->fontset is negative, just return ascii_face.
Kenichi Handa <handa@m17n.org>
parents: 98575
diff changeset
946 /* If face->fontset is negative (that happens when no font is found
13af2a2ff3db (face_for_char): If face->fontset is negative, just return ascii_face.
Kenichi Handa <handa@m17n.org>
parents: 98575
diff changeset
947 for face), just return face->ascii_face because we can't do
13af2a2ff3db (face_for_char): If face->fontset is negative, just return ascii_face.
Kenichi Handa <handa@m17n.org>
parents: 98575
diff changeset
948 anything. Perhaps, we should fix the callers to assure
13af2a2ff3db (face_for_char): If face->fontset is negative, just return ascii_face.
Kenichi Handa <handa@m17n.org>
parents: 98575
diff changeset
949 that face->fontset is always valid. */
13af2a2ff3db (face_for_char): If face->fontset is negative, just return ascii_face.
Kenichi Handa <handa@m17n.org>
parents: 98575
diff changeset
950 if (ASCII_CHAR_P (c) || face->fontset < 0)
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
951 return face->ascii_face->id;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
952
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
953 xassert (fontset_id_valid_p (face->fontset));
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
954 fontset = FONTSET_FROM_ID (face->fontset);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
955 xassert (!BASE_FONTSET_P (fontset));
96556
0af6d3c9fb7c (fontset_compare_rfontdef): Fix plus/minus.
Kenichi Handa <handa@m17n.org>
parents: 96414
diff changeset
956
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
957 if (pos < 0)
97539
cc7d396b5612 (face_for_char): Add font log.
Kenichi Handa <handa@m17n.org>
parents: 97043
diff changeset
958 {
cc7d396b5612 (face_for_char): Add font log.
Kenichi Handa <handa@m17n.org>
parents: 97043
diff changeset
959 id = -1;
cc7d396b5612 (face_for_char): Add font log.
Kenichi Handa <handa@m17n.org>
parents: 97043
diff changeset
960 charset = Qnil;
cc7d396b5612 (face_for_char): Add font log.
Kenichi Handa <handa@m17n.org>
parents: 97043
diff changeset
961 }
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
962 else
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
963 {
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
964 charset = Fget_char_property (make_number (pos), Qcharset, object);
100168
acef56f002fc (face_for_char): Handle invalid charset property
Kenichi Handa <handa@m17n.org>
parents: 99980
diff changeset
965 if (CHARSETP (charset))
91266
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
966 {
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
967 Lisp_Object val;
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
968
101553
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
969 val = assq_no_quit (charset, Vfont_encoding_charset_alist);
91266
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
970 if (CONSP (val) && CHARSETP (XCDR (val)))
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
971 charset = XCDR (val);
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
972 id = XINT (CHARSET_SYMBOL_ID (charset));
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
973 }
100168
acef56f002fc (face_for_char): Handle invalid charset property
Kenichi Handa <handa@m17n.org>
parents: 99980
diff changeset
974 else
acef56f002fc (face_for_char): Handle invalid charset property
Kenichi Handa <handa@m17n.org>
parents: 99980
diff changeset
975 id = -1;
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
976 }
95291
5ad7b7aaa2a5 (face_for_char): Optimize for the case of no charset property.
Kenichi Handa <handa@m17n.org>
parents: 95256
diff changeset
977
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
978 rfont_def = fontset_font (fontset, c, face, id);
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
979 if (VECTORP (rfont_def))
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
980 {
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
981 if (INTEGERP (RFONT_DEF_FACE (rfont_def)))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
982 face_id = XINT (RFONT_DEF_FACE (rfont_def));
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
983 else
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
984 {
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
985 Lisp_Object font_object;
41987
34952771ae85 Fix typos, remove unnecessary space.
Pavel Janík <Pavel@Janik.cz>
parents: 41052
diff changeset
986
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
987 font_object = RFONT_DEF_OBJECT (rfont_def);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
988 face_id = face_for_font (f, font_object, face);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
989 RFONT_DEF_SET_FACE (rfont_def, face_id);
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
990 }
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
991 }
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
992 else
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
993 {
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
994 if (INTEGERP (FONTSET_NOFONT_FACE (fontset)))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
995 face_id = XINT (FONTSET_NOFONT_FACE (fontset));
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
996 else
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
997 {
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
998 face_id = face_for_font (f, Qnil, face);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
999 FONTSET_NOFONT_FACE (fontset) = make_number (face_id);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1000 }
89898
0167306cb580 (fontset_font): Renamed from fontset_face. Return
Kenichi Handa <handa@m17n.org>
parents: 89865
diff changeset
1001 }
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1002 xassert (face_id >= 0);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1003 return face_id;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1004 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1005
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1006
97824
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1007 Lisp_Object
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1008 font_for_char (face, c, pos, object)
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1009 struct face *face;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1010 int c, pos;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1011 Lisp_Object object;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1012 {
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1013 Lisp_Object fontset, rfont_def, charset;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1014 int id;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1015
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1016 if (ASCII_CHAR_P (c))
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1017 {
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1018 Lisp_Object font_object;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1019
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1020 XSETFONT (font_object, face->ascii_face->font);
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1021 return font_object;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1022 }
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1023
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1024 xassert (fontset_id_valid_p (face->fontset));
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1025 fontset = FONTSET_FROM_ID (face->fontset);
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1026 xassert (!BASE_FONTSET_P (fontset));
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1027 if (pos < 0)
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1028 {
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1029 id = -1;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1030 charset = Qnil;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1031 }
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1032 else
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1033 {
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1034 charset = Fget_char_property (make_number (pos), Qcharset, object);
100168
acef56f002fc (face_for_char): Handle invalid charset property
Kenichi Handa <handa@m17n.org>
parents: 99980
diff changeset
1035 if (CHARSETP (charset))
97824
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1036 {
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1037 Lisp_Object val;
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1038
101601
58bce94ff020 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101553
diff changeset
1039 val = assq_no_quit (charset, Vfont_encoding_charset_alist);
97824
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1040 if (CONSP (val) && CHARSETP (XCDR (val)))
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1041 charset = XCDR (val);
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1042 id = XINT (CHARSET_SYMBOL_ID (charset));
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1043 }
100168
acef56f002fc (face_for_char): Handle invalid charset property
Kenichi Handa <handa@m17n.org>
parents: 99980
diff changeset
1044 else
acef56f002fc (face_for_char): Handle invalid charset property
Kenichi Handa <handa@m17n.org>
parents: 99980
diff changeset
1045 id = -1;
97824
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1046 }
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1047
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1048 rfont_def = fontset_font (fontset, c, face, id);
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1049 return (VECTORP (rfont_def)
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1050 ? RFONT_DEF_OBJECT (rfont_def)
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1051 : Qnil);
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1052 }
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1053
991e41e2d92a (font_for_char): New function.
Kenichi Handa <handa@m17n.org>
parents: 97556
diff changeset
1054
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1055 /* Make a realized fontset for ASCII face FACE on frame F from the
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1056 base fontset BASE_FONTSET_ID. If BASE_FONTSET_ID is -1, use the
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1057 default fontset as the base. Value is the id of the new fontset.
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1058 Called from realize_x_face. */
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1059
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1060 int
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1061 make_fontset_for_ascii_face (f, base_fontset_id, face)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1062 FRAME_PTR f;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1063 int base_fontset_id;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1064 struct face *face;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1065 {
34975
0d69e2d2724e (fontset_ref): Remove unused variable `i'.
Eli Zaretskii <eliz@gnu.org>
parents: 32978
diff changeset
1066 Lisp_Object base_fontset, fontset, frame;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1067
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1068 XSETFRAME (frame, f);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1069 if (base_fontset_id >= 0)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1070 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1071 base_fontset = FONTSET_FROM_ID (base_fontset_id);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1072 if (!BASE_FONTSET_P (base_fontset))
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1073 base_fontset = FONTSET_BASE (base_fontset);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1074 if (! BASE_FONTSET_P (base_fontset))
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1075 abort ();
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1076 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1077 else
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1078 base_fontset = Vdefault_fontset;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1079
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1080 fontset = make_fontset (frame, Qnil, base_fontset);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1081 return XINT (FONTSET_ID (fontset));
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1082 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1083
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1084
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1085
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1086 /* Cache data used by fontset_pattern_regexp. The car part is a
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1087 pattern string containing at least one wild card, the cdr part is
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1088 the corresponding regular expression. */
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1089 static Lisp_Object Vcached_fontset_data;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1090
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1091 #define CACHED_FONTSET_NAME ((char *) SDATA (XCAR (Vcached_fontset_data)))
26164
d39ec0a27081 more XCAR/XCDR/XFLOAT_DATA uses, to help isolete lisp engine
Ken Raeburn <raeburn@raeburn.org>
parents: 25668
diff changeset
1092 #define CACHED_FONTSET_REGEX (XCDR (Vcached_fontset_data))
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1093
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1094 /* If fontset name PATTERN contains any wild card, return regular
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1095 expression corresponding to PATTERN. */
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1096
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1097 static Lisp_Object
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1098 fontset_pattern_regexp (pattern)
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1099 Lisp_Object pattern;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1100 {
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1101 if (!index ((char *) SDATA (pattern), '*')
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1102 && !index ((char *) SDATA (pattern), '?'))
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1103 /* PATTERN does not contain any wild cards. */
17730
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
1104 return Qnil;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1105
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1106 if (!CONSP (Vcached_fontset_data)
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1107 || strcmp ((char *) SDATA (pattern), CACHED_FONTSET_NAME))
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1108 {
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1109 /* We must at first update the cached data. */
57947
678d2c0d522e (fontset_pattern_regexp): Use unsigned char.
Kim F. Storm <storm@cua.dk>
parents: 57921
diff changeset
1110 unsigned char *regex, *p0, *p1;
96020
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1111 int ndashes = 0, nstars = 0, nescs = 0;
57947
678d2c0d522e (fontset_pattern_regexp): Use unsigned char.
Kim F. Storm <storm@cua.dk>
parents: 57921
diff changeset
1112
57685
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1113 for (p0 = SDATA (pattern); *p0; p0++)
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1114 {
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1115 if (*p0 == '-')
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1116 ndashes++;
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1117 else if (*p0 == '*')
57685
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1118 nstars++;
96020
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1119 else if (*p0 == '['
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1120 || *p0 == '.' || *p0 == '\\'
101943
97c9e9322753 Remove spurious semicolons.
Juanma Barranquero <lekktu@gmail.com>
parents: 101605
diff changeset
1121 || *p0 == '+' || *p0 == '^'
96020
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1122 || *p0 == '$')
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1123 nescs++;
57685
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1124 }
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1125
57685
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1126 /* If PATTERN is not full XLFD we conert "*" to ".*". Otherwise
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1127 we convert "*" to "[^-]*" which is much faster in regular
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1128 expression matching. */
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1129 if (ndashes < 14)
96020
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1130 p1 = regex = (unsigned char *) alloca (SBYTES (pattern) + 2 * nstars + 2 * nescs + 1);
57685
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1131 else
96020
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1132 p1 = regex = (unsigned char *) alloca (SBYTES (pattern) + 5 * nstars + 2 * nescs + 1);
57685
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1133
17730
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
1134 *p1++ = '^';
57947
678d2c0d522e (fontset_pattern_regexp): Use unsigned char.
Kim F. Storm <storm@cua.dk>
parents: 57921
diff changeset
1135 for (p0 = SDATA (pattern); *p0; p0++)
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1136 {
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1137 if (*p0 == '*')
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1138 {
57685
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1139 if (ndashes < 14)
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1140 *p1++ = '.';
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1141 else
b935fc1cb542 (fontset_pattern_regexp): Optimize for the case that
Kenichi Handa <handa@m17n.org>
parents: 57573
diff changeset
1142 *p1++ = '[', *p1++ = '^', *p1++ = '-', *p1++ = ']';
17730
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
1143 *p1++ = '*';
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1144 }
17730
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
1145 else if (*p0 == '?')
21127
577865651099 (fontset_pattern_regexp): `==' was used instead of `='.
Richard M. Stallman <rms@gnu.org>
parents: 20346
diff changeset
1146 *p1++ = '.';
96020
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1147 else if (*p0 == '['
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1148 || *p0 == '.' || *p0 == '\\'
101943
97c9e9322753 Remove spurious semicolons.
Juanma Barranquero <lekktu@gmail.com>
parents: 101605
diff changeset
1149 || *p0 == '+' || *p0 == '^'
96020
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1150 || *p0 == '$')
b52fa52cd0fa (fontset_pattern_regexp): Escape some regexp characters.
Kenichi Handa <handa@m17n.org>
parents: 95961
diff changeset
1151 *p1++ = '\\', *p1++ = *p0;
17730
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
1152 else
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
1153 *p1++ = *p0;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1154 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1155 *p1++ = '$';
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1156 *p1++ = 0;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1157
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1158 Vcached_fontset_data = Fcons (build_string ((char *) SDATA (pattern)),
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1159 build_string ((char *) regex));
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1160 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1161
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1162 return CACHED_FONTSET_REGEX;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1163 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1164
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1165 /* Return ID of the base fontset named NAME. If there's no such
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1166 fontset, return -1. NAME_PATTERN specifies how to treat NAME as this:
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1167 0: pattern containing '*' and '?' as wildcards
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1168 1: regular expression
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1169 2: literal fontset name
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1170 */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1171
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1172 int
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1173 fs_query_fontset (name, name_pattern)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1174 Lisp_Object name;
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1175 int name_pattern;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1176 {
34975
0d69e2d2724e (fontset_ref): Remove unused variable `i'.
Eli Zaretskii <eliz@gnu.org>
parents: 32978
diff changeset
1177 Lisp_Object tem;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1178 int i;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1179
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1180 name = Fdowncase (name);
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1181 if (name_pattern != 1)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1182 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1183 tem = Frassoc (name, Vfontset_alias_alist);
89699
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
1184 if (NILP (tem))
cda6f41a592e (reorder_font_vector): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 89687
diff changeset
1185 tem = Fassoc (name, Vfontset_alias_alist);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1186 if (CONSP (tem) && STRINGP (XCAR (tem)))
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1187 name = XCAR (tem);
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1188 else if (name_pattern == 0)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1189 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1190 tem = fontset_pattern_regexp (name);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1191 if (STRINGP (tem))
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1192 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1193 name = tem;
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1194 name_pattern = 1;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1195 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1196 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1197 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1198
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1199 for (i = 0; i < ASIZE (Vfontset_table); i++)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1200 {
57573
43067aee2f3e (fs_load_font): Use fast_string_match_ignore_case for
Kenichi Handa <handa@m17n.org>
parents: 56293
diff changeset
1201 Lisp_Object fontset, this_name;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1202
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1203 fontset = FONTSET_FROM_ID (i);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1204 if (NILP (fontset)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1205 || !BASE_FONTSET_P (fontset))
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1206 continue;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1207
57573
43067aee2f3e (fs_load_font): Use fast_string_match_ignore_case for
Kenichi Handa <handa@m17n.org>
parents: 56293
diff changeset
1208 this_name = FONTSET_NAME (fontset);
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1209 if (name_pattern == 1
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1210 ? fast_string_match_ignore_case (name, this_name) >= 0
95212
a6a4ada91449 * dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents: 95203
diff changeset
1211 : !xstrcasecmp (SDATA (name), SDATA (this_name)))
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1212 return i;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1213 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1214 return -1;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1215 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1216
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1217
21553
2d7afcd11b72 (find_ccl_program_func): New variable.
Kenichi Handa <handa@m17n.org>
parents: 21514
diff changeset
1218 DEFUN ("query-fontset", Fquery_fontset, Squery_fontset, 1, 2, 0,
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1219 doc: /* Return the name of a fontset that matches PATTERN.
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1220 The value is nil if there is no matching fontset.
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1221 PATTERN can contain `*' or `?' as a wildcard
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1222 just as X font name matching algorithm allows.
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1223 If REGEXPP is non-nil, PATTERN is a regular expression. */)
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1224 (pattern, regexpp)
21553
2d7afcd11b72 (find_ccl_program_func): New variable.
Kenichi Handa <handa@m17n.org>
parents: 21514
diff changeset
1225 Lisp_Object pattern, regexpp;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1226 {
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1227 Lisp_Object fontset;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1228 int id;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1229
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1230 (*check_window_system_func) ();
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1231
40656
cdfd4d09b79a Update usage of CHECK_ macros (remove unused second argument).
Pavel Janík <Pavel@Janik.cz>
parents: 40028
diff changeset
1232 CHECK_STRING (pattern);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1233
46370
40db0673e6f0 Most uses of XSTRING combined with STRING_BYTES or indirection changed to
Ken Raeburn <raeburn@raeburn.org>
parents: 45848
diff changeset
1234 if (SCHARS (pattern) == 0)
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1235 return Qnil;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1236
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1237 id = fs_query_fontset (pattern, !NILP (regexpp));
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1238 if (id < 0)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1239 return Qnil;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1240
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1241 fontset = FONTSET_FROM_ID (id);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1242 return FONTSET_NAME (fontset);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1243 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1244
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1245 /* Return a list of base fontset names matching PATTERN on frame F. */
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1246
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1247 Lisp_Object
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1248 list_fontsets (f, pattern, size)
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1249 FRAME_PTR f;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1250 Lisp_Object pattern;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1251 int size;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1252 {
34975
0d69e2d2724e (fontset_ref): Remove unused variable `i'.
Eli Zaretskii <eliz@gnu.org>
parents: 32978
diff changeset
1253 Lisp_Object frame, regexp, val;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1254 int id;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1255
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1256 XSETFRAME (frame, f);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1257
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1258 regexp = fontset_pattern_regexp (pattern);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1259 val = Qnil;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1260
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1261 for (id = 0; id < ASIZE (Vfontset_table); id++)
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1262 {
57573
43067aee2f3e (fs_load_font): Use fast_string_match_ignore_case for
Kenichi Handa <handa@m17n.org>
parents: 56293
diff changeset
1263 Lisp_Object fontset, name;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1264
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1265 fontset = FONTSET_FROM_ID (id);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1266 if (NILP (fontset)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1267 || !BASE_FONTSET_P (fontset)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1268 || !EQ (frame, FONTSET_FRAME (fontset)))
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1269 continue;
57573
43067aee2f3e (fs_load_font): Use fast_string_match_ignore_case for
Kenichi Handa <handa@m17n.org>
parents: 56293
diff changeset
1270 name = FONTSET_NAME (fontset);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1271
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1272 if (STRINGP (regexp)
57573
43067aee2f3e (fs_load_font): Use fast_string_match_ignore_case for
Kenichi Handa <handa@m17n.org>
parents: 56293
diff changeset
1273 ? (fast_string_match (regexp, name) < 0)
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1274 : strcmp ((char *) SDATA (pattern), (char *) SDATA (name)))
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1275 continue;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1276
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1277 val = Fcons (Fcopy_sequence (FONTSET_NAME (fontset)), val);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1278 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1279
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1280 return val;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1281 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1282
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1283
89483
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
1284 /* Free all realized fontsets whose base fontset is BASE. */
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1285
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1286 static void
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1287 free_realized_fontsets (base)
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1288 Lisp_Object base;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1289 {
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1290 int id;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1291
90806
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1292 #if 0
88482
effba1417b74 (free_realized_fontsets): Call Fclear_face_cache instead
Kenichi Handa <handa@m17n.org>
parents: 88405
diff changeset
1293 /* For the moment, this doesn't work because free_realized_face
effba1417b74 (free_realized_fontsets): Call Fclear_face_cache instead
Kenichi Handa <handa@m17n.org>
parents: 88405
diff changeset
1294 doesn't remove FACE from a cache. Until we find a solution, we
effba1417b74 (free_realized_fontsets): Call Fclear_face_cache instead
Kenichi Handa <handa@m17n.org>
parents: 88405
diff changeset
1295 suppress this code, and simply use Fclear_face_cache even though
effba1417b74 (free_realized_fontsets): Call Fclear_face_cache instead
Kenichi Handa <handa@m17n.org>
parents: 88405
diff changeset
1296 that is not efficient. */
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1297 BLOCK_INPUT;
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1298 for (id = 0; id < ASIZE (Vfontset_table); id++)
58025
bcd053632eb2 (fontset_pattern_regexp): Cancel my previous change;
Kenichi Handa <handa@m17n.org>
parents: 57947
diff changeset
1299 {
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1300 Lisp_Object this = AREF (Vfontset_table, id);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1301
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1302 if (EQ (FONTSET_BASE (this), base))
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1303 {
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1304 Lisp_Object tail;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1305
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1306 for (tail = FONTSET_FACE_ALIST (this); CONSP (tail);
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1307 tail = XCDR (tail))
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1308 {
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1309 FRAME_PTR f = XFRAME (FONTSET_FRAME (this));
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1310 int face_id = XINT (XCDR (XCAR (tail)));
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1311 struct face *face = FACE_FROM_ID (f, face_id);
89483
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
1312
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1313 /* Face THIS itself is also freed by the following call. */
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1314 free_realized_face (f, face);
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1315 }
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1316 }
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1317 }
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1318 UNBLOCK_INPUT;
88482
effba1417b74 (free_realized_fontsets): Call Fclear_face_cache instead
Kenichi Handa <handa@m17n.org>
parents: 88405
diff changeset
1319 #else /* not 0 */
90806
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1320 /* But, we don't have to call Fclear_face_cache if no fontset has
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1321 been realized from BASE. */
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1322 for (id = 0; id < ASIZE (Vfontset_table); id++)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1323 {
90806
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1324 Lisp_Object this = AREF (Vfontset_table, id);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1325
91046
35069180a991 Fix up multi-tty merge
Miles Bader <miles@gnu.org>
parents: 91041
diff changeset
1326 if (CHAR_TABLE_P (this) && EQ (FONTSET_BASE (this), base))
90806
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1327 {
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1328 Fclear_face_cache (Qt);
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1329 break;
1ae136ad0ba0 (free_realized_fontsets): Avoid unnecessary call of
Kenichi Handa <handa@m17n.org>
parents: 90802
diff changeset
1330 }
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1331 }
88482
effba1417b74 (free_realized_fontsets): Call Fclear_face_cache instead
Kenichi Handa <handa@m17n.org>
parents: 88405
diff changeset
1332 #endif /* not 0 */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1333 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1334
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1335
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1336 /* Check validity of NAME as a fontset name and return the
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1337 corresponding fontset. If not valid, signal an error.
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1338
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1339 If NAME is t, return Vdefault_fontset. If NAME is nil, return the
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1340 fontset of *FRAME.
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1341
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1342 Set *FRAME to the actual frame. */
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1343
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1344 static Lisp_Object
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1345 check_fontset_name (name, frame)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1346 Lisp_Object name, *frame;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1347 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1348 int id;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1349
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1350 if (NILP (*frame))
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1351 *frame = selected_frame;
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1352 CHECK_LIVE_FRAME (*frame);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1353
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1354 if (EQ (name, Qt))
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1355 return Vdefault_fontset;
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1356 if (NILP (name))
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1357 {
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1358 id = FRAME_FONTSET (XFRAME (*frame));
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1359 }
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1360 else
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1361 {
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1362 CHECK_STRING (name);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1363 /* First try NAME as literal. */
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1364 id = fs_query_fontset (name, 2);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1365 if (id < 0)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1366 /* For backward compatibility, try again NAME as pattern. */
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1367 id = fs_query_fontset (name, 0);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1368 if (id < 0)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1369 error ("Fontset `%s' does not exist", SDATA (name));
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1370 }
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1371 return FONTSET_FROM_ID (id);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1372 }
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1373
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1374 static void
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1375 accumulate_script_ranges (arg, range, val)
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1376 Lisp_Object arg, range, val;
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1377 {
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1378 if (EQ (XCAR (arg), val))
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1379 {
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1380 if (CONSP (range))
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1381 XSETCDR (arg, Fcons (Fcons (XCAR (range), XCDR (range)), XCDR (arg)));
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1382 else
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1383 XSETCDR (arg, Fcons (Fcons (range, range), XCDR (arg)));
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1384 }
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1385 }
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
1386
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
1387
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1388 /* Callback function for map_charset_chars in Fset_fontset_font.
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1389 ARG is a vector [ FONTSET FONT_DEF ADD ASCII SCRIPT_RANGE_LIST ].
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1390
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1391 In FONTSET, set FONT_DEF in a fashion specified by ADD for
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1392 characters in RANGE and ranges in SCRIPT_RANGE_LIST before RANGE.
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1393 The consumed ranges are poped up from SCRIPT_RANGE_LIST, and the
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1394 new SCRIPT_RANGE_LIST is stored in ARG.
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1395
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1396 If ASCII is nil, don't set FONT_DEF for ASCII characters. It is
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1397 assured that SCRIPT_RANGE_LIST doesn't contain ASCII in that
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1398 case. */
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1399
89614
355fc0282e50 (set_fontset_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 89610
diff changeset
1400 static void
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1401 set_fontset_font (arg, range)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1402 Lisp_Object arg, range;
89614
355fc0282e50 (set_fontset_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 89610
diff changeset
1403 {
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1404 Lisp_Object fontset, font_def, add, ascii, script_range_list;
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1405 int from = XINT (XCAR (range)), to = XINT (XCDR (range));
89614
355fc0282e50 (set_fontset_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 89610
diff changeset
1406
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1407 fontset = AREF (arg, 0);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1408 font_def = AREF (arg, 1);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1409 add = AREF (arg, 2);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1410 ascii = AREF (arg, 3);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1411 script_range_list = AREF (arg, 4);
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1412
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1413 if (NILP (ascii) && from < 0x80)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1414 {
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1415 if (to < 0x80)
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1416 return;
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1417 from = 0x80;
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1418 range = Fcons (make_number (0x80), XCDR (range));
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
1419 }
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1420
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1421 #define SCRIPT_FROM XINT (XCAR (XCAR (script_range_list)))
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1422 #define SCRIPT_TO XINT (XCDR (XCAR (script_range_list)))
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1423 #define POP_SCRIPT_RANGE() script_range_list = XCDR (script_range_list)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1424
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1425 for (; CONSP (script_range_list) && SCRIPT_TO < from; POP_SCRIPT_RANGE ())
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1426 FONTSET_ADD (fontset, XCAR (script_range_list), font_def, add);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1427 if (CONSP (script_range_list))
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1428 {
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1429 if (SCRIPT_FROM < from)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1430 range = Fcons (make_number (SCRIPT_FROM), XCDR (range));
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1431 while (CONSP (script_range_list) && SCRIPT_TO <= to)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1432 POP_SCRIPT_RANGE ();
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1433 if (CONSP (script_range_list) && SCRIPT_FROM <= to)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1434 XSETCAR (XCAR (script_range_list), make_number (to + 1));
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1435 }
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1436
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1437 FONTSET_ADD (fontset, range, font_def, add);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1438 ASET (arg, 4, script_range_list);
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
1439 }
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
1440
91136
d54684fee154 (fontset_find_font) [USE_FONT_BACKEND]: Try multiple
Kenichi Handa <handa@m17n.org>
parents: 91053
diff changeset
1441 extern Lisp_Object QCfamily, QCregistry;
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1442 static void update_auto_fontset_alist P_ ((Lisp_Object, Lisp_Object));
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1443
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1444
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1445 DEFUN ("set-fontset-font", Fset_fontset_font, Sset_fontset_font, 3, 5, 0,
89483
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
1446 doc: /*
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1447 Modify fontset NAME to use FONT-SPEC for TARGET characters.
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1448
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1449 NAME is a fontset name string, nil for the fontset of FRAME, or t for
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1450 the default fontset.
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1451
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1452 TARGET may be a cons; (FROM . TO), where FROM and TO are characters.
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1453 In that case, use FONT-SPEC for all characters in the range FROM and
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1454 TO (inclusive).
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1455
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1456 TARGET may be a script name symbol. In that case, use FONT-SPEC for
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1457 all characters that belong to the script.
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1458
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1459 TARGET may be a charset. In that case, use FONT-SPEC for all
89669
6871c119b186 (Fset_fontset_font): Fix docstring.
Kenichi Handa <handa@m17n.org>
parents: 89614
diff changeset
1460 characters in the charset.
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1461
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1462 TARGET may be nil. In that case, use FONT-SPEC for any characters for
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1463 that no FONT-SPEC is specified.
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1464
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
1465 FONT-SPEC may one of these:
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1466 * A font-spec object made by the function `font-spec' (which see).
89337
6026c8e5664f (Fset_fontset_font): Fix indentation of docstring.
Kenichi Handa <handa@m17n.org>
parents: 89069
diff changeset
1467 * A cons (FAMILY . REGISTRY), where FAMILY is a font family name and
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1468 REGISTRY is a font registry name. FAMILY may contain foundry
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1469 name, and REGISTRY may contain encoding name.
88931
74d18470865c (fontset_add): Declare args. Call make_number
Dave Love <fx@gnu.org>
parents: 88903
diff changeset
1470 * A font name string.
91364
1e43b74bf9e5 (reorder_font_vector): Exclude nil elements from the
Kenichi Handa <handa@m17n.org>
parents: 91352
diff changeset
1471 * nil, which explicitly specifies that there's no font for TARGET.
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1472
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1473 Optional 4th argument FRAME is a frame or nil for the selected frame
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1474 that is concerned in the case that NAME is nil.
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1475
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1476 Optional 5th argument ADD, if non-nil, specifies how to add FONT-SPEC
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1477 to the font specifications for TARGET previously set. If it is
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1478 `prepend', FONT-SPEC is prepended. If it is `append', FONT-SPEC is
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1479 appended. By default, FONT-SPEC overrides the previous settings. */)
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1480 (name, target, font_spec, frame, add)
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1481 Lisp_Object name, target, font_spec, frame, add;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1482 {
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1483 Lisp_Object fontset;
90056
b0c203a8776d (Fset_fontset_font): Call find_font_encoding with
Kenichi Handa <handa@m17n.org>
parents: 90044
diff changeset
1484 Lisp_Object font_def, registry, family;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1485 Lisp_Object range_list;
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1486 struct charset *charset = NULL;
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1487 Lisp_Object fontname;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1488 int ascii_changed = 0;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1489
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1490 fontset = check_fontset_name (name, &frame);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1491
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1492 fontname = Qnil;
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1493 if (CONSP (font_spec))
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1494 {
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1495 Lisp_Object spec = Ffont_spec (0, NULL);
91169
8eb408860621 Include "font.h" unconditionally.
Kenichi Handa <handa@m17n.org>
parents: 91136
diff changeset
1496
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1497 font_parse_family_registry (XCAR (font_spec), XCDR (font_spec), spec);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1498 font_spec = spec;
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1499 fontname = Ffont_xlfd_name (font_spec, Qnil);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1500 }
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1501 else if (STRINGP (font_spec))
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1502 {
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
1503 Lisp_Object args[2];
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1504 extern Lisp_Object QCname;
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
1505
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1506 fontname = font_spec;
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
1507 args[0] = QCname;
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
1508 args[1] = font_spec;
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
1509 font_spec = Ffont_spec (2, args);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1510 }
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1511 else if (FONT_SPEC_P (font_spec))
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1512 fontname = Ffont_xlfd_name (font_spec, Qnil);
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1513 else if (! NILP (font_spec))
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1514 Fsignal (Qfont, list2 (build_string ("Invalid font-spec"), font_spec));
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1515
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1516 if (! NILP (font_spec))
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1517 {
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1518 Lisp_Object encoding, repertory;
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1519
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1520 family = AREF (font_spec, FONT_FAMILY_INDEX);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1521 if (! NILP (family) )
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1522 family = SYMBOL_NAME (family);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1523 registry = AREF (font_spec, FONT_REGISTRY_INDEX);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1524 if (! NILP (registry))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1525 registry = Fdowncase (SYMBOL_NAME (registry));
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1526 encoding = find_font_encoding (concat3 (family, build_string ("-"),
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1527 registry));
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1528 if (NILP (encoding))
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1529 encoding = Qascii;
91231
29d8135e8f58 (fontset_add): New args charset_id and famliy. Caller
Kenichi Handa <handa@m17n.org>
parents: 91224
diff changeset
1530
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1531 if (SYMBOLP (encoding))
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1532 {
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1533 CHECK_CHARSET (encoding);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1534 encoding = repertory = CHARSET_SYMBOL_ID (encoding);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1535 }
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1536 else
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1537 {
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1538 repertory = XCDR (encoding);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1539 encoding = XCAR (encoding);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1540 CHECK_CHARSET (encoding);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1541 encoding = CHARSET_SYMBOL_ID (encoding);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1542 if (! NILP (repertory) && SYMBOLP (repertory))
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1543 {
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1544 CHECK_CHARSET (repertory);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1545 repertory = CHARSET_SYMBOL_ID (repertory);
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1546 }
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1547 }
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1548 FONT_DEF_NEW (font_def, font_spec, encoding, repertory);
89826
b17725d55ba2 (Fset_fontset_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 89811
diff changeset
1549 }
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1550 else
91352
b6befec471b8 (reorder_font_vector): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 91336
diff changeset
1551 font_def = Qnil;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1552
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1553 if (CHARACTERP (target))
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1554 {
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1555 if (XFASTINT (target) < 0x80)
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1556 error ("Can't set a font for partial ASCII range.");
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1557 range_list = Fcons (Fcons (target, target), Qnil);
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1558 }
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1559 else if (CONSP (target))
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1560 {
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1561 Lisp_Object from, to;
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1562
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1563 from = Fcar (target);
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1564 to = Fcdr (target);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1565 CHECK_CHARACTER (from);
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1566 CHECK_CHARACTER (to);
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1567 if (XFASTINT (from) < 0x80)
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1568 {
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1569 if (XFASTINT (from) != 0 || XFASTINT (to) < 0x7F)
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1570 error ("Can't set a font for partial ASCII range.");
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1571 ascii_changed = 1;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1572 }
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1573 range_list = Fcons (target, Qnil);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1574 }
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1575 else if (SYMBOLP (target) && !NILP (target))
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1576 {
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1577 Lisp_Object script_list;
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1578 Lisp_Object val;
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1579
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1580 range_list = Qnil;
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1581 script_list = XCHAR_TABLE (Vchar_script_table)->extras[0];
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1582 if (! NILP (Fmemq (target, script_list)))
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1583 {
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1584 if (EQ (target, Qlatin))
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1585 ascii_changed = 1;
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1586 val = Fcons (target, Qnil);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1587 map_char_table (accumulate_script_ranges, Qnil, Vchar_script_table,
89483
2f877ed80fa6 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 88123 89428
diff changeset
1588 val);
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1589 range_list = Fnreverse (XCDR (val));
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1590 }
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1591 if (CHARSETP (target))
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1592 {
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1593 CHECK_CHARSET_GET_CHARSET (target, charset);
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1594 if (charset->ascii_compatible_p)
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1595 ascii_changed = 1;
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1596 }
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1597 else if (NILP (range_list))
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1598 error ("Invalid script or charset name: %s",
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1599 SDATA (SYMBOL_NAME (target)));
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1600 }
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1601 else if (NILP (target))
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1602 range_list = Fcons (Qnil, Qnil);
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1603 else
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
1604 error ("Invalid target for setting a font");
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1605
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1606 if (ascii_changed)
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1607 {
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1608 Lisp_Object val;
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1609
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1610 if (NILP (font_spec))
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1611 error ("Can't set ASCII font to nil");
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1612 val = CHAR_TABLE_REF (fontset, 0);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1613 if (! NILP (val) && EQ (add, Qappend))
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1614 /* We are going to change just an additional font for ASCII. */
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1615 ascii_changed = 0;
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1616 }
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1617
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1618 if (charset)
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1619 {
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1620 Lisp_Object arg;
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1621
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1622 arg = Fmake_vector (make_number (5), Qnil);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1623 ASET (arg, 0, fontset);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1624 ASET (arg, 1, font_def);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1625 ASET (arg, 2, add);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1626 ASET (arg, 3, ascii_changed ? Qt : Qnil);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1627 ASET (arg, 4, range_list);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1628
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1629 map_charset_chars (set_fontset_font, Qnil, arg, charset,
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1630 CHARSET_MIN_CODE (charset),
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1631 CHARSET_MAX_CODE (charset));
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1632 range_list = AREF (arg, 4);
89901
d1a1970e3dd1 (find_font_encoding): Return `ascii' for unknown
Kenichi Handa <handa@m17n.org>
parents: 89898
diff changeset
1633 }
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1634 for (; CONSP (range_list); range_list = XCDR (range_list))
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1635 FONTSET_ADD (fontset, XCAR (range_list), font_def, add);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1636
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1637 if (ascii_changed)
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1638 {
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1639 Lisp_Object tail, frame, alist;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1640 int fontset_id = XINT (FONTSET_ID (fontset));
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1641
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1642 FONTSET_ASCII (fontset) = fontname;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1643 name = FONTSET_NAME (fontset);
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1644 FOR_EACH_FRAME (tail, frame)
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1645 {
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1646 FRAME_PTR f = XFRAME (frame);
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1647 Lisp_Object font_object;
102654
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1648 struct face *face;
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1649
102654
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1650 if (FRAME_INITIAL_P (f) || FRAME_TERMCAP_P (f))
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1651 continue;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1652 if (fontset_id != FRAME_FONTSET (f))
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1653 continue;
102654
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1654 face = FACE_FROM_ID (f, DEFAULT_FACE_ID);
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1655 if (face)
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1656 font_object = font_load_for_lface (f, face->lface, font_spec);
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1657 else
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1658 font_object = font_open_by_spec (f, font_spec);
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1659 if (! NILP (font_object))
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1660 {
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1661 update_auto_fontset_alist (font_object, fontset);
102654
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1662 alist = Fcons (Fcons (Qfont, Fcons (name, font_object)), Qnil);
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1663 Fmodify_frame_parameters (frame, alist);
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1664 }
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1665 }
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1666 }
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1667
102654
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1668 /* Free all realized fontsets whose base is FONTSET. This way, the
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1669 specified character(s) are surely redisplayed by a correct
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1670 font. */
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1671 free_realized_fontsets (fontset);
8cacd0d8fb30 (Fset_fontset_font): When a spec of ASCII font is
Kenichi Handa <handa@m17n.org>
parents: 102528
diff changeset
1672
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1673 return Qnil;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1674 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1675
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1676
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1677 DEFUN ("new-fontset", Fnew_fontset, Snew_fontset, 2, 2, 0,
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1678 doc: /* Create a new fontset NAME from font information in FONTLIST.
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1679
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1680 FONTLIST is an alist of scripts vs the corresponding font specification list.
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1681 Each element of FONTLIST has the form (SCRIPT FONT-SPEC ...), where a
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1682 character of SCRIPT is displayed by a font that matches one of
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1683 FONT-SPEC.
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1684
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1685 SCRIPT is a symbol that appears in the first extra slot of the
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1686 char-table `char-script-table'.
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1687
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1688 FONT-SPEC is a vector, a cons, or a string. See the documentation of
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1689 `set-fontset-font' for the meaning. */)
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1690 (name, fontlist)
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1691 Lisp_Object name, fontlist;
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1692 {
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1693 Lisp_Object fontset;
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1694 int id;
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1695
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1696 CHECK_STRING (name);
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1697 CHECK_LIST (fontlist);
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1698
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1699 name = Fdowncase (name);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1700 id = fs_query_fontset (name, 0);
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1701 if (id < 0)
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1702 {
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1703 Lisp_Object font_spec = Ffont_spec (0, NULL);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1704 Lisp_Object short_name;
94981
e01e37b8203e (Fnew_fontset): Call font_unparse_xlfd with 256-byte
Kenichi Handa <handa@m17n.org>
parents: 94963
diff changeset
1705 char xlfd[256];
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1706 int len;
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1707
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1708 if (font_parse_xlfd ((char *) SDATA (name), font_spec) < 0)
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1709 error ("Fontset name must be in XLFD format");
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1710 short_name = AREF (font_spec, FONT_REGISTRY_INDEX);
95230
fa14617b247e Delete unused variables and add casting for char *
Kenichi Handa <handa@m17n.org>
parents: 95212
diff changeset
1711 if (strncmp ((char *) SDATA (SYMBOL_NAME (short_name)), "fontset-", 8)
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1712 || SBYTES (SYMBOL_NAME (short_name)) < 9)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1713 error ("Registry field of fontset name must be \"fontset-*\"");
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1714 Vfontset_alias_alist = Fcons (Fcons (name, SYMBOL_NAME (short_name)),
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1715 Vfontset_alias_alist);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1716 ASET (font_spec, FONT_REGISTRY_INDEX, Qiso8859_1);
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1717 fontset = make_fontset (Qnil, name, Qnil);
94981
e01e37b8203e (Fnew_fontset): Call font_unparse_xlfd with 256-byte
Kenichi Handa <handa@m17n.org>
parents: 94963
diff changeset
1718 len = font_unparse_xlfd (font_spec, 0, xlfd, 256);
e01e37b8203e (Fnew_fontset): Call font_unparse_xlfd with 256-byte
Kenichi Handa <handa@m17n.org>
parents: 94963
diff changeset
1719 if (len < 0)
e01e37b8203e (Fnew_fontset): Call font_unparse_xlfd with 256-byte
Kenichi Handa <handa@m17n.org>
parents: 94963
diff changeset
1720 error ("Invalid fontset name (perhaps too long): %s", SDATA (name));
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1721 FONTSET_ASCII (fontset) = make_unibyte_string (xlfd, len);
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1722 }
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1723 else
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1724 {
101943
97c9e9322753 Remove spurious semicolons.
Juanma Barranquero <lekktu@gmail.com>
parents: 101605
diff changeset
1725 fontset = FONTSET_FROM_ID (id);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1726 free_realized_fontsets (fontset);
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1727 Fset_char_table_range (fontset, Qt, Qnil);
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1728 }
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1729
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1730 for (; ! NILP (fontlist); fontlist = Fcdr (fontlist))
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1731 {
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1732 Lisp_Object elt, script;
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1733
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1734 elt = Fcar (fontlist);
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1735 script = Fcar (elt);
89607
9090f7eba02c (Fnew_fontset): Check NAME more rigidly.
Kenichi Handa <handa@m17n.org>
parents: 89603
diff changeset
1736 elt = Fcdr (elt);
9090f7eba02c (Fnew_fontset): Check NAME more rigidly.
Kenichi Handa <handa@m17n.org>
parents: 89603
diff changeset
1737 if (CONSP (elt) && (NILP (XCDR (elt)) || CONSP (XCDR (elt))))
9090f7eba02c (Fnew_fontset): Check NAME more rigidly.
Kenichi Handa <handa@m17n.org>
parents: 89603
diff changeset
1738 for (; CONSP (elt); elt = XCDR (elt))
9090f7eba02c (Fnew_fontset): Check NAME more rigidly.
Kenichi Handa <handa@m17n.org>
parents: 89603
diff changeset
1739 Fset_fontset_font (name, script, XCAR (elt), Qnil, Qappend);
9090f7eba02c (Fnew_fontset): Check NAME more rigidly.
Kenichi Handa <handa@m17n.org>
parents: 89603
diff changeset
1740 else
9090f7eba02c (Fnew_fontset): Check NAME more rigidly.
Kenichi Handa <handa@m17n.org>
parents: 89603
diff changeset
1741 Fset_fontset_font (name, script, elt, Qnil, Qappend);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1742 }
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1743 return name;
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1744 }
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1745
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
1746
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
1747 /* Alist of automatically created fontsets. Each element is a cons
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1748 (FONT-SPEC . FONTSET-ID). */
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
1749 static Lisp_Object auto_fontset_alist;
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1750
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1751 /* Number of automatically created fontsets. */
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1752 static int num_auto_fontsets;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1753
102793
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1754 /* Retun a fontset synthesized from FONT-OBJECT. This is called from
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1755 x_new_font when FONT-OBJECT is used for the default ASCII font of a
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1756 frame, and the returned fontset is used for the default fontset of
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1757 that frame. The fontset specifies a font of the same registry as
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1758 FONT-OBJECT for all characters in the repertory of the registry
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1759 (see Vfont_encoding_alist). If the repertory is not known, the
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1760 fontset specifies the font for all Latin characters assuming that a
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1761 user intends to use FONT-OBJECT for Latin characters. */
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1762
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1763 int
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1764 fontset_from_font (font_object)
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
1765 Lisp_Object font_object;
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
1766 {
90466
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1767 Lisp_Object font_name = font_get_name (font_object);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1768 Lisp_Object font_spec = Fcopy_font_spec (font_object);
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1769 Lisp_Object registry = AREF (font_spec, FONT_REGISTRY_INDEX);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1770 Lisp_Object fontset_spec, alias, name, fontset;
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1771 Lisp_Object val;
90466
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1772
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1773 val = assoc_no_quit (font_spec, auto_fontset_alist);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1774 if (CONSP (val))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1775 return XINT (FONTSET_ID (XCDR (val)));
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1776 if (num_auto_fontsets++ == 0)
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1777 alias = intern ("fontset-startup");
90466
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1778 else
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1779 {
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1780 char temp[32];
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
1781
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1782 sprintf (temp, "fontset-auto%d", num_auto_fontsets - 1);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1783 alias = intern (temp);
90466
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1784 }
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1785 fontset_spec = Fcopy_font_spec (font_spec);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1786 ASET (fontset_spec, FONT_REGISTRY_INDEX, alias);
95179
5c007b5b6cd8 (fontset_from_font, Ffontset_info): Add the 2nd arg in
Kenichi Handa <handa@m17n.org>
parents: 95143
diff changeset
1787 name = Ffont_xlfd_name (fontset_spec, Qnil);
90466
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1788 if (NILP (name))
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1789 abort ();
90466
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1790 fontset = make_fontset (Qnil, name, Qnil);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1791 Vfontset_alias_alist = Fcons (Fcons (name, SYMBOL_NAME (alias)),
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1792 Vfontset_alias_alist);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1793 alias = Fdowncase (AREF (font_object, FONT_NAME_INDEX));
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1794 Vfontset_alias_alist = Fcons (Fcons (name, alias), Vfontset_alias_alist);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1795 auto_fontset_alist = Fcons (Fcons (font_spec, fontset), auto_fontset_alist);
102793
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1796 font_spec = Ffont_spec (0, NULL);
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1797 ASET (font_spec, FONT_REGISTRY_INDEX, registry);
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1798 {
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1799 Lisp_Object target = find_font_encoding (SYMBOL_NAME (registry));
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1800
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1801 if (CONSP (target))
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1802 target = XCDR (target);
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1803 if (! CHARSETP (target))
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1804 target = Qlatin;
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1805 Fset_fontset_font (name, target, font_spec, Qnil, Qnil);
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1806 Fset_fontset_font (name, Qnil, font_spec, Qnil, Qnil);
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1807 }
0e6449977a63 (fontset_from_font): Specify only registry in a font-spec for all
Kenichi Handa <handa@m17n.org>
parents: 102654
diff changeset
1808
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1809 FONTSET_ASCII (fontset) = font_name;
96675
d45acf0c8d23 merging Emacs.app (NeXTstep port)
Adrian Robert <Adrian.B.Robert@gmail.com>
parents: 96655
diff changeset
1810
90466
4c9461c6aef4 (new_fontset_from_font) [USE_FONT_BACKEND]: Argument F
Kenichi Handa <handa@m17n.org>
parents: 90449
diff changeset
1811 return XINT (FONTSET_ID (fontset));
90410
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
1812 }
55a58b0d3d9e Include "font.h".
Kenichi Handa <handa@m17n.org>
parents: 90294
diff changeset
1813
102480
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1814
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1815 /* Update auto_fontset_alist for FONTSET. When an ASCII font of
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1816 FONTSET is changed, we delete an entry of FONTSET if any from
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1817 auto_fontset_alist so that FONTSET is not re-used by
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1818 fontset_from_font. */
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1819
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1820 static void
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1821 update_auto_fontset_alist (font_object, fontset)
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1822 Lisp_Object font_object, fontset;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1823 {
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1824 Lisp_Object prev, tail;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1825
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1826 for (prev = Qnil, tail = auto_fontset_alist; CONSP (tail);
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1827 prev = tail, tail = XCDR (tail))
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1828 if (EQ (fontset, XCDR (XCAR (tail))))
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1829 {
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1830 if (NILP (prev))
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1831 auto_fontset_alist = XCDR (tail);
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1832 else
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1833 XSETCDR (prev, XCDR (tail));
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1834 break;
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1835 }
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1836 }
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1837
c50bd87f030b (Fset_fontset_font): When a font for ASCII is changed,
Kenichi Handa <handa@m17n.org>
parents: 102417
diff changeset
1838
96414
37737408d4f2 (Finternal_char_font): Return font-object instead of font-name.
Kenichi Handa <handa@m17n.org>
parents: 96087
diff changeset
1839 /* Return a cons (FONT-OBJECT . GLYPH-CODE).
37737408d4f2 (Finternal_char_font): Return font-object instead of font-name.
Kenichi Handa <handa@m17n.org>
parents: 96087
diff changeset
1840 FONT-OBJECT is the font for the character at POSITION in the current
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1841 buffer. This is computed from all the text properties and overlays
55094
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1842 that apply to POSITION. POSTION may be nil, in which case,
96414
37737408d4f2 (Finternal_char_font): Return font-object instead of font-name.
Kenichi Handa <handa@m17n.org>
parents: 96087
diff changeset
1843 FONT-SPEC is the font for displaying the character CH with the
55094
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1844 default face.
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1845
52654
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1846 GLYPH-CODE is the glyph code in the font to use for the character.
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1847
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1848 If the 2nd optional arg CH is non-nil, it is a character to check
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1849 the font instead of the character at POSITION.
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1850
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1851 It returns nil in the following cases:
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1852
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1853 (1) The window system doesn't have a font for the character (thus
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1854 it is displayed by an empty box).
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1855
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1856 (2) The character code is invalid.
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1857
55094
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1858 (3) If POSITION is not nil, and the current buffer is not displayed
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1859 in any window.
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1860
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1861 In addition, the returned font name may not take into account of
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1862 such redisplay engine hooks as what used in jit-lock-mode if
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1863 POSITION is currently not visible. */
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1864
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1865
52654
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1866 DEFUN ("internal-char-font", Finternal_char_font, Sinternal_char_font, 1, 2, 0,
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
1867 doc: /* For internal use only. */)
52654
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1868 (position, ch)
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1869 Lisp_Object position, ch;
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1870 {
92237
ce06567a933d * dispextern.h (face_at_buffer_position, face_for_overlay_string)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91908
diff changeset
1871 EMACS_INT pos, pos_byte, dummy;
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1872 int face_id;
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1873 int c;
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1874 struct frame *f;
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1875 struct face *face;
90725
6d8c81691fc8 (Finternal_char_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 90716
diff changeset
1876 int cs_id;
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1877
55094
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1878 if (NILP (position))
52654
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1879 {
89904
76c449b624ad Sync to HEAD.
Kenichi Handa <handa@m17n.org>
parents: 89901
diff changeset
1880 CHECK_CHARACTER (ch);
52654
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1881 c = XINT (ch);
55094
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1882 f = XFRAME (selected_frame);
95457
415f68458e61 Implement face-remapping-alist feature
Miles Bader <miles@gnu.org>
parents: 95404
diff changeset
1883 face_id = lookup_basic_face (f, DEFAULT_FACE_ID);
89943
4c90ffeb71c5 Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-15
Miles Bader <miles@gnu.org>
parents: 89940 55094
diff changeset
1884 pos = -1;
90725
6d8c81691fc8 (Finternal_char_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 90716
diff changeset
1885 cs_id = -1;
55094
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1886 }
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1887 else
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1888 {
90716
f5dc0b9a442c (Finternal_char_font): Fix for the case of POSITION
Kenichi Handa <handa@m17n.org>
parents: 90642
diff changeset
1889 Lisp_Object window, charset;
55094
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1890 struct window *w;
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1891
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1892 CHECK_NUMBER_COERCE_MARKER (position);
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1893 pos = XINT (position);
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1894 if (pos < BEGV || pos >= ZV)
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1895 args_out_of_range_3 (position, make_number (BEGV), make_number (ZV));
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1896 pos_byte = CHAR_TO_BYTE (pos);
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1897 if (NILP (ch))
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1898 c = FETCH_CHAR (pos_byte);
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1899 else
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1900 {
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1901 CHECK_NATNUM (ch);
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1902 c = XINT (ch);
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1903 }
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1904 window = Fget_buffer_window (Fcurrent_buffer (), Qnil);
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1905 if (NILP (window))
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1906 return Qnil;
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1907 w = XWINDOW (window);
450b41d3c078 (Finternal_char_font): If POSITION is nil, return
Kenichi Handa <handa@m17n.org>
parents: 54995
diff changeset
1908 f = XFRAME (w->frame);
103114
fa8e2c663118 * xfaces.c (face_at_buffer_position): New arg base_face_id.
Chong Yidong <cyd@stupidchicken.com>
parents: 103112
diff changeset
1909 face_id = face_at_buffer_position (w, pos, -1, -1, &dummy,
fa8e2c663118 * xfaces.c (face_at_buffer_position): New arg base_face_id.
Chong Yidong <cyd@stupidchicken.com>
parents: 103112
diff changeset
1910 pos + 100, 0, -1);
90716
f5dc0b9a442c (Finternal_char_font): Fix for the case of POSITION
Kenichi Handa <handa@m17n.org>
parents: 90642
diff changeset
1911 charset = Fget_char_property (position, Qcharset, Qnil);
f5dc0b9a442c (Finternal_char_font): Fix for the case of POSITION
Kenichi Handa <handa@m17n.org>
parents: 90642
diff changeset
1912 if (CHARSETP (charset))
90725
6d8c81691fc8 (Finternal_char_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 90716
diff changeset
1913 cs_id = XINT (CHARSET_SYMBOL_ID (charset));
90716
f5dc0b9a442c (Finternal_char_font): Fix for the case of POSITION
Kenichi Handa <handa@m17n.org>
parents: 90642
diff changeset
1914 else
90725
6d8c81691fc8 (Finternal_char_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 90716
diff changeset
1915 cs_id = -1;
52654
2e5944e29aa0 (Finternal_char_font): Change return value to
Kenichi Handa <handa@m17n.org>
parents: 52401
diff changeset
1916 }
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1917 if (! CHAR_VALID_P (c, 0))
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1918 return Qnil;
89943
4c90ffeb71c5 Revision: miles@gnu.org--gnu-2004/emacs--unicode--0--patch-15
Miles Bader <miles@gnu.org>
parents: 89940 55094
diff changeset
1919 face_id = FACE_FOR_CHAR (f, FACE_FROM_ID (f, face_id), c, pos, Qnil);
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1920 face = FACE_FROM_ID (f, face_id);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1921 if (face->font)
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1922 {
96414
37737408d4f2 (Finternal_char_font): Return font-object instead of font-name.
Kenichi Handa <handa@m17n.org>
parents: 96087
diff changeset
1923 unsigned code = face->font->driver->encode_char (face->font, c);
37737408d4f2 (Finternal_char_font): Return font-object instead of font-name.
Kenichi Handa <handa@m17n.org>
parents: 96087
diff changeset
1924 Lisp_Object font_object;
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1925 /* Assignment to EMACS_INT stops GCC whining about limited range
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1926 of data type. */
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1927 EMACS_INT cod = code;
49874
3bdee1887901 (check_fontset_name): If NAME is nil, return the
Kenichi Handa <handa@m17n.org>
parents: 49286
diff changeset
1928
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1929 if (code == FONT_INVALID_CODE)
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1930 return Qnil;
96414
37737408d4f2 (Finternal_char_font): Return font-object instead of font-name.
Kenichi Handa <handa@m17n.org>
parents: 96087
diff changeset
1931 XSETFONT (font_object, face->font);
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1932 if (cod <= MOST_POSITIVE_FIXNUM)
96414
37737408d4f2 (Finternal_char_font): Return font-object instead of font-name.
Kenichi Handa <handa@m17n.org>
parents: 96087
diff changeset
1933 return Fcons (font_object, make_number (code));
37737408d4f2 (Finternal_char_font): Return font-object instead of font-name.
Kenichi Handa <handa@m17n.org>
parents: 96087
diff changeset
1934 return Fcons (font_object, Fcons (make_number (code >> 16),
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
1935 make_number (code & 0xFFFF)));
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1936 }
89904
76c449b624ad Sync to HEAD.
Kenichi Handa <handa@m17n.org>
parents: 89901
diff changeset
1937 return Qnil;
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1938 }
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1939
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1940
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1941 DEFUN ("fontset-info", Ffontset_info, Sfontset_info, 1, 2, 0,
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1942 doc: /* Return information about a fontset FONTSET on frame FRAME.
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1943
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1944 FONTSET is a fontset name string, nil for the fontset of FRAME, or t
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1945 for the default fontset. FRAME nil means the selected frame.
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1946
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
1947 The value is a char-table whose elements have this form:
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1948
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1949 ((FONT OPENED-FONT ...) ...)
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1950
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1951 FONT is a name of font specified for a range of characters.
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1952
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1953 OPENED-FONT is a name of a font actually opened.
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
1954
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1955 The char-table has one extra slot. If FONTSET is not the default
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1956 fontset, the value the extra slot is a char-table containing the
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1957 information about the derived fonts from the default fontset. The
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1958 format is the same as above. */)
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1959 (fontset, frame)
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1960 Lisp_Object fontset, frame;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1961 {
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1962 FRAME_PTR f;
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1963 Lisp_Object *realized[2], fontsets[2], tables[2];
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1964 Lisp_Object val, elt;
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1965 int c, i, j, k;
41987
34952771ae85 Fix typos, remove unnecessary space.
Pavel Janík <Pavel@Janik.cz>
parents: 41052
diff changeset
1966
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1967 (*check_window_system_func) ();
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1968
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1969 fontset = check_fontset_name (fontset, &frame);
25668
99290b59352d (Ffont_info): Change for Lisp_Object selected_frame.
Gerd Moellmann <gerd@gnu.org>
parents: 24611
diff changeset
1970 f = XFRAME (frame);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1971
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1972 /* Recode fontsets realized on FRAME from the base fontset FONTSET
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1973 in the table `realized'. */
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1974 realized[0] = (Lisp_Object *) alloca (sizeof (Lisp_Object)
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1975 * ASIZE (Vfontset_table));
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1976 for (i = j = 0; i < ASIZE (Vfontset_table); i++)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1977 {
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1978 elt = FONTSET_FROM_ID (i);
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
1979 if (!NILP (elt)
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1980 && EQ (FONTSET_BASE (elt), fontset)
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
1981 && EQ (FONTSET_FRAME (elt), frame))
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1982 realized[0][j++] = elt;
49874
3bdee1887901 (check_fontset_name): If NAME is nil, return the
Kenichi Handa <handa@m17n.org>
parents: 49286
diff changeset
1983 }
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1984 realized[0][j] = Qnil;
49874
3bdee1887901 (check_fontset_name): If NAME is nil, return the
Kenichi Handa <handa@m17n.org>
parents: 49286
diff changeset
1985
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1986 realized[1] = (Lisp_Object *) alloca (sizeof (Lisp_Object)
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1987 * ASIZE (Vfontset_table));
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1988 for (i = j = 0; ! NILP (realized[0][i]); i++)
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1989 {
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1990 elt = FONTSET_DEFAULT (realized[0][i]);
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1991 if (! NILP (elt))
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1992 realized[1][j++] = elt;
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1993 }
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1994 realized[1][j] = Qnil;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
1995
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1996 tables[0] = Fmake_char_table (Qfontset_info, Qnil);
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
1997 fontsets[0] = fontset;
102528
89dd546c60a7 (Ffontset_info): YAILOM (Yet another int/Lisp_Object mixup).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 102527
diff changeset
1998 if (!EQ (fontset, Vdefault_fontset))
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
1999 {
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2000 tables[1] = Fmake_char_table (Qnil, Qnil);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2001 XCHAR_TABLE (tables[0])->extras[0] = tables[1];
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2002 fontsets[1] = Vdefault_fontset;
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2003 }
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2004
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2005 /* Accumulate information of the fontset in TABLE. The format of
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2006 each element is ((FONT-SPEC OPENED-FONT ...) ...). */
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2007 for (k = 0; k <= 1; k++)
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2008 {
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2009 for (c = 0; c <= MAX_CHAR; )
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2010 {
99980
0a43374c0145 (fontset_add): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 98582
diff changeset
2011 int from = c, to = MAX_5_BYTE_CHAR;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2012
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2013 if (c <= MAX_5_BYTE_CHAR)
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2014 {
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2015 val = char_table_ref_and_range (fontsets[k], c, &from, &to);
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2016 }
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2017 else
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2018 {
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2019 val = FONTSET_FALLBACK (fontsets[k]);
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2020 to = MAX_CHAR;
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2021 }
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2022 if (VECTORP (val))
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2023 {
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2024 Lisp_Object alist;
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2025
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2026 /* At first, set ALIST to ((FONT-SPEC) ...). */
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2027 for (alist = Qnil, i = 0; i < ASIZE (val); i++)
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2028 if (! NILP (AREF (val, i)))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2029 alist = Fcons (Fcons (FONT_DEF_SPEC (AREF (val, i)), Qnil),
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2030 alist);
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2031 alist = Fnreverse (alist);
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2032
95656
32785fc68f99 (Ffontset_info): Fix typo.
Andreas Schwab <schwab@suse.de>
parents: 95570
diff changeset
2033 /* Then store opened font names to cdr of each elements. */
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2034 for (i = 0; ! NILP (realized[k][i]); i++)
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2035 {
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2036 if (c <= MAX_5_BYTE_CHAR)
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2037 val = FONTSET_REF (realized[k][i], c);
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2038 else
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2039 val = FONTSET_FALLBACK (realized[k][i]);
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2040 if (! CONSP (val) || ! VECTORP (XCDR (val)))
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2041 continue;
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2042 /* VAL: (int . [[FACE-ID FONT-DEF FONT-OBJECT int] ... ]) */
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2043 val = XCDR (val);
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2044 for (j = 0; j < ASIZE (val); j++)
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2045 {
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2046 elt = AREF (val, j);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2047 if (FONT_OBJECT_P (RFONT_DEF_OBJECT (elt)))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2048 {
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2049 Lisp_Object font_object = RFONT_DEF_OBJECT (elt);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2050 Lisp_Object slot, name;
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2051
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2052 slot = Fassq (RFONT_DEF_SPEC (elt), alist);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2053 name = AREF (font_object, FONT_NAME_INDEX);
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2054 if (NILP (Fmember (name, XCDR (slot))))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2055 nconc2 (slot, Fcons (name, Qnil));
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2056 }
91513
53399782ad84 (Ffontset_info): Handle the case of inhibitting the
Kenichi Handa <handa@m17n.org>
parents: 91364
diff changeset
2057 }
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2058 }
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2059
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2060 /* Store ALIST in TBL for characters C..TO. */
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2061 if (c <= MAX_5_BYTE_CHAR)
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2062 char_table_set_range (tables[k], c, to, alist);
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2063 else
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2064 XCHAR_TABLE (tables[k])->defalt = alist;
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2065
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2066 /* At last, change each elements to font names. */
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2067 for (; CONSP (alist); alist = XCDR (alist))
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2068 {
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2069 elt = XCAR (alist);
95179
5c007b5b6cd8 (fontset_from_font, Ffontset_info): Add the 2nd arg in
Kenichi Handa <handa@m17n.org>
parents: 95143
diff changeset
2070 XSETCAR (elt, Ffont_xlfd_name (XCAR (elt), Qnil));
94928
a9ee82808208 Throughout the file, delete all USE_FONT_BACKEND
Kenichi Handa <handa@m17n.org>
parents: 92705
diff changeset
2071 }
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2072 }
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2073 c = to + 1;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2074 }
102527
e16d4567a1bc (Ffontset_info): YAILOM (Yet another int/Lisp_Object mixup).
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 102524
diff changeset
2075 if (EQ (fontset, Vdefault_fontset))
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2076 break;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2077 }
30124
26076259e03f (Ffontset_info): Make the return value more compatible
Kenichi Handa <handa@m17n.org>
parents: 29767
diff changeset
2078
89811
d13626b05df3 (fontset_face): Handle fallback fonts correctly.
Kenichi Handa <handa@m17n.org>
parents: 89805
diff changeset
2079 return tables[0];
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2080 }
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2081
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2082
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2083 DEFUN ("fontset-font", Ffontset_font, Sfontset_font, 2, 3, 0,
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2084 doc: /* Return a font name pattern for character CH in fontset NAME.
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2085 If NAME is t, find a pattern in the default fontset.
104319
61b86c490f92 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 103788
diff changeset
2086 If NAME is nil, find a pattern in the fontset of the selected frame.
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2087
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2088 The value has the form (FAMILY . REGISTRY), where FAMILY is a font
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2089 family name and REGISTRY is a font registry name. This is actually
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2090 the first font name pattern for CH in the fontset or in the default
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2091 fontset.
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2092
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2093 If the 2nd optional arg ALL is non-nil, return a list of all font name
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2094 patterns. */)
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2095 (name, ch, all)
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2096 Lisp_Object name, ch, all;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2097 {
34975
0d69e2d2724e (fontset_ref): Remove unused variable `i'.
Eli Zaretskii <eliz@gnu.org>
parents: 32978
diff changeset
2098 int c;
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2099 Lisp_Object fontset, elt, list, repertory, val;
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2100 int i, j;
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2101 Lisp_Object frame;
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2102
102521
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2103 frame = Qnil;
855091f2ad89 (Ffontset_info, check_fontset_name): New arg frame.
Kenichi Handa <handa@m17n.org>
parents: 102480
diff changeset
2104 fontset = check_fontset_name (name, &frame);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2105
88405
8ae0d0693ed9 Mostly re-written.
Kenichi Handa <handa@m17n.org>
parents: 41987
diff changeset
2106 CHECK_CHARACTER (ch);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2107 c = XINT (ch);
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2108 list = Qnil;
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2109 while (1)
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2110 {
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2111 for (i = 0, elt = FONTSET_REF (fontset, c); i < 2;
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2112 i++, elt = FONTSET_FALLBACK (fontset))
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2113 if (VECTORP (elt))
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2114 for (j = 0; j < ASIZE (elt); j++)
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2115 {
101553
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2116 Lisp_Object family, registry;
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2117
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2118 val = AREF (elt, j);
104319
61b86c490f92 *** empty log message ***
Kenichi Handa <handa@m17n.org>
parents: 103788
diff changeset
2119 if (NILP (val))
104321
8f1c018c050c (Ffontset_font): Fix previous change.
Kenichi Handa <handa@m17n.org>
parents: 104319
diff changeset
2120 return Qnil;
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2121 repertory = AREF (val, 1);
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2122 if (INTEGERP (repertory))
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2123 {
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2124 struct charset *charset = CHARSET_FROM_ID (XINT (repertory));
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2125
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2126 if (! CHAR_CHARSET_P (c, charset))
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2127 continue;
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2128 }
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2129 else if (CHAR_TABLE_P (repertory))
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2130 {
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2131 if (NILP (CHAR_TABLE_REF (repertory, c)))
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2132 continue;
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2133 }
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2134 val = AREF (val, 0);
101553
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2135 /* VAL is a FONT-SPEC */
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2136 family = AREF (val, FONT_FAMILY_INDEX);
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2137 if (! NILP (family))
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2138 family = SYMBOL_NAME (family);
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2139 registry = AREF (val, FONT_REGISTRY_INDEX);
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2140 if (! NILP (registry))
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2141 registry = SYMBOL_NAME (registry);
a44c0bbce387 (font_for_char): Use assq_no_quit, not assoc_no_quit.
Kenichi Handa <handa@m17n.org>
parents: 101522
diff changeset
2142 val = Fcons (family, registry);
89940
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2143 if (NILP (all))
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2144 return val;
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2145 list = Fcons (val, list);
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2146 }
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2147 if (EQ (fontset, Vdefault_fontset))
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2148 break;
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2149 fontset = Vdefault_fontset;
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2150 }
713a4f4140ca (Fset_fontset_font): Docstring fixed.
Kenichi Handa <handa@m17n.org>
parents: 89904
diff changeset
2151 return (Fnreverse (list));
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2152 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2153
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2154 DEFUN ("fontset-list", Ffontset_list, Sfontset_list, 0, 0, 0,
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2155 doc: /* Return a list of all defined fontset names. */)
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2156 ()
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2157 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2158 Lisp_Object fontset, list;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2159 int i;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2160
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2161 list = Qnil;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2162 for (i = 0; i < ASIZE (Vfontset_table); i++)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2163 {
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2164 fontset = FONTSET_FROM_ID (i);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2165 if (!NILP (fontset)
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2166 && BASE_FONTSET_P (fontset))
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2167 list = Fcons (FONTSET_NAME (fontset), list);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2168 }
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2169
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2170 return list;
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2171 }
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2172
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2173
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2174 #ifdef FONTSET_DEBUG
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2175
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2176 Lisp_Object
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2177 dump_fontset (fontset)
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2178 Lisp_Object fontset;
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2179 {
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2180 Lisp_Object vec;
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2181
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2182 vec = Fmake_vector (make_number (3), Qnil);
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2183 ASET (vec, 0, FONTSET_ID (fontset));
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2184
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2185 if (BASE_FONTSET_P (fontset))
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2186 {
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2187 ASET (vec, 1, FONTSET_NAME (fontset));
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2188 }
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2189 else
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2190 {
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2191 Lisp_Object frame;
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2192
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2193 frame = FONTSET_FRAME (fontset);
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2194 if (FRAMEP (frame))
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2195 {
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2196 FRAME_PTR f = XFRAME (frame);
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2197
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2198 if (FRAME_LIVE_P (f))
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
2199 ASET (vec, 1,
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
2200 Fcons (FONTSET_NAME (FONTSET_BASE (fontset)), f->name));
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2201 else
90802
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
2202 ASET (vec, 1,
bfafc889caa9 (fontset_find_font): New function.
Kenichi Handa <handa@m17n.org>
parents: 90737
diff changeset
2203 Fcons (FONTSET_NAME (FONTSET_BASE (fontset)), Qnil));
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2204 }
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
2205 if (!NILP (FONTSET_DEFAULT (fontset)))
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
2206 ASET (vec, 2, FONTSET_ID (FONTSET_DEFAULT (fontset)));
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2207 }
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2208 return vec;
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2209 }
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2210
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2211 DEFUN ("fontset-list-all", Ffontset_list_all, Sfontset_list_all, 0, 0, 0,
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2212 doc: /* Return a brief summary of all fontsets for debug use. */)
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2213 ()
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2214 {
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2215 Lisp_Object val;
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2216 int i;
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2217
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2218 for (i = 0, val = Qnil; i < ASIZE (Vfontset_table); i++)
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2219 if (! NILP (AREF (Vfontset_table, i)))
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2220 val = Fcons (dump_fontset (AREF (Vfontset_table, i)), val);
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2221 return (Fnreverse (val));
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2222 }
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2223 #endif /* FONTSET_DEBUG */
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2224
21514
fa9ff387d260 Fix -Wimplicit warnings.
Andreas Schwab <schwab@suse.de>
parents: 21127
diff changeset
2225 void
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2226 syms_of_fontset ()
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2227 {
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2228 DEFSYM (Qfontset, "fontset");
89805
35a0a24752d3 (FONTSET_DEFAULT): New macro.
Kenichi Handa <handa@m17n.org>
parents: 89711
diff changeset
2229 Fput (Qfontset, Qchar_table_extra_slots, make_number (9));
89349
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2230 DEFSYM (Qfontset_info, "fontset-info");
9a305cf42688 Give 8 extra slots to fontset objects.
Kenichi Handa <handa@m17n.org>
parents: 89337
diff changeset
2231 Fput (Qfontset_info, Qchar_table_extra_slots, make_number (1));
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2232
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2233 DEFSYM (Qprepend, "prepend");
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2234 DEFSYM (Qappend, "append");
90642
92baf98563e4 (Qlatin): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90509
diff changeset
2235 DEFSYM (Qlatin, "latin");
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2236
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2237 Vcached_fontset_data = Qnil;
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2238 staticpro (&Vcached_fontset_data);
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2239
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2240 Vfontset_table = Fmake_vector (make_number (32), Qnil);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2241 staticpro (&Vfontset_table);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2242
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2243 Vdefault_fontset = Fmake_char_table (Qfontset, Qnil);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2244 staticpro (&Vdefault_fontset);
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2245 FONTSET_ID (Vdefault_fontset) = make_number (0);
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2246 FONTSET_NAME (Vdefault_fontset)
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2247 = build_string ("-*-*-*-*-*-*-*-*-*-*-*-*-fontset-default");
91668
aeadaa72f7b1 (free_face_fontset): Use FONTSET_FROM_ID.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91513
diff changeset
2248 ASET (Vfontset_table, 0, Vdefault_fontset);
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2249 next_fontset_id = 1;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2250
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2251 auto_fontset_alist = Qnil;
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2252 staticpro (&auto_fontset_alist);
53353
b085f18ebcf0 (Voverriding_fontspec_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 53072
diff changeset
2253
91266
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2254 DEFVAR_LISP ("font-encoding-charset-alist", &Vfont_encoding_charset_alist,
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2255 doc: /*
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2256 Alist of charsets vs the charsets to determine the preferred font encoding.
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
2257 Each element looks like (CHARSET . ENCODING-CHARSET),
91266
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2258 where ENCODING-CHARSET is a charset registered in the variable
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2259 `font-encoding-alist' as ENCODING.
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2260
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2261 When a text has a property `charset' and the value is CHARSET, a font
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2262 whose encoding corresponds to ENCODING-CHARSET is preferred. */);
3cd59392b3ec (Vfont_encoding_charset_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 91250
diff changeset
2263 Vfont_encoding_charset_alist = Qnil;
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2264
17112
5c48ff325655 (syms_of_fontset): Intern Qfontset. Declare new lisp
Kenichi Handa <handa@m17n.org>
parents: 17071
diff changeset
2265 DEFVAR_LISP ("use-default-ascent", &Vuse_default_ascent,
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2266 doc: /*
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2267 Char table of characters whose ascent values should be ignored.
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2268 If an entry for a character is non-nil, the ascent value of the glyph
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
2269 is assumed to be specified by _MULE_DEFAULT_ASCENT property of a font.
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2270
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2271 This affects how a composite character which contains
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2272 such a character is displayed on screen. */);
19282
09a1536debb4 (Vignore_relative_composition): New variable.
Kenichi Handa <handa@m17n.org>
parents: 19172
diff changeset
2273 Vuse_default_ascent = Qnil;
09a1536debb4 (Vignore_relative_composition): New variable.
Kenichi Handa <handa@m17n.org>
parents: 19172
diff changeset
2274
09a1536debb4 (Vignore_relative_composition): New variable.
Kenichi Handa <handa@m17n.org>
parents: 19172
diff changeset
2275 DEFVAR_LISP ("ignore-relative-composition", &Vignore_relative_composition,
88903
d32a3736c4fe (Qprepend, Qappend): New variables.
Kenichi Handa <handa@m17n.org>
parents: 88857
diff changeset
2276 doc: /*
95143
3e0cd839473e (Ffontset_info): Doc fix.
Juanma Barranquero <lekktu@gmail.com>
parents: 95127
diff changeset
2277 Char table of characters which are not composed relatively.
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2278 If an entry for a character is non-nil, a composition sequence
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2279 which contains that character is displayed so that
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2280 the glyph of that character is put without considering
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2281 an ascent and descent value of a previous character. */);
26858
7cc081b4e084 (Vvertical_centering_font_regexp): New variable.
Kenichi Handa <handa@m17n.org>
parents: 26164
diff changeset
2282 Vignore_relative_composition = Qnil;
17112
5c48ff325655 (syms_of_fontset): Intern Qfontset. Declare new lisp
Kenichi Handa <handa@m17n.org>
parents: 17071
diff changeset
2283
19450
895dc2520755 (Valternate_fontname_alist): Name changed from
Kenichi Handa <handa@m17n.org>
parents: 19282
diff changeset
2284 DEFVAR_LISP ("alternate-fontname-alist", &Valternate_fontname_alist,
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2285 doc: /* Alist of fontname vs list of the alternate fontnames.
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2286 When a specified font name is not found, the corresponding
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2287 alternate fontnames (if any) are tried instead. */);
19450
895dc2520755 (Valternate_fontname_alist): Name changed from
Kenichi Handa <handa@m17n.org>
parents: 19282
diff changeset
2288 Valternate_fontname_alist = Qnil;
17193
dc4562b0152a (Valternative_fontname_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17190
diff changeset
2289
17730
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
2290 DEFVAR_LISP ("fontset-alias-alist", &Vfontset_alias_alist,
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2291 doc: /* Alist of fontset names vs the aliases. */);
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2292 Vfontset_alias_alist = Fcons (Fcons (FONTSET_NAME (Vdefault_fontset),
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2293 build_string ("fontset-default")),
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2294 Qnil);
17730
4bbcc6804b5d (Vfontset_alias_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 17331
diff changeset
2295
26858
7cc081b4e084 (Vvertical_centering_font_regexp): New variable.
Kenichi Handa <handa@m17n.org>
parents: 26164
diff changeset
2296 DEFVAR_LISP ("vertical-centering-font-regexp",
7cc081b4e084 (Vvertical_centering_font_regexp): New variable.
Kenichi Handa <handa@m17n.org>
parents: 26164
diff changeset
2297 &Vvertical_centering_font_regexp,
41001
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2298 doc: /* *Regexp matching font names that require vertical centering on display.
a17c8b15ef1b Change doc-string comments to `new style' [w/`doc:' keyword].
Pavel Janík <Pavel@Janik.cz>
parents: 40771
diff changeset
2299 When a character is displayed with such fonts, the character is displayed
41987
34952771ae85 Fix typos, remove unnecessary space.
Pavel Janík <Pavel@Janik.cz>
parents: 41052
diff changeset
2300 at the vertical center of lines. */);
26858
7cc081b4e084 (Vvertical_centering_font_regexp): New variable.
Kenichi Handa <handa@m17n.org>
parents: 26164
diff changeset
2301 Vvertical_centering_font_regexp = Qnil;
7cc081b4e084 (Vvertical_centering_font_regexp): New variable.
Kenichi Handa <handa@m17n.org>
parents: 26164
diff changeset
2302
90509
c1ec6b950928 (Votf_script_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90475
diff changeset
2303 DEFVAR_LISP ("otf-script-alist", &Votf_script_alist,
c1ec6b950928 (Votf_script_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90475
diff changeset
2304 doc: /* Alist of OpenType script tags vs the corresponding script names. */);
c1ec6b950928 (Votf_script_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90475
diff changeset
2305 Votf_script_alist = Qnil;
c1ec6b950928 (Votf_script_alist): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90475
diff changeset
2306
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2307 defsubr (&Squery_fontset);
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2308 defsubr (&Snew_fontset);
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2309 defsubr (&Sset_fontset_font);
28963
24af4ff8f7b6 Include "buffer.h".
Kenichi Handa <handa@m17n.org>
parents: 28766
diff changeset
2310 defsubr (&Sinternal_char_font);
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2311 defsubr (&Sfontset_info);
28223
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2312 defsubr (&Sfontset_font);
b888c69e8bf0 All codes rewritten or adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 26858
diff changeset
2313 defsubr (&Sfontset_list);
89610
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2314 #ifdef FONTSET_DEBUG
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2315 defsubr (&Sfontset_list_all);
3aa74296be55 (fontset_face): Create a fallback fontset on demand
Kenichi Handa <handa@m17n.org>
parents: 89607
diff changeset
2316 #endif
17052
d0d7b244b1d0 Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2317 }
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 51033
diff changeset
2318
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 51033
diff changeset
2319 /* arch-tag: ea861585-2f5f-4e5b-9849-d04a9c3a3537
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 51033
diff changeset
2320 (do not change this comment) */