Mercurial > emacs
annotate src/font.c @ 95265:de1c8bf64340
(capitalized-words-mode): Fix typos in docstring.
| author | Juanma Barranquero <lekktu@gmail.com> |
|---|---|
| date | Fri, 23 May 2008 15:29:53 +0000 |
| parents | 22b86bc3a920 |
| children | e3e5f8759ca5 |
| rev | line source |
|---|---|
| 90400 | 1 /* font.c -- "Font" primitives. |
| 91553 | 2 Copyright (C) 2006, 2007, 2008 Free Software Foundation, Inc. |
| 3 Copyright (C) 2006, 2007, 2008 | |
| 90400 | 4 National Institute of Advanced Industrial Science and Technology (AIST) |
| 5 Registration Number H13PRO009 | |
| 6 | |
| 7 This file is part of GNU Emacs. | |
| 8 | |
|
94963
8971ddf55736
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94926
diff
changeset
|
9 GNU Emacs is free software: you can redistribute it and/or modify |
| 90400 | 10 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:
94926
diff
changeset
|
11 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:
94926
diff
changeset
|
12 (at your option) any later version. |
| 90400 | 13 |
| 14 GNU Emacs is distributed in the hope that it will be useful, | |
| 15 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 17 GNU General Public License for more details. | |
| 18 | |
| 19 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:
94926
diff
changeset
|
20 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */ |
| 90400 | 21 |
| 22 #include <config.h> | |
| 23 #include <stdio.h> | |
| 24 #include <stdlib.h> | |
| 25 #include <ctype.h> | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
26 #ifdef HAVE_M17N_FLT |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
27 #include <m17n-flt.h> |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
28 #endif |
| 90400 | 29 |
| 30 #include "lisp.h" | |
| 31 #include "buffer.h" | |
| 32 #include "frame.h" | |
| 90541 | 33 #include "window.h" |
| 90400 | 34 #include "dispextern.h" |
| 35 #include "charset.h" | |
| 36 #include "character.h" | |
| 37 #include "composite.h" | |
| 38 #include "fontset.h" | |
| 39 #include "font.h" | |
| 40 | |
| 91909 | 41 #ifdef HAVE_X_WINDOWS |
| 42 #include "xterm.h" | |
| 43 #endif /* HAVE_X_WINDOWS */ | |
| 44 | |
| 45 #ifdef HAVE_NTGUI | |
| 46 #include "w32term.h" | |
| 47 #endif /* HAVE_NTGUI */ | |
| 48 | |
| 49 #ifdef MAC_OS | |
| 50 #include "macterm.h" | |
| 51 #endif /* MAC_OS */ | |
| 52 | |
| 94926 | 53 Lisp_Object Qfont_spec, Qfont_entity, Qfont_object; |
| 90400 | 54 |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
55 Lisp_Object Qopentype; |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
56 |
| 94926 | 57 /* Important character set strings. */ |
|
90622
bb9362e3a03b
(Qunicode_sip): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90590
diff
changeset
|
58 Lisp_Object Qiso8859_1, Qiso10646_1, Qunicode_bmp, Qunicode_sip; |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
59 |
| 90400 | 60 /* Special vector of zero length. This is repeatedly used by (struct |
| 61 font_driver *)->list when a specified font is not found. */ | |
| 94926 | 62 static Lisp_Object null_vector; |
| 63 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
64 static Lisp_Object Vfont_weight_table, Vfont_slant_table, Vfont_width_table; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
65 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
66 /* Vector of Vfont_weight_table, Vfont_slant_table, and Vfont_width_table. */ |
| 90400 | 67 static Lisp_Object font_style_table; |
| 68 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
69 /* Structure used for tables mapping weight, slant, and width numeric |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
70 values and their names. */ |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
71 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
72 struct table_entry |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
73 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
74 int numeric; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
75 /* The first one is a valid name as a face attribute. |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
76 The second one (if any) is a typical name in XLFD field. */ |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
77 char *names[5]; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
78 Lisp_Object *symbols; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
79 }; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
80 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
81 /* Table of weight numeric values and their names. This table must be |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
82 sorted by numeric values in ascending order. */ |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
83 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
84 static struct table_entry weight_table[] = |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
85 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
86 { 0, { "thin" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
87 { 20, { "ultra-light", "ultralight" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
88 { 40, { "extra-light", "extralight" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
89 { 50, { "light" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
90 { 75, { "semi-light", "semilight", "demilight", "book" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
91 { 100, { "normal", "medium", "regular" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
92 { 180, { "semi-bold", "semibold", "demibold", "demi" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
93 { 200, { "bold" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
94 { 205, { "extra-bold", "extrabold" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
95 { 210, { "ultra-bold", "ultrabold", "black" }} |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
96 }; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
97 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
98 /* Table of slant numeric values and their names. This table must be |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
99 sorted by numeric values in ascending order. */ |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
100 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
101 static struct table_entry slant_table[] = |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
102 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
103 { 0, { "reverse-oblique", "ro" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
104 { 10, { "reverse-italic", "ri" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
105 { 100, { "normal", "r" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
106 { 200, { "italic" ,"i", "ot" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
107 { 210, { "oblique", "o" }} |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
108 }; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
109 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
110 /* Table of width numeric values and their names. This table must be |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
111 sorted by numeric values in ascending order. */ |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
112 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
113 static struct table_entry width_table[] = |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
114 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
115 { 50, { "ultra-condensed", "ultracondensed" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
116 { 63, { "extra-condensed", "extracondensed" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
117 { 75, { "condensed", "compressed", "narrow" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
118 { 87, { "semi-condensed", "semicondensed", "demicondensed" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
119 { 100, { "normal", "medium", "regular" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
120 { 113, { "semi-expanded", "semiexpanded", "demiexpanded" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
121 { 125, { "expanded" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
122 { 150, { "extra-expanded", "extraexpanded" }}, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
123 { 200, { "ultra-expanded", "ultraexpanded", "wide" }} |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
124 }; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
125 |
| 94926 | 126 extern Lisp_Object Qnormal; |
| 90400 | 127 |
| 128 /* Symbols representing keys of normal font properties. */ | |
| 129 extern Lisp_Object QCtype, QCfamily, QCweight, QCslant, QCwidth, QCsize, QCname; | |
| 94926 | 130 Lisp_Object QCfoundry, QCadstyle, QCregistry; |
| 90400 | 131 /* Symbols representing keys of font extra info. */ |
| 94926 | 132 Lisp_Object QCspacing, QCdpi, QCscalable, QCotf, QClang, QCscript, QCavgwidth; |
| 133 Lisp_Object QCantialias, QCfont_entity, QCfc_unknown_spec; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
134 /* Symbols representing values of font spacing property. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
135 Lisp_Object Qc, Qm, Qp, Qd; |
| 90400 | 136 |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
137 Lisp_Object Vfont_encoding_alist; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
138 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
139 /* Alist of font registry symbol and the corresponding charsets |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
140 information. The information is retrieved from |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
141 Vfont_encoding_alist on demand. |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
142 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
143 Eash element has the form: |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
144 (REGISTRY . (ENCODING-CHARSET-ID . REPERTORY-CHARSET-ID)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
145 or |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
146 (REGISTRY . nil) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
147 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
148 In the former form, ENCODING-CHARSET-ID is an ID of a charset that |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
149 encodes a character code to a glyph code of a font, and |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
150 REPERTORY-CHARSET-ID is an ID of a charset that tells if a |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
151 character is supported by a font. |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
152 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
153 The latter form means that the information for REGISTRY couldn't be |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
154 retrieved. */ |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
155 static Lisp_Object font_charset_alist; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
156 |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
157 /* List of all font drivers. Each font-backend (XXXfont.c) calls |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
158 register_font_driver in syms_of_XXXfont to register its font-driver |
| 90400 | 159 here. */ |
| 160 static struct font_driver_list *font_driver_list; | |
| 161 | |
| 94926 | 162 |
| 163 | |
| 164 /* Creaters of font-related Lisp object. */ | |
| 165 | |
| 166 Lisp_Object | |
| 167 font_make_spec () | |
| 168 { | |
| 169 Lisp_Object font_spec; | |
| 170 struct font_spec *spec | |
| 171 = ((struct font_spec *) | |
| 172 allocate_pseudovector (VECSIZE (struct font_spec), | |
| 173 FONT_SPEC_MAX, PVEC_FONT)); | |
| 174 XSETFONT (font_spec, spec); | |
| 175 return font_spec; | |
| 176 } | |
| 177 | |
| 178 Lisp_Object | |
| 179 font_make_entity () | |
| 180 { | |
| 181 Lisp_Object font_entity; | |
| 182 struct font_entity *entity | |
| 183 = ((struct font_entity *) | |
| 184 allocate_pseudovector (VECSIZE (struct font_entity), | |
| 185 FONT_ENTITY_MAX, PVEC_FONT)); | |
| 186 XSETFONT (font_entity, entity); | |
| 187 return font_entity; | |
| 188 } | |
| 189 | |
| 190 Lisp_Object | |
| 191 font_make_object (size) | |
| 192 int size; | |
| 193 { | |
| 194 Lisp_Object font_object; | |
| 195 struct font *font | |
| 196 = (struct font *) allocate_pseudovector (size, FONT_OBJECT_MAX, PVEC_FONT); | |
| 197 XSETFONT (font_object, font); | |
| 198 | |
| 199 return font_object; | |
| 200 } | |
| 201 | |
| 202 | |
| 203 | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
204 static int font_pixel_size P_ ((FRAME_PTR f, Lisp_Object)); |
| 94926 | 205 static Lisp_Object font_open_entity P_ ((FRAME_PTR, Lisp_Object, int)); |
| 206 static Lisp_Object font_matching_entity P_ ((FRAME_PTR, Lisp_Object *, | |
| 90400 | 207 Lisp_Object)); |
| 208 | |
| 209 /* Number of registered font drivers. */ | |
| 210 static int num_font_drivers; | |
| 211 | |
| 94926 | 212 |
| 213 /* Return a Lispy value of a font property value at STR and LEN bytes. | |
| 214 If STR is "*", it returns nil. | |
| 215 If all characters in STR are digits, it returns an integer. | |
| 216 Otherwise, it returns a symbol interned from STR. */ | |
| 217 | |
| 218 Lisp_Object | |
| 219 font_intern_prop (str, len) | |
| 220 char *str; | |
| 221 int len; | |
| 222 { | |
| 223 int i; | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
224 Lisp_Object tem; |
| 94926 | 225 Lisp_Object obarray; |
| 226 | |
| 227 if (len == 1 && *str == '*') | |
| 228 return Qnil; | |
| 229 if (len >=1 && isdigit (*str)) | |
| 230 { | |
| 231 for (i = 1; i < len; i++) | |
| 232 if (! isdigit (str[i])) | |
| 233 break; | |
| 234 if (i == len) | |
| 235 return make_number (atoi (str)); | |
| 236 } | |
| 237 | |
| 238 /* The following code is copied from the function intern (in lread.c). */ | |
| 239 obarray = Vobarray; | |
| 240 if (!VECTORP (obarray) || XVECTOR (obarray)->size == 0) | |
| 241 obarray = check_obarray (obarray); | |
| 242 tem = oblookup (obarray, str, len, len); | |
| 243 if (SYMBOLP (tem)) | |
| 244 return tem; | |
| 245 return Fintern (make_unibyte_string (str, len), obarray); | |
| 246 } | |
| 247 | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
248 /* Return a pixel size of font-spec SPEC on frame F. */ |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
249 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
250 static int |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
251 font_pixel_size (f, spec) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
252 FRAME_PTR f; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
253 Lisp_Object spec; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
254 { |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
255 #ifdef HAVE_WINDOW_SYSTEM |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
256 Lisp_Object size = AREF (spec, FONT_SIZE_INDEX); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
257 double point_size; |
| 94926 | 258 int dpi, pixel_size; |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
259 Lisp_Object val; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
260 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
261 if (INTEGERP (size)) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
262 return XINT (size); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
263 if (NILP (size)) |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
264 return 0; |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
265 font_assert (FLOATP (size)); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
266 point_size = XFLOAT_DATA (size); |
| 94926 | 267 val = AREF (spec, FONT_DPI_INDEX); |
| 268 if (INTEGERP (val)) | |
| 269 dpi = XINT (XCDR (val)); | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
270 else |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
271 dpi = f->resy; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
272 pixel_size = POINT_TO_PIXEL (point_size, dpi); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
273 return pixel_size; |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
274 #else |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
275 return 1; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
276 #endif |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
277 } |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
278 |
| 94926 | 279 |
| 280 /* Return a value of PROP's VAL (symbol or integer) to be stored in a | |
| 281 font vector. If VAL is not valid (i.e. not registered in | |
| 282 font_style_table), return -1 if NOERROR is zero, and return a | |
| 283 proper index if NOERROR is nonzero. In that case, register VAL in | |
| 284 font_style_table if VAL is a symbol, and return a closest index if | |
| 285 VAL is an integer. */ | |
| 286 | |
| 287 int | |
| 288 font_style_to_value (prop, val, noerror) | |
| 90400 | 289 enum font_property_index prop; |
| 94926 | 290 Lisp_Object val; |
| 291 int noerror; | |
| 90400 | 292 { |
| 94926 | 293 Lisp_Object table = AREF (font_style_table, prop - FONT_WEIGHT_INDEX); |
| 294 int len = ASIZE (table); | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
295 int i, j; |
| 94926 | 296 |
| 297 if (SYMBOLP (val)) | |
| 90400 | 298 { |
| 94926 | 299 char *s; |
| 300 Lisp_Object args[2], elt; | |
| 301 | |
| 302 /* At first try exact match. */ | |
| 303 for (i = 0; i < len; i++) | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
304 for (j = 1; j < ASIZE (AREF (table, i)); j++) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
305 if (EQ (val, AREF (AREF (table, i), j))) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
306 return ((XINT (AREF (AREF (table, i), 0)) << 8) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
307 | (i << 4) | (j - 1)); |
| 94926 | 308 /* Try also with case-folding match. */ |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
309 s = (char *) SDATA (SYMBOL_NAME (val)); |
| 94926 | 310 for (i = 0; i < len; i++) |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
311 for (j = 1; j < ASIZE (AREF (table, i)); j++) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
312 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
313 elt = AREF (AREF (table, i), j); |
|
95211
e5b02763f924
* dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents:
95204
diff
changeset
|
314 if (xstrcasecmp (s, (char *) SDATA (SYMBOL_NAME (elt))) == 0) |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
315 return ((XINT (AREF (AREF (table, i), 0)) << 8) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
316 | (i << 4) | (j - 1)); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
317 } |
| 94926 | 318 if (! noerror) |
| 319 return -1; | |
| 320 if (len == 255) | |
| 321 abort (); | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
322 elt = Fmake_vector (make_number (2), make_number (255)); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
323 ASET (elt, 1, val); |
| 94926 | 324 args[0] = table; |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
325 args[1] = Fmake_vector (make_number (1), elt); |
| 94926 | 326 ASET (font_style_table, prop - FONT_WEIGHT_INDEX, Fvconcat (2, args)); |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
327 return (255 << 8) | (i << 4); |
| 90400 | 328 } |
| 94926 | 329 else |
| 330 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
331 int i, last_n; |
| 94926 | 332 int numeric = XINT (val); |
| 333 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
334 for (i = 0, last_n = -1; i < len; i++) |
| 94926 | 335 { |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
336 int n = XINT (AREF (AREF (table, i), 0)); |
| 94926 | 337 |
| 338 if (numeric == n) | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
339 return (n << 8) | (i << 4); |
| 94926 | 340 if (numeric < n) |
| 341 { | |
| 342 if (! noerror) | |
| 343 return -1; | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
344 return ((i == 0 || n - numeric < numeric - last_n) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
345 ? (n << 8) | (i << 4): (last_n << 8 | ((i - 1) << 4))); |
| 94926 | 346 } |
| 347 last_n = n; | |
| 348 } | |
| 349 if (! noerror) | |
| 350 return -1; | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
351 return ((last_n << 8) | ((i - 1) << 4)); |
| 94926 | 352 } |
| 90400 | 353 } |
| 354 | |
| 355 Lisp_Object | |
| 94926 | 356 font_style_symbolic (font, prop, for_face) |
| 357 Lisp_Object font; | |
| 358 enum font_property_index prop; | |
| 359 int for_face; | |
| 90400 | 360 { |
| 94926 | 361 Lisp_Object val = AREF (font, prop); |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
362 Lisp_Object table, elt; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
363 int i; |
| 94926 | 364 |
| 365 if (NILP (val)) | |
| 366 return Qnil; | |
| 367 table = AREF (font_style_table, prop - FONT_WEIGHT_INDEX); | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
368 i = XINT (val) & 0xFF; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
369 font_assert (((i >> 4) & 0xF) < ASIZE (table)); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
370 elt = AREF (table, ((i >> 4) & 0xF)); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
371 font_assert ((i & 0xF) + 1 < ASIZE (elt)); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
372 return (for_face ? AREF (elt, 1) : AREF (elt, (i & 0xF) + 1)); |
| 90400 | 373 } |
| 374 | |
| 375 extern Lisp_Object Vface_alternative_font_family_alist; | |
| 376 | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
377 extern Lisp_Object find_font_encoding P_ ((Lisp_Object)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
378 |
| 94926 | 379 |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
380 /* Return ENCODING or a cons of ENCODING and REPERTORY of the font |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
381 FONTNAME. ENCODING is a charset symbol that specifies the encoding |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
382 of the font. REPERTORY is a charset symbol or nil. */ |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
383 |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
384 Lisp_Object |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
385 find_font_encoding (fontname) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
386 Lisp_Object fontname; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
387 { |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
388 Lisp_Object tail, elt; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
389 |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
390 for (tail = Vfont_encoding_alist; CONSP (tail); tail = XCDR (tail)) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
391 { |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
392 elt = XCAR (tail); |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
393 if (CONSP (elt) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
394 && STRINGP (XCAR (elt)) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
395 && fast_string_match_ignore_case (XCAR (elt), fontname) >= 0 |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
396 && (SYMBOLP (XCDR (elt)) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
397 ? CHARSETP (XCDR (elt)) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
398 : CONSP (XCDR (elt)) && CHARSETP (XCAR (XCDR (elt))))) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
399 return (XCDR (elt)); |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
400 } |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
401 /* We don't know the encoding of this font. Let's assume `ascii'. */ |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
402 return Qascii; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
403 } |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
404 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
405 /* Return encoding charset and repertory charset for REGISTRY in |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
406 ENCODING and REPERTORY correspondingly. If correct information for |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
407 REGISTRY is available, return 0. Otherwise return -1. */ |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
408 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
409 int |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
410 font_registry_charsets (registry, encoding, repertory) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
411 Lisp_Object registry; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
412 struct charset **encoding, **repertory; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
413 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
414 Lisp_Object val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
415 int encoding_id, repertory_id; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
416 |
| 94926 | 417 val = Fassoc_string (registry, font_charset_alist, Qt); |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
418 if (! NILP (val)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
419 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
420 val = XCDR (val); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
421 if (NILP (val)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
422 return -1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
423 encoding_id = XINT (XCAR (val)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
424 repertory_id = XINT (XCDR (val)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
425 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
426 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
427 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
428 val = find_font_encoding (SYMBOL_NAME (registry)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
429 if (SYMBOLP (val) && CHARSETP (val)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
430 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
431 encoding_id = repertory_id = XINT (CHARSET_SYMBOL_ID (val)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
432 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
433 else if (CONSP (val)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
434 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
435 if (! CHARSETP (XCAR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
436 goto invalid_entry; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
437 encoding_id = XINT (CHARSET_SYMBOL_ID (XCAR (val))); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
438 if (NILP (XCDR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
439 repertory_id = -1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
440 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
441 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
442 if (! CHARSETP (XCDR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
443 goto invalid_entry; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
444 repertory_id = XINT (CHARSET_SYMBOL_ID (XCDR (val))); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
445 } |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
446 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
447 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
448 goto invalid_entry; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
449 val = Fcons (make_number (encoding_id), make_number (repertory_id)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
450 font_charset_alist |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
451 = nconc2 (font_charset_alist, Fcons (Fcons (registry, val), Qnil)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
452 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
453 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
454 if (encoding) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
455 *encoding = CHARSET_FROM_ID (encoding_id); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
456 if (repertory) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
457 *repertory = repertory_id >= 0 ? CHARSET_FROM_ID (repertory_id) : NULL; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
458 return 0; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
459 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
460 invalid_entry: |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
461 font_charset_alist |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
462 = nconc2 (font_charset_alist, Fcons (Fcons (registry, Qnil), Qnil)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
463 return -1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
464 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
465 |
| 90400 | 466 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
467 /* Font property value validaters. See the comment of |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
468 font_property_table for the meaning of the arguments. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
469 |
| 94926 | 470 static Lisp_Object font_prop_validate P_ ((int, Lisp_Object, Lisp_Object)); |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
471 static Lisp_Object font_prop_validate_symbol P_ ((Lisp_Object, Lisp_Object)); |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
472 static Lisp_Object font_prop_validate_style P_ ((Lisp_Object, Lisp_Object)); |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
473 static Lisp_Object font_prop_validate_non_neg P_ ((Lisp_Object, Lisp_Object)); |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
474 static Lisp_Object font_prop_validate_spacing P_ ((Lisp_Object, Lisp_Object)); |
| 94926 | 475 static int get_font_prop_index P_ ((Lisp_Object)); |
| 90400 | 476 |
| 477 static Lisp_Object | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
478 font_prop_validate_symbol (prop, val) |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
479 Lisp_Object prop, val; |
| 90400 | 480 { |
| 481 if (STRINGP (val)) | |
| 94926 | 482 val = Fintern (val, Qnil); |
| 483 if (! SYMBOLP (val)) | |
| 484 val = Qerror; | |
| 485 else if (EQ (prop, QCregistry)) | |
| 486 val = Fintern (Fdowncase (SYMBOL_NAME (val)), Qnil); | |
| 487 return val; | |
| 488 } | |
| 489 | |
| 490 | |
| 491 static Lisp_Object | |
| 492 font_prop_validate_style (style, val) | |
| 493 Lisp_Object style, val; | |
| 494 { | |
| 495 enum font_property_index prop = (EQ (style, QCweight) ? FONT_WEIGHT_INDEX | |
| 496 : EQ (style, QCslant) ? FONT_SLANT_INDEX | |
| 497 : FONT_WIDTH_INDEX); | |
| 498 int n; | |
| 499 if (INTEGERP (val)) | |
| 500 { | |
| 501 n = XINT (val); | |
|
95194
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
502 if (((n >> 4) & 0xF) |
| 94926 | 503 >= ASIZE (AREF (font_style_table, prop - FONT_WEIGHT_INDEX))) |
| 504 val = Qerror; | |
| 505 else | |
| 506 { | |
|
95194
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
507 Lisp_Object elt = AREF (AREF (font_style_table, prop - FONT_WEIGHT_INDEX), (n >> 4) & 0xF); |
|
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
508 |
|
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
509 if ((n & 0xF) + 1 >= ASIZE (elt)) |
|
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
510 val = Qerror; |
|
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
511 else if (XINT (AREF (elt, 0)) != (n >> 8)) |
| 94926 | 512 val = Qerror; |
| 513 } | |
| 514 } | |
| 90400 | 515 else if (SYMBOLP (val)) |
| 516 { | |
| 94926 | 517 int n = font_style_to_value (prop, val, 0); |
| 518 | |
| 519 val = n >= 0 ? make_number (n) : Qerror; | |
| 90400 | 520 } |
| 521 else | |
| 522 val = Qerror; | |
| 523 return val; | |
| 524 } | |
| 525 | |
| 526 static Lisp_Object | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
527 font_prop_validate_non_neg (prop, val) |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
528 Lisp_Object prop, val; |
| 90400 | 529 { |
| 530 return (NATNUMP (val) || (FLOATP (val) && XFLOAT_DATA (val) >= 0) | |
| 531 ? val : Qerror); | |
| 532 } | |
| 533 | |
| 534 static Lisp_Object | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
535 font_prop_validate_spacing (prop, val) |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
536 Lisp_Object prop, val; |
| 90400 | 537 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
538 if (NILP (val) || (NATNUMP (val) && XINT (val) <= FONT_SPACING_CHARCELL)) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
539 return val; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
540 if (EQ (val, Qc)) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
541 return make_number (FONT_SPACING_CHARCELL); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
542 if (EQ (val, Qm)) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
543 return make_number (FONT_SPACING_MONO); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
544 if (EQ (val, Qp)) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
545 return make_number (FONT_SPACING_PROPORTIONAL); |
| 94926 | 546 if (EQ (val, Qd)) |
| 547 return make_number (FONT_SPACING_DUAL); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
548 return Qerror; |
| 90400 | 549 } |
| 550 | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
551 static Lisp_Object |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
552 font_prop_validate_otf (prop, val) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
553 Lisp_Object prop, val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
554 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
555 Lisp_Object tail, tmp; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
556 int i; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
557 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
558 /* VAL = (SCRIPT [ LANGSYS [ GSUB-FEATURES [ GPOS-FEATURES ]]]) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
559 GSUB-FEATURES = (FEATURE ... [ nil FEATURE ... ]) | nil |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
560 GPOS-FEATURES = (FEATURE ... [ nil FEATURE ... ]) | nil */ |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
561 if (! CONSP (val)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
562 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
563 if (! SYMBOLP (XCAR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
564 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
565 tail = XCDR (val); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
566 if (NILP (tail)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
567 return val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
568 if (! CONSP (tail) || ! SYMBOLP (XCAR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
569 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
570 for (i = 0; i < 2; i++) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
571 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
572 tail = XCDR (tail); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
573 if (NILP (tail)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
574 return val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
575 if (! CONSP (tail)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
576 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
577 for (tmp = XCAR (tail); CONSP (tmp); tmp = XCDR (tmp)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
578 if (! SYMBOLP (XCAR (tmp))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
579 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
580 if (! NILP (tmp)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
581 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
582 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
583 return val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
584 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
585 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
586 /* Structure of known font property keys and validater of the |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
587 values. */ |
| 90400 | 588 struct |
| 589 { | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
590 /* Pointer to the key symbol. */ |
| 90400 | 591 Lisp_Object *key; |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
592 /* Function to validate PROP's value VAL, or NULL if any value is |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
593 ok. The value is VAL or its regularized value if VAL is valid, |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
594 and Qerror if not. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
595 Lisp_Object (*validater) P_ ((Lisp_Object prop, Lisp_Object val)); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
596 } font_property_table[] = |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
597 { { &QCtype, font_prop_validate_symbol }, |
| 90400 | 598 { &QCfoundry, font_prop_validate_symbol }, |
| 599 { &QCfamily, font_prop_validate_symbol }, | |
| 600 { &QCadstyle, font_prop_validate_symbol }, | |
| 601 { &QCregistry, font_prop_validate_symbol }, | |
| 602 { &QCweight, font_prop_validate_style }, | |
| 603 { &QCslant, font_prop_validate_style }, | |
| 604 { &QCwidth, font_prop_validate_style }, | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
605 { &QCsize, font_prop_validate_non_neg }, |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
606 { &QCdpi, font_prop_validate_non_neg }, |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
607 { &QCspacing, font_prop_validate_spacing }, |
| 94926 | 608 { &QCavgwidth, font_prop_validate_non_neg }, |
| 609 /* The order of the above entries must match with enum | |
| 610 font_property_index. */ | |
| 611 { &QClang, font_prop_validate_symbol }, | |
| 612 { &QCscript, font_prop_validate_symbol }, | |
| 613 { &QCotf, font_prop_validate_otf } | |
| 90400 | 614 }; |
| 615 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
616 /* Size (number of elements) of the above table. */ |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
617 #define FONT_PROPERTY_TABLE_SIZE \ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
618 ((sizeof font_property_table) / (sizeof *font_property_table)) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
619 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
620 /* Return an index number of font property KEY or -1 if KEY is not an |
| 94926 | 621 already known property. */ |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
622 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
623 static int |
| 94926 | 624 get_font_prop_index (key) |
| 90400 | 625 Lisp_Object key; |
| 626 { | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
627 int i; |
| 94926 | 628 |
| 629 for (i = 0; i < FONT_PROPERTY_TABLE_SIZE; i++) | |
| 630 if (EQ (key, *font_property_table[i].key)) | |
| 631 return i; | |
| 632 return -1; | |
| 633 } | |
| 634 | |
| 635 /* Validate the font property. The property key is specified by the | |
| 636 symbol PROP, or the index IDX (if PROP is nil). If VAL is invalid, | |
| 637 signal an error. The value is VAL or the regularized one. */ | |
| 638 | |
| 639 static Lisp_Object | |
| 640 font_prop_validate (idx, prop, val) | |
| 641 int idx; | |
| 642 Lisp_Object prop, val; | |
| 643 { | |
| 644 Lisp_Object validated; | |
| 645 | |
|
94964
5ffc88767cc1
(font_prop_validate): Make nil a valid value.
Kenichi Handa <handa@m17n.org>
parents:
94963
diff
changeset
|
646 if (NILP (val)) |
|
5ffc88767cc1
(font_prop_validate): Make nil a valid value.
Kenichi Handa <handa@m17n.org>
parents:
94963
diff
changeset
|
647 return val; |
| 94926 | 648 if (NILP (prop)) |
| 649 prop = *font_property_table[idx].key; | |
| 650 else | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
651 { |
| 94926 | 652 idx = get_font_prop_index (prop); |
| 653 if (idx < 0) | |
| 654 return val; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
655 } |
| 94926 | 656 validated = (font_property_table[idx].validater) (prop, val); |
| 657 if (EQ (validated, Qerror)) | |
| 658 signal_error ("invalid font property", Fcons (prop, val)); | |
| 659 return validated; | |
| 90400 | 660 } |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
661 |
| 94926 | 662 |
| 663 /* Store VAL as a value of extra font property PROP in FONT while | |
| 664 keeping the sorting order. Don't check the validity of VAL. */ | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
665 |
|
90888
5f03b3602143
(font_put_extra): Expose externally.
Jason Rumney <jasonr@gnu.org>
parents:
90883
diff
changeset
|
666 Lisp_Object |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
667 font_put_extra (font, prop, val) |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
668 Lisp_Object font, prop, val; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
669 { |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
670 Lisp_Object extra = AREF (font, FONT_EXTRA_INDEX); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
671 Lisp_Object slot = (NILP (extra) ? Qnil : assq_no_quit (prop, extra)); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
672 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
673 if (NILP (slot)) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
674 { |
| 94926 | 675 Lisp_Object prev = Qnil; |
| 676 | |
| 677 while (CONSP (extra) | |
| 678 && NILP (Fstring_lessp (prop, XCAR (XCAR (extra))))) | |
| 679 prev = extra, extra = XCDR (extra); | |
| 680 if (NILP (prev)) | |
| 681 ASET (font, FONT_EXTRA_INDEX, Fcons (Fcons (prop, val), extra)); | |
| 682 else | |
| 683 XSETCDR (prev, Fcons (Fcons (prop, val), extra)); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
684 return val; |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
685 } |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
686 XSETCDR (slot, val); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
687 return val; |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
688 } |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
689 |
| 90400 | 690 |
| 691 /* Font name parser and unparser */ | |
| 692 | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
693 static int parse_matrix P_ ((char *)); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
694 static int font_expand_wildcards P_ ((Lisp_Object *, int)); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
695 static int font_parse_name P_ ((char *, Lisp_Object)); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
696 |
| 90400 | 697 /* An enumerator for each field of an XLFD font name. */ |
| 698 enum xlfd_field_index | |
| 699 { | |
| 700 XLFD_FOUNDRY_INDEX, | |
| 701 XLFD_FAMILY_INDEX, | |
| 702 XLFD_WEIGHT_INDEX, | |
| 703 XLFD_SLANT_INDEX, | |
| 704 XLFD_SWIDTH_INDEX, | |
| 705 XLFD_ADSTYLE_INDEX, | |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
706 XLFD_PIXEL_INDEX, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
707 XLFD_POINT_INDEX, |
| 90400 | 708 XLFD_RESX_INDEX, |
| 709 XLFD_RESY_INDEX, | |
| 710 XLFD_SPACING_INDEX, | |
| 711 XLFD_AVGWIDTH_INDEX, | |
| 712 XLFD_REGISTRY_INDEX, | |
| 713 XLFD_ENCODING_INDEX, | |
| 714 XLFD_LAST_INDEX | |
| 715 }; | |
| 716 | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
717 /* An enumerator for mask bit corresponding to each XLFD field. */ |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
718 enum xlfd_field_mask |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
719 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
720 XLFD_FOUNDRY_MASK = 0x0001, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
721 XLFD_FAMILY_MASK = 0x0002, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
722 XLFD_WEIGHT_MASK = 0x0004, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
723 XLFD_SLANT_MASK = 0x0008, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
724 XLFD_SWIDTH_MASK = 0x0010, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
725 XLFD_ADSTYLE_MASK = 0x0020, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
726 XLFD_PIXEL_MASK = 0x0040, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
727 XLFD_POINT_MASK = 0x0080, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
728 XLFD_RESX_MASK = 0x0100, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
729 XLFD_RESY_MASK = 0x0200, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
730 XLFD_SPACING_MASK = 0x0400, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
731 XLFD_AVGWIDTH_MASK = 0x0800, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
732 XLFD_REGISTRY_MASK = 0x1000, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
733 XLFD_ENCODING_MASK = 0x2000 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
734 }; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
735 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
736 |
| 90400 | 737 /* Parse P pointing the pixel/point size field of the form |
| 738 `[A B C D]' which specifies a transformation matrix: | |
| 739 | |
| 740 A B 0 | |
| 741 C D 0 | |
| 742 0 0 1 | |
| 743 | |
| 744 by which all glyphs of the font are transformed. The spec says | |
| 745 that scalar value N for the pixel/point size is equivalent to: | |
| 746 A = N * resx/resy, B = C = 0, D = N. | |
| 747 | |
| 748 Return the scalar value N if the form is valid. Otherwise return | |
| 749 -1. */ | |
| 750 | |
| 751 static int | |
| 752 parse_matrix (p) | |
| 753 char *p; | |
| 754 { | |
| 755 double matrix[4]; | |
| 756 char *end; | |
| 757 int i; | |
| 758 | |
| 759 for (i = 0, p++; i < 4 && *p && *p != ']'; i++) | |
| 760 { | |
| 761 if (*p == '~') | |
| 762 matrix[i] = - strtod (p + 1, &end); | |
| 763 else | |
| 764 matrix[i] = strtod (p, &end); | |
| 765 p = end; | |
| 766 } | |
| 767 return (i == 4 ? (int) matrix[3] : -1); | |
| 768 } | |
| 769 | |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
770 /* Expand a wildcard field in FIELD (the first N fields are filled) to |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
771 multiple fields to fill in all 14 XLFD fields while restring a |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
772 field position by its contents. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
773 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
774 static int |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
775 font_expand_wildcards (field, n) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
776 Lisp_Object field[XLFD_LAST_INDEX]; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
777 int n; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
778 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
779 /* Copy of FIELD. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
780 Lisp_Object tmp[XLFD_LAST_INDEX]; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
781 /* Array of information about where this element can go. Nth |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
782 element is for Nth element of FIELD. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
783 struct { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
784 /* Minimum possible field. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
785 int from; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
786 /* Maxinum possible field. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
787 int to; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
788 /* Bit mask of possible field. Nth bit corresponds to Nth field. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
789 int mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
790 } range[XLFD_LAST_INDEX]; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
791 int i, j; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
792 int range_from, range_to; |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
793 unsigned range_mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
794 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
795 #define XLFD_SYMBOL_MASK (XLFD_FOUNDRY_MASK | XLFD_FAMILY_MASK \ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
796 | XLFD_ADSTYLE_MASK | XLFD_REGISTRY_MASK) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
797 #define XLFD_NULL_MASK (XLFD_FOUNDRY_MASK | XLFD_ADSTYLE_MASK) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
798 #define XLFD_LARGENUM_MASK (XLFD_POINT_MASK | XLFD_RESX_MASK | XLFD_RESY_MASK \ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
799 | XLFD_AVGWIDTH_MASK) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
800 #define XLFD_REGENC_MASK (XLFD_REGISTRY_MASK | XLFD_ENCODING_MASK) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
801 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
802 /* Initialize RANGE_MASK for FIELD[0] which can be 0th to (14 - N)th |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
803 field. The value is shifted to left one bit by one in the |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
804 following loop. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
805 for (i = 0, range_mask = 0; i <= 14 - n; i++) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
806 range_mask = (range_mask << 1) | 1; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
807 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
808 /* The triplet RANGE_FROM, RANGE_TO, and RANGE_MASK is a |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
809 position-based retriction for FIELD[I]. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
810 for (i = 0, range_from = 0, range_to = 14 - n; i < n; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
811 i++, range_from++, range_to++, range_mask <<= 1) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
812 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
813 Lisp_Object val = field[i]; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
814 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
815 tmp[i] = val; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
816 if (NILP (val)) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
817 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
818 /* Wildcard. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
819 range[i].from = range_from; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
820 range[i].to = range_to; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
821 range[i].mask = range_mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
822 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
823 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
824 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
825 /* The triplet FROM, TO, and MASK is a value-based |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
826 retriction for FIELD[I]. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
827 int from, to; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
828 unsigned mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
829 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
830 if (INTEGERP (val)) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
831 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
832 int numeric = XINT (val); |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
833 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
834 if (i + 1 == n) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
835 from = to = XLFD_ENCODING_INDEX, |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
836 mask = XLFD_ENCODING_MASK; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
837 else if (numeric == 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
838 from = XLFD_PIXEL_INDEX, to = XLFD_AVGWIDTH_INDEX, |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
839 mask = XLFD_PIXEL_MASK | XLFD_LARGENUM_MASK; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
840 else if (numeric <= 48) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
841 from = to = XLFD_PIXEL_INDEX, |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
842 mask = XLFD_PIXEL_MASK; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
843 else |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
844 from = XLFD_POINT_INDEX, to = XLFD_AVGWIDTH_INDEX, |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
845 mask = XLFD_LARGENUM_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
846 } |
| 94926 | 847 else if (SBYTES (SYMBOL_NAME (val)) == 0) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
848 from = XLFD_FOUNDRY_INDEX, to = XLFD_ADSTYLE_INDEX, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
849 mask = XLFD_NULL_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
850 else if (i == 0) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
851 from = to = XLFD_FOUNDRY_INDEX, mask = XLFD_FOUNDRY_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
852 else if (i + 1 == n) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
853 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
854 Lisp_Object name = SYMBOL_NAME (val); |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
855 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
856 if (SDATA (name)[SBYTES (name) - 1] == '*') |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
857 from = XLFD_REGISTRY_INDEX, to = XLFD_ENCODING_INDEX, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
858 mask = XLFD_REGENC_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
859 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
860 from = to = XLFD_ENCODING_INDEX, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
861 mask = XLFD_ENCODING_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
862 } |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
863 else if (range_from <= XLFD_WEIGHT_INDEX |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
864 && range_to >= XLFD_WEIGHT_INDEX |
| 94926 | 865 && FONT_WEIGHT_NAME_NUMERIC (val) >= 0) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
866 from = to = XLFD_WEIGHT_INDEX, mask = XLFD_WEIGHT_MASK; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
867 else if (range_from <= XLFD_SLANT_INDEX |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
868 && range_to >= XLFD_SLANT_INDEX |
| 94926 | 869 && FONT_SLANT_NAME_NUMERIC (val) >= 0) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
870 from = to = XLFD_SLANT_INDEX, mask = XLFD_SLANT_MASK; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
871 else if (range_from <= XLFD_SWIDTH_INDEX |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
872 && range_to >= XLFD_SWIDTH_INDEX |
| 94926 | 873 && FONT_WIDTH_NAME_NUMERIC (val) >= 0) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
874 from = to = XLFD_SWIDTH_INDEX, mask = XLFD_SWIDTH_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
875 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
876 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
877 if (EQ (val, Qc) || EQ (val, Qm) || EQ (val, Qp) || EQ (val, Qd)) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
878 from = to = XLFD_SPACING_INDEX, mask = XLFD_SPACING_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
879 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
880 from = XLFD_FOUNDRY_INDEX, to = XLFD_ENCODING_INDEX, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
881 mask = XLFD_SYMBOL_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
882 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
883 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
884 /* Merge position-based and value-based restrictions. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
885 mask &= range_mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
886 while (from < range_from) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
887 mask &= ~(1 << from++); |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
888 while (from < 14 && ! (mask & (1 << from))) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
889 from++; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
890 while (to > range_to) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
891 mask &= ~(1 << to--); |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
892 while (to >= 0 && ! (mask & (1 << to))) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
893 to--; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
894 if (from > to) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
895 return -1; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
896 range[i].from = from; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
897 range[i].to = to; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
898 range[i].mask = mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
899 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
900 if (from > range_from || to < range_to) |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
901 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
902 /* The range is narrowed by value-based restrictions. |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
903 Reflect it to the other fields. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
904 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
905 /* Following fields should be after FROM. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
906 range_from = from; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
907 /* Preceding fields should be before TO. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
908 for (j = i - 1, from--, to--; j >= 0; j--, from--, to--) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
909 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
910 /* Check FROM for non-wildcard field. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
911 if (! NILP (tmp[j]) && range[j].from < from) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
912 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
913 while (range[j].from < from) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
914 range[j].mask &= ~(1 << range[j].from++); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
915 while (from < 14 && ! (range[j].mask & (1 << from))) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
916 from++; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
917 range[j].from = from; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
918 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
919 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
920 from = range[j].from; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
921 if (range[j].to > to) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
922 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
923 while (range[j].to > to) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
924 range[j].mask &= ~(1 << range[j].to--); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
925 while (to >= 0 && ! (range[j].mask & (1 << to))) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
926 to--; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
927 range[j].to = to; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
928 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
929 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
930 to = range[j].to; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
931 if (from > to) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
932 return -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
933 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
934 } |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
935 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
936 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
937 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
938 /* Decide all fileds from restrictions in RANGE. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
939 for (i = j = 0; i < n ; i++) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
940 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
941 if (j < range[i].from) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
942 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
943 if (i == 0 || ! NILP (tmp[i - 1])) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
944 /* None of TMP[X] corresponds to Jth field. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
945 return -1; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
946 for (; j < range[i].from; j++) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
947 field[j] = Qnil; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
948 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
949 field[j++] = tmp[i]; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
950 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
951 if (! NILP (tmp[n - 1]) && j < XLFD_REGISTRY_INDEX) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
952 return -1; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
953 for (; j < XLFD_LAST_INDEX; j++) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
954 field[j] = Qnil; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
955 if (INTEGERP (field[XLFD_ENCODING_INDEX])) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
956 field[XLFD_ENCODING_INDEX] |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
957 = Fintern (Fnumber_to_string (field[XLFD_ENCODING_INDEX]), Qnil); |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
958 return 0; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
959 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
960 |
|
92113
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
961 |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
962 #ifdef ENABLE_CHECKING |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
963 /* Match a 14-field XLFD pattern against a full XLFD font name. */ |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
964 static int |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
965 font_match_xlfd (char *pattern, char *name) |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
966 { |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
967 while (*pattern && *name) |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
968 { |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
969 if (*pattern == *name) |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
970 pattern++; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
971 else if (*pattern == '*') |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
972 if (*name == pattern[1]) |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
973 pattern += 2; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
974 else |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
975 ; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
976 else |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
977 return 0; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
978 name++; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
979 } |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
980 return 1; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
981 } |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
982 |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
983 /* Make sure the font object matches the XLFD font name. */ |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
984 static int |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
985 font_check_xlfd_parse (Lisp_Object font, char *name) |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
986 { |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
987 char name_check[256]; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
988 font_unparse_xlfd (font, 0, name_check, 255); |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
989 return font_match_xlfd (name_check, name); |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
990 } |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
991 |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
992 #endif |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
993 |
| 94926 | 994 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
995 /* Parse NAME (null terminated) as XLFD and store information in FONT |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
996 (font-spec or font-entity). Size property of FONT is set as |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
997 follows: |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
998 specified XLFD fields FONT property |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
999 --------------------- ------------- |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1000 PIXEL_SIZE PIXEL_SIZE (Lisp integer) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1001 POINT_SIZE and RESY calculated pixel size (Lisp integer) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1002 POINT_SIZE POINT_SIZE/10 (Lisp float) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1003 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1004 If NAME is successfully parsed, return 0. Otherwise return -1. |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1005 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1006 FONT is usually a font-spec, but when this function is called from |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1007 X font backend driver, it is a font-entity. In that case, NAME is |
| 94926 | 1008 a fully specified XLFD. */ |
| 90400 | 1009 |
| 1010 int | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1011 font_parse_xlfd (name, font) |
| 90400 | 1012 char *name; |
| 1013 Lisp_Object font; | |
| 1014 { | |
| 1015 int len = strlen (name); | |
| 94926 | 1016 int i, j, n; |
|
90695
a1cd7344d6a2
(font_parse_xlfd): Fix the array size of `f'.
Kenichi Handa <handa@m17n.org>
parents:
90677
diff
changeset
|
1017 char *f[XLFD_LAST_INDEX + 1]; |
| 90400 | 1018 Lisp_Object val; |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1019 char *p; |
| 90400 | 1020 |
| 1021 if (len > 255) | |
| 1022 /* Maximum XLFD name length is 255. */ | |
| 1023 return -1; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1024 /* Accept "*-.." as a fully specified XLFD. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1025 if (name[0] == '*' && name[1] == '-') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1026 i = 1, f[XLFD_FOUNDRY_INDEX] = name; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1027 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1028 i = 0; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1029 for (p = name + i; *p; p++) |
| 94926 | 1030 if (*p == '-') |
| 1031 { | |
| 1032 f[i++] = p + 1; | |
| 1033 if (i == XLFD_LAST_INDEX) | |
| 1034 break; | |
| 1035 } | |
| 1036 f[i] = name + len; | |
| 1037 | |
| 1038 #define INTERN_FIELD(N) font_intern_prop (f[N], f[(N) + 1] - 1 - f[N]) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1039 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1040 if (i == XLFD_LAST_INDEX) |
| 90400 | 1041 { |
| 94926 | 1042 /* Fully specified XLFD. */ |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1043 int pixel_size; |
| 94926 | 1044 |
| 1045 ASET (font, FONT_FOUNDRY_INDEX, INTERN_FIELD (XLFD_FOUNDRY_INDEX)); | |
| 1046 ASET (font, FONT_FAMILY_INDEX, INTERN_FIELD (XLFD_FAMILY_INDEX)); | |
| 1047 for (i = XLFD_WEIGHT_INDEX, j = FONT_WEIGHT_INDEX; | |
| 1048 i <= XLFD_SWIDTH_INDEX; i++, j++) | |
| 90400 | 1049 { |
| 94926 | 1050 val = INTERN_FIELD (i); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1051 if (! NILP (val)) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1052 { |
| 94926 | 1053 if ((n = font_style_to_value (j, INTERN_FIELD (i), 0)) < 0) |
| 1054 return -1; | |
| 1055 ASET (font, j, make_number (n)); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1056 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1057 } |
| 94926 | 1058 ASET (font, FONT_ADSTYLE_INDEX, INTERN_FIELD (XLFD_ADSTYLE_INDEX)); |
| 1059 if (strcmp (f[XLFD_REGISTRY_INDEX], "*-*") == 0) | |
| 1060 ASET (font, FONT_REGISTRY_INDEX, Qnil); | |
| 1061 else | |
| 1062 ASET (font, FONT_REGISTRY_INDEX, | |
| 1063 font_intern_prop (f[XLFD_REGISTRY_INDEX], | |
| 1064 f[XLFD_LAST_INDEX] - f[XLFD_REGISTRY_INDEX])); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1065 p = f[XLFD_PIXEL_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1066 if (*p == '[' && (pixel_size = parse_matrix (p)) >= 0) |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
1067 ASET (font, FONT_SIZE_INDEX, make_number (pixel_size)); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1068 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1069 { |
| 94926 | 1070 val = INTERN_FIELD (XLFD_PIXEL_INDEX); |
| 1071 if (INTEGERP (val)) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1072 ASET (font, FONT_SIZE_INDEX, val); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1073 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1074 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1075 double point_size = -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1076 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1077 font_assert (FONT_SPEC_P (font)); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1078 p = f[XLFD_POINT_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1079 if (*p == '[') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1080 point_size = parse_matrix (p); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1081 else if (isdigit (*p)) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1082 point_size = atoi (p), point_size /= 10; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1083 if (point_size >= 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1084 ASET (font, FONT_SIZE_INDEX, make_float (point_size)); |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1085 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1086 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1087 |
| 94926 | 1088 ASET (font, FONT_DPI_INDEX, INTERN_FIELD (XLFD_RESY_INDEX)); |
| 1089 val = INTERN_FIELD (XLFD_SPACING_INDEX); | |
| 1090 if (! NILP (val)) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1091 { |
| 94926 | 1092 val = font_prop_validate_spacing (QCspacing, val); |
| 1093 if (! INTEGERP (val)) | |
| 1094 return -1; | |
| 1095 ASET (font, FONT_SPACING_INDEX, val); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1096 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1097 p = f[XLFD_AVGWIDTH_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1098 if (*p == '~') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1099 p++; |
| 94926 | 1100 ASET (font, FONT_AVGWIDTH_INDEX, |
| 1101 font_intern_prop (p, f[XLFD_REGISTRY_INDEX] - 1 - p)); | |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1102 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1103 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1104 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1105 int wild_card_found = 0; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1106 Lisp_Object prop[XLFD_LAST_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1107 |
| 94926 | 1108 if (FONT_ENTITY_P (font)) |
| 1109 return -1; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1110 for (j = 0; j < i; j++) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1111 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1112 if (*f[j] == '*') |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1113 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1114 if (f[j][1] && f[j][1] != '-') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1115 return -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1116 prop[j] = Qnil; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1117 wild_card_found = 1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1118 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1119 else if (j + 1 < i) |
| 94926 | 1120 prop[j] = INTERN_FIELD (j); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1121 else |
| 94926 | 1122 prop[j] = font_intern_prop (f[j], f[i] - f[j]); |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1123 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1124 if (! wild_card_found) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1125 return -1; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1126 if (font_expand_wildcards (prop, i) < 0) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1127 return -1; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1128 |
| 94926 | 1129 ASET (font, FONT_FOUNDRY_INDEX, prop[XLFD_FOUNDRY_INDEX]); |
| 1130 ASET (font, FONT_FAMILY_INDEX, prop[XLFD_FAMILY_INDEX]); | |
| 1131 for (i = XLFD_WEIGHT_INDEX, j = FONT_WEIGHT_INDEX; | |
| 1132 i <= XLFD_SWIDTH_INDEX; i++, j++) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1133 if (! NILP (prop[i])) |
| 94926 | 1134 { |
| 1135 if ((n = font_style_to_value (j, prop[i], 1)) < 0) | |
| 1136 return -1; | |
| 1137 ASET (font, j, make_number (n)); | |
| 1138 } | |
| 1139 ASET (font, FONT_ADSTYLE_INDEX, prop[XLFD_ADSTYLE_INDEX]); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1140 val = prop[XLFD_REGISTRY_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1141 if (NILP (val)) |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1142 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1143 val = prop[XLFD_ENCODING_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1144 if (! NILP (val)) |
| 94926 | 1145 val = concat2 (build_string ("*-"), SYMBOL_NAME (val)); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1146 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1147 else if (NILP (prop[XLFD_ENCODING_INDEX])) |
| 94926 | 1148 val = concat2 (SYMBOL_NAME (val), build_string ("-*")); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1149 else |
| 94926 | 1150 val = concat3 (SYMBOL_NAME (val), build_string ("-"), |
| 1151 SYMBOL_NAME (prop[XLFD_ENCODING_INDEX])); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1152 if (! NILP (val)) |
| 94926 | 1153 ASET (font, FONT_REGISTRY_INDEX, Fintern (val, Qnil)); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1154 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1155 if (INTEGERP (prop[XLFD_PIXEL_INDEX])) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1156 ASET (font, FONT_SIZE_INDEX, prop[XLFD_PIXEL_INDEX]); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1157 else if (INTEGERP (prop[XLFD_POINT_INDEX])) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1158 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1159 double point_size = XINT (prop[XLFD_POINT_INDEX]); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1160 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1161 ASET (font, FONT_SIZE_INDEX, make_float (point_size / 10)); |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1162 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1163 |
| 94926 | 1164 if (INTEGERP (prop[XLFD_RESX_INDEX])) |
| 1165 ASET (font, FONT_DPI_INDEX, prop[XLFD_RESY_INDEX]); | |
| 1166 if (! NILP (prop[XLFD_SPACING_INDEX])) | |
| 1167 { | |
| 1168 val = font_prop_validate_spacing (QCspacing, | |
| 1169 prop[XLFD_SPACING_INDEX]); | |
| 1170 if (! INTEGERP (val)) | |
| 1171 return -1; | |
| 1172 ASET (font, FONT_SPACING_INDEX, val); | |
| 1173 } | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1174 if (INTEGERP (prop[XLFD_AVGWIDTH_INDEX])) |
| 94926 | 1175 ASET (font, FONT_AVGWIDTH_INDEX, prop[XLFD_AVGWIDTH_INDEX]); |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1176 } |
| 90400 | 1177 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1178 return 0; |
| 90400 | 1179 } |
| 1180 | |
| 1181 /* Store XLFD name of FONT (font-spec or font-entity) in NAME (NBYTES | |
| 1182 length), and return the name length. If FONT_SIZE_INDEX of FONT is | |
| 1183 0, use PIXEL_SIZE instead. */ | |
| 1184 | |
| 1185 int | |
| 1186 font_unparse_xlfd (font, pixel_size, name, nbytes) | |
| 1187 Lisp_Object font; | |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1188 int pixel_size; |
| 90400 | 1189 char *name; |
| 1190 int nbytes; | |
| 1191 { | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1192 char *f[XLFD_REGISTRY_INDEX + 1]; |
| 90400 | 1193 Lisp_Object val; |
| 1194 int i, j, len = 0; | |
| 1195 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1196 font_assert (FONTP (font)); |
| 90400 | 1197 |
| 1198 for (i = FONT_FOUNDRY_INDEX, j = XLFD_FOUNDRY_INDEX; i <= FONT_REGISTRY_INDEX; | |
| 1199 i++, j++) | |
| 1200 { | |
| 1201 if (i == FONT_ADSTYLE_INDEX) | |
| 1202 j = XLFD_ADSTYLE_INDEX; | |
| 1203 else if (i == FONT_REGISTRY_INDEX) | |
| 1204 j = XLFD_REGISTRY_INDEX; | |
| 1205 val = AREF (font, i); | |
| 1206 if (NILP (val)) | |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1207 { |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1208 if (j == XLFD_REGISTRY_INDEX) |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1209 f[j] = "*-*", len += 4; |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1210 else |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1211 f[j] = "*", len += 2; |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1212 } |
| 90400 | 1213 else |
| 1214 { | |
| 1215 if (SYMBOLP (val)) | |
| 1216 val = SYMBOL_NAME (val); | |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1217 if (j == XLFD_REGISTRY_INDEX |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1218 && ! strchr ((char *) SDATA (val), '-')) |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1219 { |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1220 /* Change "jisx0208*" and "jisx0208" to "jisx0208*-*". */ |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1221 if (SDATA (val)[SBYTES (val) - 1] == '*') |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1222 { |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1223 f[j] = alloca (SBYTES (val) + 3); |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1224 sprintf (f[j], "%s-*", SDATA (val)); |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1225 len += SBYTES (val) + 3; |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1226 } |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1227 else |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1228 { |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1229 f[j] = alloca (SBYTES (val) + 4); |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1230 sprintf (f[j], "%s*-*", SDATA (val)); |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1231 len += SBYTES (val) + 4; |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1232 } |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1233 } |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1234 else |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1235 f[j] = (char *) SDATA (val), len += SBYTES (val) + 1; |
| 90400 | 1236 } |
| 1237 } | |
| 1238 | |
| 1239 for (i = FONT_WEIGHT_INDEX, j = XLFD_WEIGHT_INDEX; i <= FONT_WIDTH_INDEX; | |
| 1240 i++, j++) | |
| 1241 { | |
| 94926 | 1242 val = font_style_symbolic (font, i, 0); |
| 90400 | 1243 if (NILP (val)) |
| 1244 f[j] = "*", len += 2; | |
| 1245 else | |
| 1246 { | |
| 94926 | 1247 val = SYMBOL_NAME (val); |
| 90400 | 1248 f[j] = (char *) SDATA (val), len += SBYTES (val) + 1; |
| 1249 } | |
| 1250 } | |
| 1251 | |
| 1252 val = AREF (font, FONT_SIZE_INDEX); | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1253 font_assert (NUMBERP (val) || NILP (val)); |
| 90400 | 1254 if (INTEGERP (val)) |
| 1255 { | |
| 94926 | 1256 i = XINT (val); |
|
91943
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1257 if (i <= 0) |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1258 i = pixel_size; |
| 90400 | 1259 if (i > 0) |
|
91943
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1260 { |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1261 f[XLFD_PIXEL_INDEX] = alloca (22); |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1262 len += sprintf (f[XLFD_PIXEL_INDEX], "%d-*", i) + 1; |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1263 } |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1264 else |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1265 f[XLFD_PIXEL_INDEX] = "*-*", len += 4; |
| 90400 | 1266 } |
| 1267 else if (FLOATP (val)) | |
| 1268 { | |
| 94926 | 1269 i = XFLOAT_DATA (val) * 10; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1270 f[XLFD_PIXEL_INDEX] = alloca (12); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1271 len += sprintf (f[XLFD_PIXEL_INDEX], "*-%d", i) + 1; |
| 90400 | 1272 } |
| 1273 else | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1274 f[XLFD_PIXEL_INDEX] = "*-*", len += 4; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1275 |
| 94926 | 1276 if (INTEGERP (AREF (font, FONT_DPI_INDEX))) |
| 90400 | 1277 { |
| 94926 | 1278 i = XINT (AREF (font, FONT_DPI_INDEX)); |
| 1279 f[XLFD_RESX_INDEX] = alloca (22); | |
| 1280 len += sprintf (f[XLFD_RESX_INDEX], | |
| 1281 "%d-%d", i, i) + 1; | |
| 90400 | 1282 } |
| 1283 else | |
| 94926 | 1284 f[XLFD_RESX_INDEX] = "*-*", len += 4; |
| 1285 if (INTEGERP (AREF (font, FONT_SPACING_INDEX))) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1286 { |
| 94926 | 1287 int spacing = XINT (AREF (font, FONT_SPACING_INDEX)); |
| 1288 | |
| 1289 f[XLFD_SPACING_INDEX] = (spacing <= FONT_SPACING_PROPORTIONAL ? "p" | |
| 1290 : spacing <= FONT_SPACING_DUAL ? "d" | |
| 1291 : spacing <= FONT_SPACING_MONO ? "m" | |
| 1292 : "c"); | |
| 1293 len += 2; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1294 } |
| 94926 | 1295 else |
| 1296 f[XLFD_SPACING_INDEX] = "*", len += 2; | |
| 1297 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX))) | |
| 1298 { | |
| 1299 f[XLFD_AVGWIDTH_INDEX] = alloca (11); | |
| 1300 len += sprintf (f[XLFD_AVGWIDTH_INDEX], | |
| 1301 "%d", XINT (AREF (font, FONT_AVGWIDTH_INDEX))) + 1; | |
| 1302 } | |
| 1303 else | |
| 1304 f[XLFD_AVGWIDTH_INDEX] = "*", len += 2; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1305 len++; /* for terminating '\0'. */ |
| 90400 | 1306 if (len >= nbytes) |
| 1307 return -1; | |
| 94926 | 1308 return sprintf (name, "-%s-%s-%s-%s-%s-%s-%s-%s-%s-%s-%s", |
| 90400 | 1309 f[XLFD_FOUNDRY_INDEX], f[XLFD_FAMILY_INDEX], |
| 1310 f[XLFD_WEIGHT_INDEX], f[XLFD_SLANT_INDEX], | |
| 94926 | 1311 f[XLFD_SWIDTH_INDEX], f[XLFD_ADSTYLE_INDEX], |
| 1312 f[XLFD_PIXEL_INDEX], f[XLFD_RESX_INDEX], | |
| 1313 f[XLFD_SPACING_INDEX], f[XLFD_AVGWIDTH_INDEX], | |
| 1314 f[XLFD_REGISTRY_INDEX]); | |
| 90400 | 1315 } |
| 1316 | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1317 /* Parse NAME (null terminated) as Fonconfig's name format and store |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1318 information in FONT (font-spec or font-entity). If NAME is |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1319 successfully parsed, return 0. Otherwise return -1. */ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1320 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1321 int |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1322 font_parse_fcname (name, font) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1323 char *name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1324 Lisp_Object font; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1325 { |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1326 char *p0, *p1; |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1327 int len = strlen (name); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1328 char *copy; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1329 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1330 if (len == 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1331 return -1; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1332 /* It is assured that (name[0] && name[0] != '-'). */ |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1333 if (name[0] == ':') |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1334 p0 = name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1335 else |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1336 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1337 Lisp_Object family; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1338 double point_size; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1339 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1340 for (p0 = name + 1; *p0 && (*p0 != '-' && *p0 != ':'); p0++) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1341 if (*p0 == '\\' && p0[1]) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1342 p0++; |
| 94926 | 1343 family = font_intern_prop (name, p0 - name); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1344 if (*p0 == '-') |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1345 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1346 if (! isdigit (p0[1])) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1347 return -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1348 point_size = strtod (p0 + 1, &p1); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1349 if (*p1 && *p1 != ':') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1350 return -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1351 ASET (font, FONT_SIZE_INDEX, make_float (point_size)); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1352 p0 = p1; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1353 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1354 ASET (font, FONT_FAMILY_INDEX, family); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1355 } |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1356 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1357 len -= p0 - name; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1358 copy = alloca (len + 1); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1359 if (! copy) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1360 return -1; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1361 name = copy; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
1362 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1363 /* Now parse ":KEY=VAL" patterns. Store known keys and values in |
| 94926 | 1364 extra, copy unknown ones to COPY. It is stored in extra slot by |
| 1365 the key QCfc_unknown_spec. */ | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1366 while (*p0) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1367 { |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1368 Lisp_Object key, val; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1369 int prop; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1370 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1371 for (p1 = p0 + 1; *p1 && *p1 != '=' && *p1 != ':'; p1++); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1372 if (*p1 != '=') |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1373 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1374 /* Must be an enumerated value. */ |
| 94926 | 1375 val = font_intern_prop (p0 + 1, p1 - p0 - 1); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1376 if (memcmp (p0 + 1, "light", 5) == 0 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1377 || memcmp (p0 + 1, "medium", 6) == 0 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1378 || memcmp (p0 + 1, "demibold", 8) == 0 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1379 || memcmp (p0 + 1, "bold", 4) == 0 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1380 || memcmp (p0 + 1, "black", 5) == 0) |
| 94926 | 1381 FONT_SET_STYLE (font, FONT_WEIGHT_INDEX, val); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1382 else if (memcmp (p0 + 1, "roman", 5) == 0 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1383 || memcmp (p0 + 1, "italic", 6) == 0 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1384 || memcmp (p0 + 1, "oblique", 7) == 0) |
| 94926 | 1385 FONT_SET_STYLE (font, FONT_SLANT_INDEX, val); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1386 else if (memcmp (p0 + 1, "charcell", 8) == 0 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1387 || memcmp (p0 + 1, "mono", 4) == 0 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1388 || memcmp (p0 + 1, "proportional", 12) == 0) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1389 { |
| 94926 | 1390 int spacing = (p0[1] == 'c' ? FONT_SPACING_CHARCELL |
| 1391 : p0[1] == 'm' ? FONT_SPACING_MONO | |
| 1392 : FONT_SPACING_PROPORTIONAL); | |
| 1393 ASET (font, FONT_SPACING_INDEX, make_number (spacing)); | |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
1394 } |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1395 else |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1396 { |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1397 /* unknown key */ |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1398 bcopy (p0, copy, p1 - p0); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1399 copy += p1 - p0; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1400 } |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1401 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1402 else |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1403 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1404 if (memcmp (p0 + 1, "pixelsize=", 10) == 0) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1405 prop = FONT_SIZE_INDEX; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1406 else |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1407 { |
| 94926 | 1408 key = font_intern_prop (p0, p1 - p0); |
| 1409 prop = get_font_prop_index (key); | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1410 } |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1411 p0 = p1 + 1; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1412 for (p1 = p0; *p1 && *p1 != ':'; p1++); |
| 94926 | 1413 val = font_intern_prop (p0, p1 - p0); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1414 if (! NILP (val)) |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1415 { |
| 94926 | 1416 if (prop >= FONT_FOUNDRY_INDEX && prop < FONT_EXTRA_INDEX) |
| 1417 ASET (font, prop, font_prop_validate (prop, Qnil, val)); | |
| 1418 else if (prop >= 0) | |
| 1419 Ffont_put (font, key, val); | |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1420 else |
| 94926 | 1421 bcopy (p0 - 1, copy, p1 - p0 + 1); |
| 1422 copy += p1 - p0 + 1; | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1423 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1424 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1425 p0 = p1; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1426 } |
| 94926 | 1427 if (name != copy) |
| 1428 font_put_extra (font, QCfc_unknown_spec, | |
| 1429 make_unibyte_string (name, copy - name)); | |
|
91261
2e5bb6a0a787
(font_parse_fcname): Default weight and slant to normal.
Jason Rumney <jasonr@gnu.org>
parents:
91247
diff
changeset
|
1430 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1431 return 0; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1432 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1433 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1434 /* Store fontconfig's font name of FONT (font-spec or font-entity) in |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1435 NAME (NBYTES length), and return the name length. If |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1436 FONT_SIZE_INDEX of FONT is 0, use PIXEL_SIZE instead. */ |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1437 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1438 int |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1439 font_unparse_fcname (font, pixel_size, name, nbytes) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1440 Lisp_Object font; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1441 int pixel_size; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1442 char *name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1443 int nbytes; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1444 { |
| 94926 | 1445 Lisp_Object tail, val; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1446 int point_size; |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1447 int dpi; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1448 int i, len = 1; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1449 char *p; |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
1450 Lisp_Object styles[3]; |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
1451 char *style_names[3] = { "weight", "slant", "width" }; |
| 94926 | 1452 char work[256]; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1453 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1454 val = AREF (font, FONT_FAMILY_INDEX); |
| 94926 | 1455 if (STRINGP (val)) |
| 1456 len += SBYTES (val); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1457 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1458 val = AREF (font, FONT_SIZE_INDEX); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1459 if (INTEGERP (val)) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1460 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1461 if (XINT (val) != 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1462 pixel_size = XINT (val); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1463 point_size = -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1464 len += 21; /* for ":pixelsize=NUM" */ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1465 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1466 else if (FLOATP (val)) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1467 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1468 pixel_size = -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1469 point_size = (int) XFLOAT_DATA (val); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1470 len += 11; /* for "-NUM" */ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1471 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1472 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1473 val = AREF (font, FONT_FOUNDRY_INDEX); |
| 94926 | 1474 if (STRINGP (val)) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1475 /* ":foundry=NAME" */ |
| 94926 | 1476 len += 9 + SBYTES (val); |
| 1477 | |
| 1478 for (i = 0; i < 3; i++) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1479 { |
| 94926 | 1480 styles[i] = font_style_symbolic (font, FONT_WEIGHT_INDEX + i, 0); |
| 1481 if (! NILP (styles[i])) | |
| 1482 len += sprintf (work, ":%s=%s", style_names[i], | |
| 1483 SDATA (SYMBOL_NAME (styles[i]))); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1484 } |
| 94926 | 1485 |
| 1486 if (INTEGERP (AREF (font, FONT_DPI_INDEX))) | |
| 1487 len += sprintf (work, ":dpi=%d", dpi); | |
| 1488 if (INTEGERP (AREF (font, FONT_SPACING_INDEX))) | |
| 1489 len += strlen (":spacing=100"); | |
| 1490 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX))) | |
| 1491 len += strlen (":scalable=false"); /* or ":scalable=true" */ | |
| 1492 for (tail = AREF (font, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail)) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1493 { |
| 94926 | 1494 Lisp_Object key = XCAR (XCAR (tail)), val = XCDR (XCAR (tail)); |
| 1495 | |
| 1496 len += SBYTES (SYMBOL_NAME (key)) + 1; /* for :KEY= */ | |
| 1497 if (STRINGP (val)) | |
| 1498 len += SBYTES (val); | |
| 1499 else if (INTEGERP (val)) | |
| 1500 len += sprintf (work, "%d", XINT (val)); | |
| 1501 else if (SYMBOLP (val)) | |
| 1502 len += (NILP (val) ? 5 : 4); /* for "false" or "true" */ | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1503 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1504 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1505 if (len > nbytes) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1506 return -1; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1507 p = name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1508 if (! NILP (AREF (font, FONT_FAMILY_INDEX))) |
| 94926 | 1509 p += sprintf(p, "%s", SDATA (SYMBOL_NAME (AREF (font, FONT_FAMILY_INDEX)))); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1510 if (point_size > 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1511 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1512 if (p == name) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1513 p += sprintf (p, "%d", point_size); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1514 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1515 p += sprintf (p, "-%d", point_size); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1516 } |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1517 else if (pixel_size > 0) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1518 p += sprintf (p, ":pixelsize=%d", pixel_size); |
| 94926 | 1519 if (! NILP (AREF (font, FONT_FOUNDRY_INDEX))) |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
1520 p += sprintf (p, ":foundry=%s", |
|
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
1521 SDATA (SYMBOL_NAME (AREF (font, FONT_FOUNDRY_INDEX)))); |
|
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
1522 for (i = 0; i < 3; i++) |
| 94926 | 1523 if (! NILP (styles[i])) |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
1524 p += sprintf (p, ":%s=%s", style_names[i], |
| 94926 | 1525 SDATA (SYMBOL_NAME (styles[i]))); |
| 1526 if (INTEGERP (AREF (font, FONT_DPI_INDEX))) | |
| 1527 p += sprintf (p, ":dpi=%d", XINT (AREF (font, FONT_DPI_INDEX))); | |
| 1528 if (INTEGERP (AREF (font, FONT_SPACING_INDEX))) | |
| 1529 p += sprintf (p, ":spacing=%d", XINT (AREF (font, FONT_SPACING_INDEX))); | |
| 1530 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX))) | |
| 1531 { | |
| 1532 if (XINT (AREF (font, FONT_AVGWIDTH_INDEX)) == 0) | |
| 1533 p += sprintf (p, ":scalable=true"); | |
| 1534 else | |
| 1535 p += sprintf (p, ":scalable=false"); | |
| 1536 } | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1537 return (p - name); |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1538 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1539 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1540 /* Parse NAME (null terminated) and store information in FONT |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1541 (font-spec or font-entity). If NAME is successfully parsed, return |
| 94926 | 1542 0. Otherwise return -1. */ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1543 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1544 static int |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1545 font_parse_name (name, font) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1546 char *name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1547 Lisp_Object font; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1548 { |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1549 if (name[0] == '-' || index (name, '*')) |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1550 return font_parse_xlfd (name, font); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1551 return font_parse_fcname (name, font); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1552 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1553 |
| 94926 | 1554 |
| 1555 /* Merge FAMILY and REGISTRY into FONT_SPEC. FAMILY may have the form | |
| 1556 "FAMILY-FOUNDRY". REGISTRY may not contain charset-encoding | |
| 1557 part. */ | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
1558 |
| 90400 | 1559 void |
| 94926 | 1560 font_parse_family_registry (family, registry, font_spec) |
| 1561 Lisp_Object family, registry, font_spec; | |
| 90400 | 1562 { |
| 94926 | 1563 int len; |
| 1564 char *p0, *p1; | |
| 1565 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1566 if (! NILP (family) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1567 && NILP (AREF (font_spec, FONT_FAMILY_INDEX))) |
| 90400 | 1568 { |
| 94926 | 1569 CHECK_STRING (family); |
| 1570 len = SBYTES (family); | |
| 1571 p0 = (char *) SDATA (family); | |
| 1572 p1 = index (p0, '-'); | |
| 1573 if (p1) | |
| 90400 | 1574 { |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1575 if ((*p0 != '*' || p1 - p0 > 1) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1576 && NILP (AREF (font_spec, FONT_FOUNDRY_INDEX))) |
| 94926 | 1577 ASET (font_spec, FONT_FOUNDRY_INDEX, |
| 1578 font_intern_prop (p0, p1 - p0)); | |
| 1579 p1++; | |
| 1580 len -= p1 - p0; | |
| 1581 ASET (font_spec, FONT_FAMILY_INDEX, font_intern_prop (p1, len)); | |
| 90400 | 1582 } |
| 94926 | 1583 else |
| 1584 ASET (font_spec, FONT_FAMILY_INDEX, Fintern (family, Qnil)); | |
| 1585 } | |
| 1586 if (! NILP (registry)) | |
| 1587 { | |
| 1588 /* Convert "XXX" and "XXX*" to "XXX*-*". */ | |
| 1589 CHECK_STRING (registry); | |
| 1590 len = SBYTES (registry); | |
| 1591 p0 = (char *) SDATA (registry); | |
| 1592 p1 = index (p0, '-'); | |
| 1593 if (! p1) | |
| 1594 { | |
| 1595 if (SDATA (registry)[len - 1] == '*') | |
| 1596 registry = concat2 (registry, build_string ("-*")); | |
| 1597 else | |
| 1598 registry = concat2 (registry, build_string ("*-*")); | |
| 1599 } | |
| 1600 registry = Fdowncase (registry); | |
| 1601 ASET (font_spec, FONT_REGISTRY_INDEX, Fintern (registry, Qnil)); | |
| 90400 | 1602 } |
| 1603 } | |
| 1604 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
1605 |
| 94926 | 1606 /* This part (through the next ^L) is still experimental and not |
| 1607 tested much. We may drastically change codes. */ | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
1608 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
1609 /* OTF handler */ |
| 90541 | 1610 |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1611 #define LGSTRING_HEADER_SIZE 6 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1612 #define LGSTRING_GLYPH_SIZE 8 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1613 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1614 static int |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1615 check_gstring (gstring) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1616 Lisp_Object gstring; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1617 { |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1618 Lisp_Object val; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1619 int i, j; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1620 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1621 CHECK_VECTOR (gstring); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1622 val = AREF (gstring, 0); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1623 CHECK_VECTOR (val); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1624 if (ASIZE (val) < LGSTRING_HEADER_SIZE) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1625 goto err; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1626 CHECK_FONT_OBJECT (LGSTRING_FONT (gstring)); |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1627 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_LBEARING))) |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1628 CHECK_NUMBER (LGSTRING_SLOT (gstring, LGSTRING_IX_LBEARING)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1629 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_RBEARING))) |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1630 CHECK_NUMBER (LGSTRING_SLOT (gstring, LGSTRING_IX_RBEARING)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1631 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_WIDTH))) |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1632 CHECK_NATNUM (LGSTRING_SLOT (gstring, LGSTRING_IX_WIDTH)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1633 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_ASCENT))) |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1634 CHECK_NUMBER (LGSTRING_SLOT (gstring, LGSTRING_IX_ASCENT)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1635 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_ASCENT))) |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1636 CHECK_NUMBER (LGSTRING_SLOT (gstring, LGSTRING_IX_ASCENT)); |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1637 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1638 for (i = 0; i < LGSTRING_LENGTH (gstring); i++) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1639 { |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1640 val = LGSTRING_GLYPH (gstring, i); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1641 CHECK_VECTOR (val); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1642 if (ASIZE (val) < LGSTRING_GLYPH_SIZE) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1643 goto err; |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1644 if (NILP (AREF (val, LGLYPH_IX_CHAR))) |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1645 break; |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1646 CHECK_NATNUM (AREF (val, LGLYPH_IX_FROM)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1647 CHECK_NATNUM (AREF (val, LGLYPH_IX_TO)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1648 CHECK_CHARACTER (AREF (val, LGLYPH_IX_CHAR)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1649 if (!NILP (AREF (val, LGLYPH_IX_CODE))) |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1650 CHECK_NATNUM (AREF (val, LGLYPH_IX_CODE)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1651 if (!NILP (AREF (val, LGLYPH_IX_WIDTH))) |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1652 CHECK_NATNUM (AREF (val, LGLYPH_IX_WIDTH)); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1653 if (!NILP (AREF (val, LGLYPH_IX_ADJUSTMENT))) |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1654 { |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1655 val = AREF (val, LGLYPH_IX_ADJUSTMENT); |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1656 CHECK_VECTOR (val); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1657 if (ASIZE (val) < 3) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1658 goto err; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1659 for (j = 0; j < 3; j++) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1660 CHECK_NUMBER (AREF (val, j)); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1661 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1662 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1663 return i; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1664 err: |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1665 error ("Invalid glyph-string format"); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1666 return -1; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1667 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1668 |
|
90823
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1669 static void |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1670 check_otf_features (otf_features) |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1671 Lisp_Object otf_features; |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1672 { |
| 94926 | 1673 Lisp_Object val; |
|
90823
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1674 |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1675 CHECK_CONS (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1676 CHECK_SYMBOL (XCAR (otf_features)); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1677 otf_features = XCDR (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1678 CHECK_CONS (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1679 CHECK_SYMBOL (XCAR (otf_features)); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1680 otf_features = XCDR (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1681 for (val = Fcar (otf_features); ! NILP (val); val = Fcdr (val)) |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1682 { |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1683 CHECK_SYMBOL (Fcar (val)); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1684 if (SBYTES (SYMBOL_NAME (XCAR (val))) > 4) |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1685 error ("Invalid OTF GSUB feature: %s", SYMBOL_NAME (XCAR (val))); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1686 } |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1687 otf_features = XCDR (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1688 for (val = Fcar (otf_features); ! NILP (val); val = Fcdr (val)) |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1689 { |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1690 CHECK_SYMBOL (Fcar (val)); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1691 if (SBYTES (SYMBOL_NAME (XCAR (val))) > 4) |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1692 error ("Invalid OTF GPOS feature: %s", SYMBOL_NAME (XCAR (val))); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1693 } |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1694 } |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1695 |
| 90400 | 1696 #ifdef HAVE_LIBOTF |
| 1697 #include <otf.h> | |
| 1698 | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1699 Lisp_Object otf_list; |
| 90400 | 1700 |
| 1701 static Lisp_Object | |
| 1702 otf_tag_symbol (tag) | |
| 1703 OTF_Tag tag; | |
| 1704 { | |
| 1705 char name[5]; | |
| 1706 | |
| 1707 OTF_tag_name (tag, name); | |
| 1708 return Fintern (make_unibyte_string (name, 4), Qnil); | |
| 1709 } | |
| 1710 | |
| 1711 static OTF * | |
| 94926 | 1712 otf_open (file) |
| 1713 Lisp_Object file; | |
| 90400 | 1714 { |
| 94926 | 1715 Lisp_Object val = Fassoc (file, otf_list); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1716 OTF *otf; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1717 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1718 if (! NILP (val)) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1719 otf = XSAVE_VALUE (XCDR (val))->pointer; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1720 else |
| 90400 | 1721 { |
| 94926 | 1722 otf = STRINGP (file) ? OTF_open ((char *) SDATA (file)) : NULL; |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1723 val = make_save_value (otf, 0); |
| 94926 | 1724 otf_list = Fcons (Fcons (file, val), otf_list); |
| 90400 | 1725 } |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1726 return otf; |
| 90400 | 1727 } |
| 1728 | |
| 1729 | |
| 1730 /* Return a list describing which scripts/languages FONT supports by | |
| 1731 which GSUB/GPOS features of OpenType tables. See the comment of | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
1732 (struct font_driver).otf_capability. */ |
| 90400 | 1733 |
| 1734 Lisp_Object | |
| 1735 font_otf_capability (font) | |
| 1736 struct font *font; | |
| 1737 { | |
| 1738 OTF *otf; | |
| 1739 Lisp_Object capability = Fcons (Qnil, Qnil); | |
| 1740 int i; | |
| 1741 | |
| 94926 | 1742 otf = otf_open (font->props[FONT_FILE_INDEX]); |
| 90400 | 1743 if (! otf) |
| 1744 return Qnil; | |
| 1745 for (i = 0; i < 2; i++) | |
| 1746 { | |
| 1747 OTF_GSUB_GPOS *gsub_gpos; | |
| 1748 Lisp_Object script_list = Qnil; | |
| 1749 int j; | |
| 1750 | |
| 1751 if (OTF_get_features (otf, i == 0) < 0) | |
| 1752 continue; | |
| 1753 gsub_gpos = i == 0 ? otf->gsub : otf->gpos; | |
| 1754 for (j = gsub_gpos->ScriptList.ScriptCount - 1; j >= 0; j--) | |
| 1755 { | |
| 1756 OTF_Script *script = gsub_gpos->ScriptList.Script + j; | |
| 1757 Lisp_Object langsys_list = Qnil; | |
| 1758 Lisp_Object script_tag = otf_tag_symbol (script->ScriptTag); | |
| 1759 int k; | |
| 1760 | |
| 1761 for (k = script->LangSysCount; k >= 0; k--) | |
| 1762 { | |
| 1763 OTF_LangSys *langsys; | |
| 1764 Lisp_Object feature_list = Qnil; | |
| 1765 Lisp_Object langsys_tag; | |
| 1766 int l; | |
| 1767 | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1768 if (k == script->LangSysCount) |
| 90400 | 1769 { |
| 1770 langsys = &script->DefaultLangSys; | |
| 1771 langsys_tag = Qnil; | |
| 1772 } | |
| 1773 else | |
| 1774 { | |
| 1775 langsys = script->LangSys + k; | |
| 1776 langsys_tag | |
| 1777 = otf_tag_symbol (script->LangSysRecord[k].LangSysTag); | |
| 1778 } | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1779 for (l = langsys->FeatureCount - 1; l >= 0; l--) |
| 90400 | 1780 { |
| 1781 OTF_Feature *feature | |
| 1782 = gsub_gpos->FeatureList.Feature + langsys->FeatureIndex[l]; | |
| 1783 Lisp_Object feature_tag | |
| 1784 = otf_tag_symbol (feature->FeatureTag); | |
| 1785 | |
| 1786 feature_list = Fcons (feature_tag, feature_list); | |
| 1787 } | |
| 1788 langsys_list = Fcons (Fcons (langsys_tag, feature_list), | |
| 1789 langsys_list); | |
| 1790 } | |
| 1791 script_list = Fcons (Fcons (script_tag, langsys_list), | |
| 1792 script_list); | |
| 1793 } | |
| 1794 | |
| 1795 if (i == 0) | |
| 1796 XSETCAR (capability, script_list); | |
| 1797 else | |
| 1798 XSETCDR (capability, script_list); | |
| 1799 } | |
| 1800 | |
| 1801 return capability; | |
| 1802 } | |
| 1803 | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1804 /* Parse OTF features in SPEC and write a proper features spec string |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1805 in FEATURES for the call of OTF_drive_gsub/gpos (of libotf). It is |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1806 assured that the sufficient memory has already allocated for |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1807 FEATURES. */ |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1808 |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1809 static void |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1810 generate_otf_features (spec, features) |
| 90400 | 1811 Lisp_Object spec; |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1812 char *features; |
| 90400 | 1813 { |
| 1814 Lisp_Object val; | |
| 94926 | 1815 char *p; |
| 90400 | 1816 int asterisk; |
| 1817 | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1818 p = features; |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1819 *p = '\0'; |
| 90400 | 1820 for (asterisk = 0; CONSP (spec); spec = XCDR (spec)) |
| 1821 { | |
| 1822 val = XCAR (spec); | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1823 CHECK_SYMBOL (val); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1824 if (p > features) |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1825 *p++ = ','; |
| 90400 | 1826 if (SREF (SYMBOL_NAME (val), 0) == '*') |
| 1827 { | |
| 1828 asterisk = 1; | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1829 *p++ = '*'; |
| 90400 | 1830 } |
| 1831 else if (! asterisk) | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1832 { |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1833 val = SYMBOL_NAME (val); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1834 p += sprintf (p, "%s", SDATA (val)); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1835 } |
| 90400 | 1836 else |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1837 { |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1838 val = SYMBOL_NAME (val); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1839 p += sprintf (p, "~%s", SDATA (val)); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1840 } |
| 90400 | 1841 } |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1842 if (CONSP (spec)) |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1843 error ("OTF spec too long"); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1844 } |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1845 |
| 90400 | 1846 |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1847 Lisp_Object |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1848 font_otf_DeviceTable (device_table) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1849 OTF_DeviceTable *device_table; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1850 { |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1851 int len = device_table->StartSize - device_table->EndSize + 1; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1852 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1853 return Fcons (make_number (len), |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1854 make_unibyte_string (device_table->DeltaValue, len)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1855 } |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1856 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1857 Lisp_Object |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1858 font_otf_ValueRecord (value_format, value_record) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1859 int value_format; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1860 OTF_ValueRecord *value_record; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1861 { |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1862 Lisp_Object val = Fmake_vector (make_number (8), Qnil); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1863 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1864 if (value_format & OTF_XPlacement) |
| 91909 | 1865 ASET (val, 0, make_number (value_record->XPlacement)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1866 if (value_format & OTF_YPlacement) |
| 91909 | 1867 ASET (val, 1, make_number (value_record->YPlacement)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1868 if (value_format & OTF_XAdvance) |
| 91909 | 1869 ASET (val, 2, make_number (value_record->XAdvance)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1870 if (value_format & OTF_YAdvance) |
| 91909 | 1871 ASET (val, 3, make_number (value_record->YAdvance)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1872 if (value_format & OTF_XPlaDevice) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1873 ASET (val, 4, font_otf_DeviceTable (&value_record->XPlaDevice)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1874 if (value_format & OTF_YPlaDevice) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1875 ASET (val, 4, font_otf_DeviceTable (&value_record->YPlaDevice)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1876 if (value_format & OTF_XAdvDevice) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1877 ASET (val, 4, font_otf_DeviceTable (&value_record->XAdvDevice)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1878 if (value_format & OTF_YAdvDevice) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1879 ASET (val, 4, font_otf_DeviceTable (&value_record->YAdvDevice)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1880 return val; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1881 } |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1882 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1883 Lisp_Object |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1884 font_otf_Anchor (anchor) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1885 OTF_Anchor *anchor; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1886 { |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1887 Lisp_Object val; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1888 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1889 val = Fmake_vector (make_number (anchor->AnchorFormat + 1), Qnil); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1890 ASET (val, 0, make_number (anchor->XCoordinate)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1891 ASET (val, 1, make_number (anchor->YCoordinate)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1892 if (anchor->AnchorFormat == 2) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1893 ASET (val, 2, make_number (anchor->f.f1.AnchorPoint)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1894 else |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1895 { |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1896 ASET (val, 3, font_otf_DeviceTable (&anchor->f.f2.XDeviceTable)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1897 ASET (val, 4, font_otf_DeviceTable (&anchor->f.f2.YDeviceTable)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1898 } |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1899 return val; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1900 } |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1901 |
| 90400 | 1902 #endif /* HAVE_LIBOTF */ |
| 1903 | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1904 /* G-string (glyph string) handler */ |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1905 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1906 /* G-string is a vector of the form [HEADER GLYPH ...]. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1907 See the docstring of `font-make-gstring' for more detail. */ |
| 90400 | 1908 |
| 1909 struct font * | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1910 font_prepare_composition (cmp, f) |
| 90400 | 1911 struct composition *cmp; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1912 FRAME_PTR f; |
| 90400 | 1913 { |
| 1914 Lisp_Object gstring | |
| 1915 = AREF (XHASH_TABLE (composition_hash_table)->key_and_value, | |
| 1916 cmp->hash_index * 2); | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1917 |
| 94926 | 1918 cmp->font = XFONT_OBJECT (LGSTRING_FONT (gstring)); |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1919 cmp->glyph_len = LGSTRING_LENGTH (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1920 cmp->pixel_width = LGSTRING_WIDTH (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1921 cmp->lbearing = LGSTRING_LBEARING (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1922 cmp->rbearing = LGSTRING_RBEARING (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1923 cmp->ascent = LGSTRING_ASCENT (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1924 cmp->descent = LGSTRING_DESCENT (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1925 cmp->width = cmp->pixel_width / FRAME_COLUMN_WIDTH (f); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1926 if (cmp->width == 0) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1927 cmp->width = 1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1928 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1929 return cmp->font; |
| 90400 | 1930 } |
| 1931 | |
| 1932 | |
| 1933 /* Font sorting */ | |
| 1934 | |
| 94926 | 1935 static unsigned font_score P_ ((Lisp_Object, Lisp_Object *, Lisp_Object)); |
| 90400 | 1936 static int font_compare P_ ((const void *, const void *)); |
| 1937 static Lisp_Object font_sort_entites P_ ((Lisp_Object, Lisp_Object, | |
| 94926 | 1938 Lisp_Object, Lisp_Object, |
| 1939 int)); | |
| 90400 | 1940 |
| 1941 /* We sort fonts by scoring each of them against a specified | |
| 1942 font-spec. The score value is 32 bit (`unsigned'), and the smaller | |
| 1943 the value is, the closer the font is to the font-spec. | |
| 1944 | |
| 94926 | 1945 The highest 2 bits of the score is used for FAMILY. The exact |
| 1946 match is 0, match with one of face-font-family-alternatives is | |
| 1947 nonzero. | |
| 1948 | |
| 1949 The next 2 bits of the score is used for the atomic properties | |
| 1950 FOUNDRY and ADSTYLE respectively. | |
| 1951 | |
| 1952 Each 7-bit in the lower 28 bits are used for numeric properties | |
| 90400 | 1953 WEIGHT, SLANT, WIDTH, and SIZE. */ |
| 1954 | |
| 1955 /* How many bits to shift to store the difference value of each font | |
| 94926 | 1956 property in a score. Note that flots for FONT_TYPE_INDEX and |
| 1957 FONT_REGISTRY_INDEX are not used. */ | |
| 90400 | 1958 static int sort_shift_bits[FONT_SIZE_INDEX + 1]; |
| 1959 | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1960 /* Score font-entity ENTITY against properties of font-spec SPEC_PROP. |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1961 The return value indicates how different ENTITY is compared with |
| 94926 | 1962 SPEC_PROP. |
| 1963 | |
| 1964 ALTERNATE_FAMILIES, if non-nil, is a pre-calculated list of | |
| 1965 alternate family names for AREF (SPEC_PROP, FONT_FAMILY_INDEX). */ | |
| 90400 | 1966 |
| 1967 static unsigned | |
| 94926 | 1968 font_score (entity, spec_prop, alternate_families) |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1969 Lisp_Object entity, *spec_prop; |
| 94926 | 1970 Lisp_Object alternate_families; |
| 90400 | 1971 { |
| 1972 unsigned score = 0; | |
| 1973 int i; | |
| 94926 | 1974 |
| 1975 /* Score three atomic fields. Maximum difference is 1 (family is 3). */ | |
| 1976 for (i = FONT_FOUNDRY_INDEX; i <= FONT_ADSTYLE_INDEX; i++) | |
| 1977 if (i != FONT_REGISTRY_INDEX | |
| 1978 && ! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i])) | |
| 1979 { | |
| 1980 Lisp_Object entity_str = SYMBOL_NAME (AREF (entity, i)); | |
| 1981 Lisp_Object spec_str = SYMBOL_NAME (spec_prop[i]); | |
| 1982 | |
|
95211
e5b02763f924
* dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents:
95204
diff
changeset
|
1983 if (xstrcasecmp ((char *) SDATA (spec_str), |
|
e5b02763f924
* dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents:
95204
diff
changeset
|
1984 (char *) SDATA (entity_str))) |
| 94926 | 1985 { |
| 1986 if (i == FONT_FAMILY_INDEX && CONSP (alternate_families)) | |
| 1987 { | |
| 1988 int j; | |
| 1989 | |
| 1990 for (j = 1; CONSP (alternate_families); | |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
1991 j++, alternate_families = XCDR (alternate_families)) |
| 94926 | 1992 { |
| 1993 spec_str = XCAR (alternate_families); | |
|
95211
e5b02763f924
* dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents:
95204
diff
changeset
|
1994 if (xstrcasecmp ((char *) SDATA (spec_str), |
|
e5b02763f924
* dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents:
95204
diff
changeset
|
1995 (char *) SDATA (entity_str)) == 0) |
| 94926 | 1996 break; |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
1997 |
| 94926 | 1998 } |
| 1999 if (j > 3) | |
| 2000 j = 3; | |
| 2001 score |= j << sort_shift_bits[i]; | |
| 2002 } | |
| 2003 else | |
| 2004 score |= 1 << sort_shift_bits[i]; | |
| 2005 } | |
| 2006 } | |
| 2007 | |
| 2008 /* Score three style numeric fields. Maximum difference is 127. */ | |
| 2009 for (i = FONT_WEIGHT_INDEX; i <= FONT_WIDTH_INDEX; i++) | |
| 2010 if (! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i])) | |
| 2011 { | |
| 2012 int diff = (XINT (AREF (entity, i)) >> 8) - (XINT (spec_prop[i]) >> 8); | |
| 2013 | |
| 2014 if (diff < 0) | |
| 2015 diff = - diff; | |
| 2016 /* This is to prefer the exact symbol style. */ | |
| 2017 diff++; | |
| 2018 score |= min (diff, 127) << sort_shift_bits[i]; | |
| 2019 } | |
| 2020 | |
| 2021 /* Score the size. Maximum difference is 127. */ | |
| 2022 i = FONT_SIZE_INDEX; | |
| 2023 if (! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i]) | |
| 2024 && XINT (AREF (entity, i)) > 0) | |
| 90400 | 2025 { |
| 94926 | 2026 /* We use the higher 6-bit for the actual size difference. The |
| 2027 lowest bit is set if the DPI is different. */ | |
| 2028 int diff = XINT (spec_prop[i]) - XINT (AREF (entity, i)); | |
| 2029 | |
| 2030 if (diff < 0) | |
| 2031 diff = - diff; | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2032 diff <<= 1; |
| 94926 | 2033 if (! NILP (spec_prop[FONT_DPI_INDEX]) |
| 2034 && ! EQ (spec_prop[FONT_DPI_INDEX], AREF (entity, FONT_DPI_INDEX))) | |
| 2035 diff |= 1; | |
| 2036 score |= min (diff, 127) << sort_shift_bits[FONT_SIZE_INDEX]; | |
| 90400 | 2037 } |
| 2038 | |
| 2039 return score; | |
| 2040 } | |
| 2041 | |
| 2042 | |
| 2043 /* The comparison function for qsort. */ | |
| 2044 | |
| 2045 static int | |
| 2046 font_compare (d1, d2) | |
| 2047 const void *d1, *d2; | |
| 2048 { | |
| 94926 | 2049 return (*(unsigned *) d1 - *(unsigned *) d2); |
| 90400 | 2050 } |
| 2051 | |
| 2052 | |
| 2053 /* The structure for elements being sorted by qsort. */ | |
| 2054 struct font_sort_data | |
| 2055 { | |
| 2056 unsigned score; | |
| 2057 Lisp_Object entity; | |
| 2058 }; | |
| 2059 | |
| 2060 | |
| 2061 /* Sort font-entities in vector VEC by closeness to font-spec PREFER. | |
| 2062 If PREFER specifies a point-size, calculate the corresponding | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2063 pixel-size from QCdpi property of PREFER or from the Y-resolution |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2064 of FRAME before sorting. If SPEC is not nil, it is a font-spec to |
| 94926 | 2065 get the font-entities in VEC. |
| 2066 | |
| 2067 If BEST-ONLY is nonzero, return the best matching entity. Otherwise, | |
| 2068 return the sorted VEC. */ | |
| 90400 | 2069 |
| 2070 static Lisp_Object | |
| 94926 | 2071 font_sort_entites (vec, prefer, frame, spec, best_only) |
| 90400 | 2072 Lisp_Object vec, prefer, frame, spec; |
| 94926 | 2073 int best_only; |
| 90400 | 2074 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2075 Lisp_Object prefer_prop[FONT_SPEC_MAX]; |
| 90400 | 2076 int len, i; |
| 2077 struct font_sort_data *data; | |
| 94926 | 2078 Lisp_Object alternate_families = Qnil; |
| 2079 unsigned best_score; | |
| 2080 Lisp_Object best_entity; | |
| 90400 | 2081 USE_SAFE_ALLOCA; |
| 2082 | |
| 2083 len = ASIZE (vec); | |
| 2084 if (len <= 1) | |
| 94926 | 2085 return best_only ? AREF (vec, 0) : vec; |
| 2086 | |
| 2087 for (i = FONT_FOUNDRY_INDEX; i <= FONT_DPI_INDEX; i++) | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2088 prefer_prop[i] = AREF (prefer, i); |
| 90400 | 2089 |
| 2090 if (! NILP (spec)) | |
| 2091 { | |
| 94926 | 2092 /* A font driver may return a font that has a property value |
| 2093 different from the value specified in SPEC if the driver | |
| 2094 thinks they are the same. That happens, for instance, such a | |
| 2095 generic family name as "serif" is specified. So, to ignore | |
| 2096 such a difference, for all properties specified in SPEC, set | |
| 2097 the corresponding properties in PREFER_PROP to nil. */ | |
| 2098 for (i = FONT_FOUNDRY_INDEX; i <= FONT_REGISTRY_INDEX; i++) | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2099 if (! NILP (AREF (spec, i))) |
| 94926 | 2100 prefer_prop[i] = Qnil; |
| 90400 | 2101 } |
| 2102 | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2103 if (FLOATP (prefer_prop[FONT_SIZE_INDEX])) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2104 prefer_prop[FONT_SIZE_INDEX] |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2105 = make_number (font_pixel_size (XFRAME (frame), prefer)); |
| 94926 | 2106 if (! NILP (prefer_prop[FONT_FAMILY_INDEX])) |
| 2107 { | |
| 2108 alternate_families | |
| 2109 = Fassoc_string (prefer_prop[FONT_FAMILY_INDEX], | |
| 2110 Vface_alternative_font_family_alist, Qt); | |
| 2111 if (CONSP (alternate_families)) | |
| 2112 alternate_families = XCDR (alternate_families); | |
| 2113 } | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2114 |
| 90400 | 2115 /* Scoring and sorting. */ |
| 2116 SAFE_ALLOCA (data, struct font_sort_data *, (sizeof *data) * len); | |
| 94926 | 2117 best_score = 0xFFFFFFFF; |
| 2118 best_entity = Qnil; | |
| 90400 | 2119 for (i = 0; i < len; i++) |
| 2120 { | |
| 2121 data[i].entity = AREF (vec, i); | |
| 94926 | 2122 data[i].score = font_score (data[i].entity, prefer_prop, |
| 2123 alternate_families); | |
| 2124 if (best_only && best_score > data[i].score) | |
| 2125 { | |
| 2126 best_score = data[i].score; | |
| 2127 best_entity = data[i].entity; | |
| 2128 if (best_score == 0) | |
| 2129 break; | |
| 2130 } | |
| 90400 | 2131 } |
| 94926 | 2132 if (NILP (best_entity)) |
| 2133 { | |
| 2134 qsort (data, len, sizeof *data, font_compare); | |
| 2135 for (i = 0; i < len; i++) | |
| 2136 ASET (vec, i, data[i].entity); | |
| 2137 } | |
| 2138 else | |
| 2139 vec = best_entity; | |
| 90400 | 2140 SAFE_FREE (); |
| 2141 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2142 font_add_log ("sort-by", prefer, vec); |
| 90400 | 2143 return vec; |
| 2144 } | |
| 2145 | |
| 2146 | |
| 2147 /* API of Font Service Layer. */ | |
| 2148 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2149 /* Reflect ORDER (see the variable font_sort_order in xfaces.c) to |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2150 sort_shift_bits. Finternal_set_font_selection_order calls this |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2151 function with font_sort_order after setting up it. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2152 |
| 90400 | 2153 void |
| 2154 font_update_sort_order (order) | |
| 2155 int *order; | |
| 2156 { | |
| 94926 | 2157 int i, shift_bits; |
| 2158 | |
| 2159 for (i = 0, shift_bits = 21; i < 4; i++, shift_bits -= 7) | |
| 90400 | 2160 { |
| 2161 int xlfd_idx = order[i]; | |
| 2162 | |
| 2163 if (xlfd_idx == XLFD_WEIGHT_INDEX) | |
| 2164 sort_shift_bits[FONT_WEIGHT_INDEX] = shift_bits; | |
| 2165 else if (xlfd_idx == XLFD_SLANT_INDEX) | |
| 2166 sort_shift_bits[FONT_SLANT_INDEX] = shift_bits; | |
| 2167 else if (xlfd_idx == XLFD_SWIDTH_INDEX) | |
| 2168 sort_shift_bits[FONT_WIDTH_INDEX] = shift_bits; | |
| 2169 else | |
| 2170 sort_shift_bits[FONT_SIZE_INDEX] = shift_bits; | |
| 2171 } | |
| 2172 } | |
| 2173 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2174 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2175 /* Check if ENTITY matches with the font specification SPEC. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2176 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2177 int |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2178 font_match_p (spec, entity) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2179 Lisp_Object spec, entity; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2180 { |
| 94926 | 2181 Lisp_Object prefer_prop[FONT_SPEC_MAX]; |
| 2182 Lisp_Object alternate_families = Qnil; | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2183 int i; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2184 |
| 94926 | 2185 for (i = FONT_FOUNDRY_INDEX; i <= FONT_SIZE_INDEX; i++) |
| 2186 prefer_prop[i] = AREF (spec, i); | |
| 2187 if (FLOATP (prefer_prop[FONT_SIZE_INDEX])) | |
| 2188 prefer_prop[FONT_SIZE_INDEX] | |
| 2189 = make_number (font_pixel_size (XFRAME (selected_frame), spec)); | |
| 2190 if (! NILP (prefer_prop[FONT_FAMILY_INDEX])) | |
| 2191 { | |
| 2192 alternate_families | |
| 2193 = Fassoc_string (prefer_prop[FONT_FAMILY_INDEX], | |
| 2194 Vface_alternative_font_family_alist, Qt); | |
| 2195 if (CONSP (alternate_families)) | |
| 2196 alternate_families = XCDR (alternate_families); | |
| 2197 } | |
| 2198 | |
| 2199 return (font_score (entity, prefer_prop, alternate_families) == 0); | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2200 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2201 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2202 |
| 94926 | 2203 /* CHeck a lispy font object corresponding to FONT. */ |
| 2204 | |
| 2205 int | |
| 2206 font_check_object (font) | |
| 90400 | 2207 struct font *font; |
| 2208 { | |
| 2209 Lisp_Object tail, elt; | |
| 2210 | |
| 94926 | 2211 for (tail = font->props[FONT_OBJLIST_INDEX]; CONSP (tail); |
| 90400 | 2212 tail = XCDR (tail)) |
| 2213 { | |
| 2214 elt = XCAR (tail); | |
| 94926 | 2215 if (font == XFONT_OBJECT (elt)) |
| 2216 return 1; | |
| 90400 | 2217 } |
| 94926 | 2218 return 0; |
| 90400 | 2219 } |
| 2220 | |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2221 |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2222 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2223 /* Font cache |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2224 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2225 Each font backend has the callback function get_cache, and it |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2226 returns a cons cell of which cdr part can be freely used for |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2227 caching fonts. The cons cell may be shared by multiple frames |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2228 and/or multiple font drivers. So, we arrange the cdr part as this: |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2229 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2230 ((DRIVER-TYPE NUM-FRAMES FONT-CACHE-DATA ...) ...) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2231 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2232 where DRIVER-TYPE is a symbol such as `x', `xft', etc., NUM-FRAMES |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2233 is a number frames sharing this cache, and FONT-CACHE-DATA is a |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2234 cons (FONT-SPEC FONT-ENTITY ...). */ |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2235 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2236 static void font_prepare_cache P_ ((FRAME_PTR, struct font_driver *)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2237 static void font_finish_cache P_ ((FRAME_PTR, struct font_driver *)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2238 static Lisp_Object font_get_cache P_ ((FRAME_PTR, struct font_driver *)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2239 static void font_clear_cache P_ ((FRAME_PTR, Lisp_Object, |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2240 struct font_driver *)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2241 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2242 static void |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2243 font_prepare_cache (f, driver) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2244 FRAME_PTR f; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2245 struct font_driver *driver; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2246 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2247 Lisp_Object cache, val; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2248 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2249 cache = driver->get_cache (f); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2250 val = XCDR (cache); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2251 while (CONSP (val) && ! EQ (XCAR (XCAR (val)), driver->type)) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2252 val = XCDR (val); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2253 if (NILP (val)) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2254 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2255 val = Fcons (driver->type, Fcons (make_number (1), Qnil)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2256 XSETCDR (cache, Fcons (val, XCDR (cache))); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2257 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2258 else |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2259 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2260 val = XCDR (XCAR (val)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2261 XSETCAR (val, make_number (XINT (XCAR (val)) + 1)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2262 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2263 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2264 |
| 91909 | 2265 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2266 static void |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2267 font_finish_cache (f, driver) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2268 FRAME_PTR f; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2269 struct font_driver *driver; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2270 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2271 Lisp_Object cache, val, tmp; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2272 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2273 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2274 cache = driver->get_cache (f); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2275 val = XCDR (cache); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2276 while (CONSP (val) && ! EQ (XCAR (XCAR (val)), driver->type)) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2277 cache = val, val = XCDR (val); |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2278 font_assert (! NILP (val)); |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2279 tmp = XCDR (XCAR (val)); |
| 91909 | 2280 XSETCAR (tmp, make_number (XINT (XCAR (tmp)) - 1)); |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2281 if (XINT (XCAR (tmp)) == 0) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2282 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2283 font_clear_cache (f, XCAR (val), driver); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2284 XSETCDR (cache, XCDR (val)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2285 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2286 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2287 |
| 91909 | 2288 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2289 static Lisp_Object |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2290 font_get_cache (f, driver) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2291 FRAME_PTR f; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2292 struct font_driver *driver; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2293 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2294 Lisp_Object val = driver->get_cache (f); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2295 Lisp_Object type = driver->type; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2296 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2297 font_assert (CONSP (val)); |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2298 for (val = XCDR (val); ! EQ (XCAR (XCAR (val)), type); val = XCDR (val)); |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2299 font_assert (CONSP (val)); |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2300 /* VAL = ((DRIVER-TYPE NUM-FRAMES FONT-CACHE-DATA ...) ...) */ |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2301 val = XCDR (XCAR (val)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2302 return val; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2303 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2304 |
| 91909 | 2305 static int num_fonts; |
| 2306 | |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2307 static void |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2308 font_clear_cache (f, cache, driver) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2309 FRAME_PTR f; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2310 Lisp_Object cache; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2311 struct font_driver *driver; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2312 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2313 Lisp_Object tail, elt; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
2314 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2315 /* CACHE = (DRIVER-TYPE NUM-FRAMES FONT-CACHE-DATA ...) */ |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2316 for (tail = XCDR (XCDR (cache)); CONSP (tail); tail = XCDR (tail)) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2317 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2318 elt = XCAR (tail); |
|
94968
e87ef440216b
(font_clear_cache): Check if the cached vector of entities is nil
Kenichi Handa <handa@m17n.org>
parents:
94964
diff
changeset
|
2319 if (CONSP (elt) && FONT_SPEC_P (XCAR (elt)) && VECTORP (XCDR (elt))) |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2320 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2321 Lisp_Object vec = XCDR (elt); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2322 int i; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2323 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2324 for (i = 0; i < ASIZE (vec); i++) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2325 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2326 Lisp_Object entity = AREF (vec, i); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2327 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2328 if (EQ (driver->type, AREF (entity, FONT_TYPE_INDEX))) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2329 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2330 Lisp_Object objlist = AREF (entity, FONT_OBJLIST_INDEX); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2331 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2332 for (; CONSP (objlist); objlist = XCDR (objlist)) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2333 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2334 Lisp_Object val = XCAR (objlist); |
| 94926 | 2335 struct font *font = XFONT_OBJECT (val); |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2336 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2337 font_assert (font && driver == font->driver); |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2338 driver->close (f, font); |
| 91909 | 2339 num_fonts--; |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2340 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2341 if (driver->free_entity) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2342 driver->free_entity (entity); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2343 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2344 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2345 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2346 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2347 XSETCDR (cache, Qnil); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2348 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2349 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2350 |
| 90400 | 2351 static Lisp_Object scratch_font_spec, scratch_font_prefer; |
| 2352 | |
| 94926 | 2353 Lisp_Object |
| 2354 font_delete_unmatched (list, spec, size) | |
| 2355 Lisp_Object list, spec; | |
| 2356 int size; | |
| 2357 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2358 Lisp_Object entity, val; |
| 94926 | 2359 enum font_property_index prop; |
| 2360 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2361 for (val = Qnil; CONSP (list); list = XCDR (list)) |
| 94926 | 2362 { |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2363 entity = XCAR (list); |
| 94926 | 2364 for (prop = FONT_WEIGHT_INDEX; prop < FONT_SIZE_INDEX; prop++) |
| 2365 if (INTEGERP (AREF (spec, prop)) | |
| 2366 && ((XINT (AREF (spec, prop)) >> 8) | |
| 2367 != (XINT (AREF (entity, prop)) >> 8))) | |
| 2368 prop = FONT_SPEC_MAX; | |
| 2369 if (prop++ <= FONT_SIZE_INDEX | |
| 2370 && size | |
| 2371 && XINT (AREF (entity, FONT_SIZE_INDEX)) > 0) | |
| 2372 { | |
| 2373 int diff = XINT (AREF (entity, FONT_SIZE_INDEX)) - size; | |
| 2374 | |
| 2375 if (diff != 0 | |
| 2376 && (diff < 0 ? -diff > FONT_PIXEL_SIZE_QUANTUM | |
| 2377 : diff > FONT_PIXEL_SIZE_QUANTUM)) | |
| 2378 prop = FONT_SPEC_MAX; | |
| 2379 } | |
| 2380 if (prop < FONT_SPEC_MAX | |
| 2381 && INTEGERP (AREF (spec, FONT_SPACING_INDEX)) | |
| 2382 && ! EQ (AREF (spec, FONT_SPACING_INDEX), | |
| 2383 AREF (entity, FONT_SPACING_INDEX))) | |
| 2384 prop = FONT_SPEC_MAX; | |
| 2385 if (prop < FONT_SPEC_MAX) | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2386 val = Fcons (entity, val); |
| 94926 | 2387 } |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2388 return val; |
| 94926 | 2389 } |
| 2390 | |
| 2391 | |
| 2392 /* Return a vector of font-entities matching with SPEC on FRAME. */ | |
| 2393 | |
| 2394 Lisp_Object | |
| 90400 | 2395 font_list_entities (frame, spec) |
| 2396 Lisp_Object frame, spec; | |
| 2397 { | |
| 2398 FRAME_PTR f = XFRAME (frame); | |
| 2399 struct font_driver_list *driver_list = f->font_driver_list; | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2400 Lisp_Object ftype, family, alternate_familes, val; |
| 94926 | 2401 Lisp_Object *vec; |
| 2402 int size; | |
| 2403 int need_filtering = 0; | |
| 2404 int n_family = 1; | |
| 90400 | 2405 int i; |
| 2406 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2407 font_assert (FONT_SPEC_P (spec)); |
| 90400 | 2408 |
| 2409 family = AREF (spec, FONT_FAMILY_INDEX); | |
| 2410 if (NILP (family)) | |
| 2411 alternate_familes = Qnil; | |
| 2412 else | |
| 2413 { | |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
2414 alternate_familes = Fassoc_string (family, |
| 94926 | 2415 Vface_alternative_font_family_alist, |
| 2416 Qt); | |
| 90400 | 2417 if (! NILP (alternate_familes)) |
| 2418 alternate_familes = XCDR (alternate_familes); | |
| 94926 | 2419 n_family += XINT (Flength (alternate_familes)); |
| 90400 | 2420 } |
| 94926 | 2421 |
| 2422 if (INTEGERP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2423 size = XINT (AREF (spec, FONT_SIZE_INDEX)); | |
| 2424 else if (FLOATP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2425 size = font_pixel_size (f, spec); | |
| 2426 else | |
| 2427 size = 0; | |
| 2428 | |
| 90400 | 2429 ftype = AREF (spec, FONT_TYPE_INDEX); |
|
95104
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2430 for (i = 1; i <= FONT_REGISTRY_INDEX; i++) |
| 94926 | 2431 ASET (scratch_font_spec, i, AREF (spec, i)); |
| 2432 for (; i < FONT_EXTRA_INDEX; i++) | |
| 2433 { | |
| 2434 ASET (scratch_font_spec, i, Qnil); | |
| 2435 if (! NILP (AREF (spec, i))) | |
| 2436 need_filtering = 1; | |
| 2437 } | |
| 2438 ASET (scratch_font_spec, FONT_EXTRA_INDEX, AREF (spec, FONT_EXTRA_INDEX)); | |
| 2439 | |
| 2440 vec = alloca (sizeof (Lisp_Object) * num_font_drivers * n_family); | |
| 2441 if (! vec) | |
| 2442 return null_vector; | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
2443 |
| 90400 | 2444 for (i = 0; driver_list; driver_list = driver_list->next) |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
2445 if (driver_list->on |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
2446 && (NILP (ftype) || EQ (driver_list->driver->type, ftype))) |
| 90400 | 2447 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2448 Lisp_Object cache = font_get_cache (f, driver_list->driver); |
| 90400 | 2449 Lisp_Object tail = alternate_familes; |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2450 |
| 90400 | 2451 while (1) |
| 2452 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2453 val = assoc_no_quit (scratch_font_spec, XCDR (cache)); |
|
95104
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2454 if (CONSP (val)) |
| 90400 | 2455 val = XCDR (val); |
| 2456 else | |
| 2457 { | |
| 94926 | 2458 Lisp_Object copy; |
| 2459 | |
| 2460 val = driver_list->driver->list (frame, scratch_font_spec); | |
| 2461 copy = Fcopy_font_spec (scratch_font_spec); | |
| 2462 XSETCDR (cache, Fcons (Fcons (copy, val), XCDR (cache))); | |
| 90400 | 2463 } |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2464 if (! NILP (val) && need_filtering) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2465 val = font_delete_unmatched (val, spec, size); |
| 94926 | 2466 if (! NILP (val)) |
| 90400 | 2467 { |
| 2468 vec[i++] = val; | |
| 2469 break; | |
| 2470 } | |
| 2471 if (NILP (tail)) | |
| 2472 break; | |
| 94926 | 2473 ASET (scratch_font_spec, FONT_FAMILY_INDEX, |
| 2474 Fintern (XCAR (tail), Qnil)); | |
| 90400 | 2475 tail = XCDR (tail); |
| 2476 } | |
| 2477 } | |
| 94926 | 2478 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2479 val = (i > 0 ? Fvconcat (i, vec) : null_vector); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2480 font_add_log ("list", spec, val); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2481 return (val); |
| 90400 | 2482 } |
| 2483 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2484 |
| 94926 | 2485 /* Return a font entity matching with SPEC on FRAME. ATTRS, if non |
| 2486 nil, is an array of face's attributes, which specifies preferred | |
| 2487 font-related attributes. */ | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2488 |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2489 static Lisp_Object |
| 94926 | 2490 font_matching_entity (f, attrs, spec) |
| 2491 FRAME_PTR f; | |
| 2492 Lisp_Object *attrs, spec; | |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2493 { |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2494 struct font_driver_list *driver_list = f->font_driver_list; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2495 Lisp_Object ftype, size, entity; |
| 94926 | 2496 Lisp_Object frame; |
| 2497 | |
| 2498 XSETFRAME (frame, f); | |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2499 ftype = AREF (spec, FONT_TYPE_INDEX); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2500 size = AREF (spec, FONT_SIZE_INDEX); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2501 if (FLOATP (size)) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2502 ASET (spec, FONT_SIZE_INDEX, make_number (font_pixel_size (f, spec))); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2503 entity = Qnil; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2504 for (; driver_list; driver_list = driver_list->next) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2505 if (driver_list->on |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2506 && (NILP (ftype) || EQ (driver_list->driver->type, ftype))) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2507 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2508 Lisp_Object cache = font_get_cache (f, driver_list->driver); |
|
95104
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2509 Lisp_Object copy; |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2510 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2511 ASET (spec, FONT_TYPE_INDEX, driver_list->driver->type); |
| 94926 | 2512 entity = assoc_no_quit (spec, XCDR (cache)); |
|
95104
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2513 if (CONSP (entity)) |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2514 entity = XCDR (entity); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2515 else |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2516 { |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2517 entity = driver_list->driver->match (frame, spec); |
|
95104
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2518 copy = Fcopy_font_spec (spec); |
|
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2519 ASET (copy, FONT_TYPE_INDEX, driver_list->driver->type); |
|
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2520 XSETCDR (cache, Fcons (Fcons (copy, entity), XCDR (cache))); |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2521 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2522 if (! NILP (entity)) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2523 break; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2524 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2525 ASET (spec, FONT_TYPE_INDEX, ftype); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2526 ASET (spec, FONT_SIZE_INDEX, size); |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2527 font_add_log ("match", spec, entity); |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2528 return entity; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2529 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2530 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2531 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2532 /* Open a font of ENTITY and PIXEL_SIZE on frame F, and return the |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2533 opened font object. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2534 |
| 90400 | 2535 static Lisp_Object |
| 2536 font_open_entity (f, entity, pixel_size) | |
| 2537 FRAME_PTR f; | |
| 2538 Lisp_Object entity; | |
| 2539 int pixel_size; | |
| 2540 { | |
| 2541 struct font_driver_list *driver_list; | |
| 91909 | 2542 Lisp_Object objlist, size, val, font_object; |
| 90400 | 2543 struct font *font; |
| 94926 | 2544 int min_width; |
| 2545 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2546 font_assert (FONT_ENTITY_P (entity)); |
| 90400 | 2547 size = AREF (entity, FONT_SIZE_INDEX); |
| 2548 if (XINT (size) != 0) | |
| 2549 pixel_size = XINT (size); | |
| 2550 | |
| 2551 for (objlist = AREF (entity, FONT_OBJLIST_INDEX); CONSP (objlist); | |
| 2552 objlist = XCDR (objlist)) | |
| 94926 | 2553 if (XFONT_OBJECT (XCAR (objlist))->pixel_size == pixel_size) |
| 2554 return XCAR (objlist); | |
| 2555 | |
| 2556 val = AREF (entity, FONT_TYPE_INDEX); | |
| 2557 for (driver_list = f->font_driver_list; | |
| 2558 driver_list && ! EQ (driver_list->driver->type, val); | |
| 2559 driver_list = driver_list->next); | |
| 2560 if (! driver_list) | |
| 2561 return Qnil; | |
| 2562 | |
| 2563 font_object = driver_list->driver->open (f, entity, pixel_size); | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2564 font_add_log ("open", entity, font_object); |
| 91909 | 2565 if (NILP (font_object)) |
| 94926 | 2566 return Qnil; |
| 2567 ASET (entity, FONT_OBJLIST_INDEX, | |
| 2568 Fcons (font_object, AREF (entity, FONT_OBJLIST_INDEX))); | |
| 2569 ASET (font_object, FONT_OBJLIST_INDEX, AREF (entity, FONT_OBJLIST_INDEX)); | |
| 2570 num_fonts++; | |
| 2571 | |
| 2572 font = XFONT_OBJECT (font_object); | |
| 2573 min_width = (font->min_width ? font->min_width | |
| 2574 : font->average_width ? font->average_width | |
| 2575 : font->space_width ? font->space_width | |
| 2576 : 1); | |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2577 #ifdef HAVE_WINDOW_SYSTEM |
| 94926 | 2578 FRAME_X_DISPLAY_INFO (f)->n_fonts++; |
| 2579 if (FRAME_X_DISPLAY_INFO (f)->n_fonts == 1) | |
| 91909 | 2580 { |
| 94926 | 2581 FRAME_SMALLEST_CHAR_WIDTH (f) = min_width; |
| 2582 FRAME_SMALLEST_FONT_HEIGHT (f) = font->height; | |
| 2583 fonts_changed_p = 1; | |
| 91909 | 2584 } |
| 94926 | 2585 else |
| 2586 { | |
| 2587 if (FRAME_SMALLEST_CHAR_WIDTH (f) > min_width) | |
| 2588 FRAME_SMALLEST_CHAR_WIDTH (f) = min_width, fonts_changed_p = 1; | |
| 2589 if (FRAME_SMALLEST_FONT_HEIGHT (f) > font->height) | |
| 2590 FRAME_SMALLEST_FONT_HEIGHT (f) = font->height, fonts_changed_p = 1; | |
| 2591 } | |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2592 #endif |
| 91909 | 2593 |
| 2594 return font_object; | |
| 90400 | 2595 } |
| 2596 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2597 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2598 /* Close FONT_OBJECT that is opened on frame F. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2599 |
| 90400 | 2600 void |
| 2601 font_close_object (f, font_object) | |
| 2602 FRAME_PTR f; | |
| 2603 Lisp_Object font_object; | |
| 2604 { | |
| 94926 | 2605 struct font *font = XFONT_OBJECT (font_object); |
| 90541 | 2606 Lisp_Object objlist; |
| 90400 | 2607 Lisp_Object tail, prev = Qnil; |
| 2608 | |
| 94926 | 2609 objlist = AREF (font_object, FONT_OBJLIST_INDEX); |
| 90400 | 2610 for (prev = Qnil, tail = objlist; CONSP (tail); |
| 2611 prev = tail, tail = XCDR (tail)) | |
| 2612 if (EQ (font_object, XCAR (tail))) | |
| 2613 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2614 font_add_log ("close", font_object, Qnil); |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2615 font->driver->close (f, font); |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2616 #ifdef HAVE_WINDOW_SYSTEM |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2617 font_assert (FRAME_X_DISPLAY_INFO (f)->n_fonts); |
| 94926 | 2618 FRAME_X_DISPLAY_INFO (f)->n_fonts--; |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2619 #endif |
| 90541 | 2620 if (NILP (prev)) |
| 94926 | 2621 ASET (font_object, FONT_OBJLIST_INDEX, XCDR (objlist)); |
| 90541 | 2622 else |
| 2623 XSETCDR (prev, XCDR (objlist)); | |
| 91909 | 2624 num_fonts--; |
| 90541 | 2625 return; |
| 90400 | 2626 } |
| 90541 | 2627 abort (); |
| 90400 | 2628 } |
| 2629 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2630 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2631 /* Return 1 if FONT on F has a glyph for character C, 0 if not, -1 if |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2632 FONT is a font-entity and it must be opened to check. */ |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2633 |
| 90400 | 2634 int |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2635 font_has_char (f, font, c) |
| 90400 | 2636 FRAME_PTR f; |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2637 Lisp_Object font; |
| 90400 | 2638 int c; |
| 2639 { | |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2640 struct font *fontp; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2641 |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2642 if (FONT_ENTITY_P (font)) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2643 { |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2644 Lisp_Object type = AREF (font, FONT_TYPE_INDEX); |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2645 struct font_driver_list *driver_list; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2646 |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2647 for (driver_list = f->font_driver_list; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2648 driver_list && ! EQ (driver_list->driver->type, type); |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2649 driver_list = driver_list->next); |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2650 if (! driver_list) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2651 return 0; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2652 if (! driver_list->driver->has_char) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2653 return -1; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2654 return driver_list->driver->has_char (font, c); |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2655 } |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2656 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2657 font_assert (FONT_OBJECT_P (font)); |
| 94926 | 2658 fontp = XFONT_OBJECT (font); |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2659 if (fontp->driver->has_char) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2660 { |
| 94926 | 2661 int result = fontp->driver->has_char (font, c); |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2662 |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2663 if (result >= 0) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2664 return result; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2665 } |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2666 return (fontp->driver->encode_char (fontp, c) != FONT_INVALID_CODE); |
| 90400 | 2667 } |
| 2668 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2669 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2670 /* Return the glyph ID of FONT_OBJECT for character C. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2671 |
| 90400 | 2672 unsigned |
| 2673 font_encode_char (font_object, c) | |
| 2674 Lisp_Object font_object; | |
| 2675 int c; | |
| 2676 { | |
| 94926 | 2677 struct font *font; |
| 2678 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2679 font_assert (FONT_OBJECT_P (font_object)); |
| 94926 | 2680 font = XFONT_OBJECT (font_object); |
| 90400 | 2681 return font->driver->encode_char (font, c); |
| 2682 } | |
| 2683 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2684 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2685 /* Return the name of FONT_OBJECT. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2686 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2687 Lisp_Object |
| 90400 | 2688 font_get_name (font_object) |
| 2689 Lisp_Object font_object; | |
| 2690 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2691 font_assert (FONT_OBJECT_P (font_object)); |
| 94926 | 2692 return AREF (font_object, FONT_NAME_INDEX); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2693 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2694 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2695 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2696 /* Return the specification of FONT_OBJECT. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2697 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2698 Lisp_Object |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2699 font_get_spec (font_object) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2700 Lisp_Object font_object; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2701 { |
| 94926 | 2702 Lisp_Object spec = font_make_spec (); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2703 int i; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2704 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2705 for (i = 0; i < FONT_SIZE_INDEX; i++) |
| 94926 | 2706 ASET (spec, i, AREF (font_object, i)); |
| 2707 ASET (spec, FONT_SIZE_INDEX, | |
| 2708 make_number (XFONT_OBJECT (font_object)->pixel_size)); | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2709 return spec; |
| 90400 | 2710 } |
| 2711 | |
| 2712 Lisp_Object | |
| 94926 | 2713 font_spec_from_name (font_name) |
| 2714 Lisp_Object font_name; | |
| 2715 { | |
| 2716 Lisp_Object args[2]; | |
| 2717 | |
| 2718 args[0] = QCname; | |
| 2719 args[1] = font_name; | |
| 2720 return Ffont_spec (2, args); | |
| 2721 } | |
| 2722 | |
| 2723 | |
| 2724 void | |
| 2725 font_clear_prop (attrs, prop) | |
| 2726 Lisp_Object *attrs; | |
| 2727 enum font_property_index prop; | |
| 2728 { | |
| 2729 Lisp_Object font = attrs[LFACE_FONT_INDEX]; | |
| 2730 | |
| 2731 if (! FONTP (font)) | |
| 2732 return; | |
| 2733 if (NILP (AREF (font, prop)) | |
| 2734 && prop != FONT_FAMILY_INDEX && prop != FONT_FAMILY_INDEX) | |
| 2735 return; | |
| 2736 font = Fcopy_font_spec (font); | |
| 2737 ASET (font, prop, Qnil); | |
| 2738 if (prop == FONT_FAMILY_INDEX) | |
| 2739 { | |
| 2740 ASET (font, FONT_FOUNDRY_INDEX, Qnil); | |
| 2741 ASET (font, FONT_ADSTYLE_INDEX, Qnil); | |
| 2742 ASET (font, FONT_SIZE_INDEX, Qnil); | |
| 2743 ASET (font, FONT_DPI_INDEX, Qnil); | |
| 2744 ASET (font, FONT_SPACING_INDEX, Qnil); | |
| 2745 ASET (font, FONT_AVGWIDTH_INDEX, Qnil); | |
| 2746 } | |
| 2747 else if (prop == FONT_SIZE_INDEX) | |
| 2748 { | |
| 2749 ASET (font, FONT_DPI_INDEX, Qnil); | |
| 2750 ASET (font, FONT_SPACING_INDEX, Qnil); | |
| 2751 ASET (font, FONT_AVGWIDTH_INDEX, Qnil); | |
| 2752 } | |
| 2753 attrs[LFACE_FONT_INDEX] = font; | |
| 2754 } | |
| 2755 | |
| 2756 void | |
| 2757 font_update_lface (f, attrs) | |
| 2758 FRAME_PTR f; | |
| 2759 Lisp_Object *attrs; | |
| 90400 | 2760 { |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2761 Lisp_Object spec; |
| 94926 | 2762 |
| 2763 spec = attrs[LFACE_FONT_INDEX]; | |
| 2764 if (! FONT_SPEC_P (spec)) | |
| 2765 return; | |
| 2766 | |
| 2767 if (! NILP (AREF (spec, FONT_FOUNDRY_INDEX)) | |
| 2768 || ! NILP (AREF (spec, FONT_FAMILY_INDEX))) | |
| 2769 { | |
| 2770 Lisp_Object family; | |
| 2771 | |
| 2772 if (NILP (AREF (spec, FONT_FOUNDRY_INDEX))) | |
| 2773 family = AREF (spec, FONT_FAMILY_INDEX); | |
| 2774 else if (NILP (AREF (spec, FONT_FAMILY_INDEX))) | |
| 2775 family = concat2 (SYMBOL_NAME (AREF (spec, FONT_FOUNDRY_INDEX)), | |
| 2776 build_string ("-*")); | |
| 2777 else | |
| 2778 family = concat3 (SYMBOL_NAME (AREF (spec, FONT_FOUNDRY_INDEX)), | |
| 2779 build_string ("-"), | |
| 2780 SYMBOL_NAME (AREF (spec, FONT_FAMILY_INDEX))); | |
| 2781 attrs[LFACE_FAMILY_INDEX] = family; | |
| 2782 } | |
| 2783 if (! NILP (AREF (spec, FONT_WEIGHT_INDEX))) | |
| 2784 attrs[LFACE_WEIGHT_INDEX] = FONT_WEIGHT_FOR_FACE (spec); | |
| 2785 if (! NILP (AREF (spec, FONT_SLANT_INDEX))) | |
| 2786 attrs[LFACE_SLANT_INDEX] = FONT_SLANT_FOR_FACE (spec);; | |
| 2787 if (! NILP (AREF (spec, FONT_WIDTH_INDEX))) | |
| 2788 attrs[LFACE_SWIDTH_INDEX] = FONT_WIDTH_FOR_FACE (spec); | |
| 2789 if (! NILP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2790 { | |
| 2791 int point; | |
| 2792 | |
| 2793 if (INTEGERP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2794 { | |
| 2795 Lisp_Object val; | |
| 2796 int dpi = f->resy; | |
| 2797 | |
| 2798 val = Ffont_get (spec, QCdpi); | |
| 2799 if (! NILP (val)) | |
| 2800 dpi = XINT (val); | |
| 2801 point = PIXEL_TO_POINT (XINT (AREF (spec, FONT_SIZE_INDEX)) * 10, | |
| 2802 dpi); | |
| 2803 } | |
| 2804 else if (FLOATP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2805 point = XFLOAT_DATA (AREF (spec, FONT_SIZE_INDEX)) * 10; | |
| 2806 attrs[LFACE_HEIGHT_INDEX] = make_number (point); | |
| 2807 } | |
| 90400 | 2808 } |
| 2809 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2810 |
| 94926 | 2811 /* Return a font-entity satisfying SPEC and best matching with face's |
| 2812 font related attributes in ATTRS. C, if not negative, is a | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2813 character that the entity must support. */ |
| 90400 | 2814 |
| 2815 Lisp_Object | |
| 94926 | 2816 font_find_for_lface (f, attrs, spec, c) |
| 90400 | 2817 FRAME_PTR f; |
| 94926 | 2818 Lisp_Object *attrs; |
| 90400 | 2819 Lisp_Object spec; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2820 int c; |
| 90400 | 2821 { |
| 94926 | 2822 Lisp_Object frame, entities, val, props[FONT_REGISTRY_INDEX + 1] ; |
| 2823 Lisp_Object size; | |
|
91353
b93ade1a3602
(font_find_for_lface): Check if the character C is
Kenichi Handa <handa@m17n.org>
parents:
91350
diff
changeset
|
2824 int i, result; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2825 |
| 94926 | 2826 if (c >= 0) |
| 2827 { | |
| 2828 Lisp_Object registry = AREF (spec, FONT_REGISTRY_INDEX); | |
| 2829 struct charset *encoding, *repertory; | |
| 2830 | |
| 2831 if (font_registry_charsets (registry, &encoding, &repertory) < 0) | |
| 2832 return Qnil; | |
| 2833 if (repertory) | |
| 2834 { | |
| 2835 if (ENCODE_CHAR (repertory, c) == CHARSET_INVALID_CODE (repertory)) | |
| 2836 return Qnil; | |
| 2837 /* Any font of this registry support C. So, let's | |
| 2838 suppress the further checking. */ | |
| 2839 c = -1; | |
| 2840 } | |
| 2841 else if (c > encoding->max_char) | |
| 2842 return Qnil; | |
| 2843 } | |
| 2844 | |
|
90507
4a6034a7c870
(font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents:
90503
diff
changeset
|
2845 XSETFRAME (frame, f); |
| 94926 | 2846 size = AREF (spec, FONT_SIZE_INDEX); |
| 2847 ASET (spec, FONT_SIZE_INDEX, Qnil); | |
| 2848 entities = font_list_entities (frame, spec); | |
| 2849 ASET (spec, FONT_SIZE_INDEX, size); | |
| 2850 if (ASIZE (entities) == 0) | |
| 2851 return Qnil; | |
| 2852 if (ASIZE (entities) == 1) | |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2853 { |
| 94926 | 2854 if (c < 0) |
| 2855 return AREF (entities, 0); | |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2856 } |
|
90507
4a6034a7c870
(font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents:
90503
diff
changeset
|
2857 else |
| 90400 | 2858 { |
|
90507
4a6034a7c870
(font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents:
90503
diff
changeset
|
2859 /* Sort fonts by properties specified in LFACE. */ |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
2860 Lisp_Object prefer = scratch_font_prefer; |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2861 |
| 94926 | 2862 for (i = 0; i < FONT_EXTRA_INDEX; i++) |
| 2863 ASET (prefer, i, AREF (spec, i)); | |
|
95013
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2864 if (FONTP (attrs[LFACE_FONT_INDEX])) |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2865 { |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2866 Lisp_Object face_font = attrs[LFACE_FONT_INDEX]; |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2867 |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2868 for (i = 0; i < FONT_EXTRA_INDEX; i++) |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2869 if (NILP (AREF (prefer, i))) |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2870 ASET (prefer, i, AREF (face_font, i)); |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2871 } |
| 94926 | 2872 if (NILP (AREF (prefer, FONT_FAMILY_INDEX))) |
| 2873 font_parse_family_registry (attrs[LFACE_FAMILY_INDEX], Qnil, prefer); | |
| 2874 if (NILP (AREF (prefer, FONT_WEIGHT_INDEX))) | |
| 2875 FONT_SET_STYLE (prefer, FONT_WEIGHT_INDEX, attrs[LFACE_WEIGHT_INDEX]); | |
| 2876 if (NILP (AREF (prefer, FONT_SLANT_INDEX))) | |
| 2877 FONT_SET_STYLE (prefer, FONT_SLANT_INDEX, attrs[LFACE_SLANT_INDEX]); | |
| 2878 if (NILP (AREF (prefer, FONT_WIDTH_INDEX))) | |
| 2879 FONT_SET_STYLE (prefer, FONT_WIDTH_INDEX, attrs[LFACE_SWIDTH_INDEX]); | |
| 2880 if (INTEGERP (size)) | |
| 2881 ASET (prefer, FONT_SIZE_INDEX, size); | |
| 2882 else if (FLOATP (size)) | |
| 2883 ASET (prefer, FONT_SIZE_INDEX, make_number (font_pixel_size (f, spec))); | |
| 2884 else | |
| 2885 { | |
| 2886 double pt = XINT (attrs[LFACE_HEIGHT_INDEX]); | |
| 2887 int pixel_size = POINT_TO_PIXEL (pt / 10, f->resy); | |
| 2888 ASET (prefer, FONT_SIZE_INDEX, make_number (pixel_size)); | |
| 2889 } | |
| 2890 ASET (spec, FONT_SIZE_INDEX, Qnil); | |
| 2891 entities = font_sort_entites (entities, prefer, frame, spec, c < 0); | |
| 2892 ASET (spec, FONT_SIZE_INDEX, size); | |
| 90400 | 2893 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2894 if (c < 0) |
| 94926 | 2895 return entities; |
| 2896 | |
| 2897 for (i = 0; i < ASIZE (entities); i++) | |
| 2898 { | |
| 2899 int j; | |
| 2900 | |
| 2901 val = AREF (entities, i); | |
| 2902 if (i > 0) | |
| 2903 { | |
| 2904 for (j = FONT_FOUNDRY_INDEX; j <= FONT_REGISTRY_INDEX; j++) | |
| 2905 if (! EQ (AREF (val, j), props[j])) | |
| 2906 break; | |
| 2907 if (j > FONT_REGISTRY_INDEX) | |
| 2908 continue; | |
| 2909 } | |
| 2910 for (j = FONT_FOUNDRY_INDEX; j <= FONT_REGISTRY_INDEX; j++) | |
| 2911 props[j] = AREF (val, j); | |
| 2912 result = font_has_char (f, val, c); | |
| 2913 if (result > 0) | |
| 2914 return val; | |
| 2915 if (result == 0) | |
| 2916 return Qnil; | |
| 2917 val = font_open_for_lface (f, val, attrs, spec); | |
| 2918 if (NILP (val)) | |
| 2919 continue; | |
| 2920 result = font_has_char (f, val, c); | |
| 2921 font_close_object (f, val); | |
| 2922 if (result > 0) | |
| 2923 return AREF (entities, i); | |
| 2924 } | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2925 return Qnil; |
| 90400 | 2926 } |
| 2927 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2928 |
| 90400 | 2929 Lisp_Object |
| 94926 | 2930 font_open_for_lface (f, entity, attrs, spec) |
| 90400 | 2931 FRAME_PTR f; |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2932 Lisp_Object entity; |
| 94926 | 2933 Lisp_Object *attrs; |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2934 Lisp_Object spec; |
| 90400 | 2935 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2936 int size; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2937 |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2938 if (FONT_SPEC_P (spec) && INTEGERP (AREF (spec, FONT_SIZE_INDEX))) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2939 size = XINT (AREF (spec, FONT_SIZE_INDEX)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2940 else |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2941 { |
| 94926 | 2942 double pt = XINT (attrs[LFACE_HEIGHT_INDEX]); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2943 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2944 pt /= 10; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2945 size = POINT_TO_PIXEL (pt, f->resy); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2946 } |
| 90400 | 2947 return font_open_entity (f, entity, size); |
| 2948 } | |
| 2949 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2950 |
| 94926 | 2951 /* Find a font satisfying SPEC and best matching with face's |
| 2952 attributes in ATTRS on FRAME, and return the opened | |
| 2953 font-object. */ | |
| 2954 | |
| 2955 Lisp_Object | |
| 2956 font_load_for_lface (f, attrs, spec) | |
| 90400 | 2957 FRAME_PTR f; |
| 94926 | 2958 Lisp_Object *attrs, spec; |
| 90400 | 2959 { |
| 94926 | 2960 Lisp_Object entity; |
| 2961 | |
| 2962 entity = font_find_for_lface (f, attrs, spec, -1); | |
| 2963 if (NILP (entity)) | |
|
91350
9673276f310c
(font_load_for_face): Handle the case that the font in
Kenichi Handa <handa@m17n.org>
parents:
91337
diff
changeset
|
2964 { |
| 94926 | 2965 /* No font is listed for SPEC, but each font-backend may have |
| 2966 the different criteria about "font matching". So, try | |
| 2967 it. */ | |
| 2968 entity = font_matching_entity (f, attrs, spec); | |
| 2969 if (NILP (entity)) | |
| 2970 return Qnil; | |
|
91350
9673276f310c
(font_load_for_face): Handle the case that the font in
Kenichi Handa <handa@m17n.org>
parents:
91337
diff
changeset
|
2971 } |
| 94926 | 2972 return font_open_for_lface (f, entity, attrs, spec); |
| 90400 | 2973 } |
| 2974 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2975 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2976 /* Make FACE on frame F ready to use the font opened for FACE. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2977 |
| 90400 | 2978 void |
| 2979 font_prepare_for_face (f, face) | |
| 2980 FRAME_PTR f; | |
| 2981 struct face *face; | |
| 2982 { | |
| 94926 | 2983 if (face->font->driver->prepare_face) |
| 2984 face->font->driver->prepare_face (f, face); | |
| 90400 | 2985 } |
| 2986 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2987 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2988 /* Make FACE on frame F stop using the font opened for FACE. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2989 |
| 90400 | 2990 void |
| 2991 font_done_for_face (f, face) | |
| 2992 FRAME_PTR f; | |
| 2993 struct face *face; | |
| 2994 { | |
| 94926 | 2995 if (face->font->driver->done_face) |
| 2996 face->font->driver->done_face (f, face); | |
| 90400 | 2997 face->extra = NULL; |
| 2998 } | |
| 2999 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3000 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3001 /* Open a font best matching with NAME on frame F. If no proper font |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3002 is found, return Qnil. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3003 |
| 90400 | 3004 Lisp_Object |
| 3005 font_open_by_name (f, name) | |
| 3006 FRAME_PTR f; | |
| 3007 char *name; | |
| 3008 { | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3009 Lisp_Object args[2]; |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3010 Lisp_Object spec, prefer, size, entity, entity_list; |
| 90400 | 3011 Lisp_Object frame; |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3012 int i; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3013 int pixel_size; |
| 90400 | 3014 |
| 3015 XSETFRAME (frame, f); | |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3016 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3017 args[0] = QCname; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3018 args[1] = make_unibyte_string (name, strlen (name)); |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3019 spec = Ffont_spec (2, args); |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3020 prefer = scratch_font_prefer; |
| 94926 | 3021 for (i = 0; i < FONT_SPEC_MAX; i++) |
| 3022 { | |
| 3023 ASET (prefer, i, AREF (spec, i)); | |
| 3024 if (NILP (AREF (prefer, i)) | |
| 3025 && i >= FONT_WEIGHT_INDEX && i <= FONT_WIDTH_INDEX) | |
| 3026 FONT_SET_STYLE (prefer, i, make_number (100)); | |
| 3027 } | |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3028 size = AREF (spec, FONT_SIZE_INDEX); |
|
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3029 if (NILP (size)) |
|
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3030 pixel_size = 0; |
| 94926 | 3031 else |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3032 { |
| 94926 | 3033 if (INTEGERP (size)) |
| 3034 pixel_size = XINT (size); | |
| 3035 else /* FLOATP (size) */ | |
| 3036 { | |
| 3037 double pt = XFLOAT_DATA (size); | |
| 3038 | |
| 3039 pixel_size = POINT_TO_PIXEL (pt, f->resy); | |
| 3040 } | |
| 3041 if (pixel_size == 0) | |
| 3042 ASET (spec, FONT_SIZE_INDEX, Qnil); | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3043 } |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3044 if (pixel_size == 0) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3045 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
3046 pixel_size = POINT_TO_PIXEL (12.0, f->resy); |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3047 size = make_number (pixel_size); |
| 94926 | 3048 ASET (prefer, FONT_SIZE_INDEX, size); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3049 } |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
3050 if (NILP (AREF (spec, FONT_REGISTRY_INDEX))) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
3051 ASET (spec, FONT_REGISTRY_INDEX, Qiso8859_1); |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3052 |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3053 entity_list = Flist_fonts (spec, frame, make_number (1), prefer); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3054 if (NILP (entity_list)) |
| 94926 | 3055 entity = font_matching_entity (f, NULL, spec); |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3056 else |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3057 entity = XCAR (entity_list); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3058 return (NILP (entity) |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3059 ? Qnil |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3060 : font_open_entity (f, entity, pixel_size)); |
| 90400 | 3061 } |
| 3062 | |
| 3063 | |
| 3064 /* Register font-driver DRIVER. This function is used in two ways. | |
| 3065 | |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3066 The first is with frame F non-NULL. In this case, make DRIVER |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3067 available (but not yet activated) on F. All frame creaters |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3068 (e.g. Fx_create_frame) must call this function at least once with |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3069 an available font-driver. |
| 90400 | 3070 |
| 3071 The second is with frame F NULL. In this case, DRIVER is globally | |
| 3072 registered in the variable `font_driver_list'. All font-driver | |
| 3073 implementations must call this function in its syms_of_XXXX | |
| 3074 (e.g. syms_of_xfont). */ | |
| 3075 | |
| 3076 void | |
| 3077 register_font_driver (driver, f) | |
| 3078 struct font_driver *driver; | |
| 3079 FRAME_PTR f; | |
| 3080 { | |
| 3081 struct font_driver_list *root = f ? f->font_driver_list : font_driver_list; | |
| 3082 struct font_driver_list *prev, *list; | |
| 3083 | |
| 3084 if (f && ! driver->draw) | |
|
92113
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
3085 error ("Unusable font driver for a frame: %s", |
| 90400 | 3086 SDATA (SYMBOL_NAME (driver->type))); |
| 3087 | |
| 3088 for (prev = NULL, list = root; list; prev = list, list = list->next) | |
|
90695
a1cd7344d6a2
(font_parse_xlfd): Fix the array size of `f'.
Kenichi Handa <handa@m17n.org>
parents:
90677
diff
changeset
|
3089 if (EQ (list->driver->type, driver->type)) |
| 90400 | 3090 error ("Duplicated font driver: %s", SDATA (SYMBOL_NAME (driver->type))); |
| 3091 | |
| 3092 list = malloc (sizeof (struct font_driver_list)); | |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3093 list->on = 0; |
| 90400 | 3094 list->driver = driver; |
| 3095 list->next = NULL; | |
| 3096 if (prev) | |
| 3097 prev->next = list; | |
| 3098 else if (f) | |
| 3099 f->font_driver_list = list; | |
| 3100 else | |
| 3101 font_driver_list = list; | |
| 3102 num_font_drivers++; | |
| 3103 } | |
| 3104 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3105 |
| 90400 | 3106 /* Free font-driver list on frame F. It doesn't free font-drivers |
| 3107 themselves. */ | |
| 3108 | |
| 3109 void | |
| 3110 free_font_driver_list (f) | |
| 3111 FRAME_PTR f; | |
| 3112 { | |
| 3113 while (f->font_driver_list) | |
| 3114 { | |
| 3115 struct font_driver_list *next = f->font_driver_list->next; | |
| 3116 | |
| 3117 free (f->font_driver_list); | |
| 3118 f->font_driver_list = next; | |
| 3119 } | |
| 3120 } | |
| 3121 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3122 |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3123 /* Make the frame F use font backends listed in NEW_DRIVERS (list of |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3124 symbols, e.g. xft, x). If NEW_DRIVERS is t, make F use all |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3125 available font drivers. If NEW_DRIVERS is nil, finalize all drivers. |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3126 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3127 A caller must free all realized faces if any in advance. The |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3128 return value is a list of font backends actually made used on |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3129 F. */ |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3130 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3131 Lisp_Object |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3132 font_update_drivers (f, new_drivers) |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3133 FRAME_PTR f; |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3134 Lisp_Object new_drivers; |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3135 { |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3136 Lisp_Object active_drivers = Qnil; |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3137 struct font_driver_list *list; |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3138 |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3139 for (list = f->font_driver_list; list; list = list->next) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3140 if (list->on) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3141 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3142 if (! EQ (new_drivers, Qt) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3143 && NILP (Fmemq (list->driver->type, new_drivers))) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3144 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3145 if (list->driver->end_for_frame) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3146 list->driver->end_for_frame (f); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3147 font_finish_cache (f, list->driver); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3148 list->on = 0; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3149 } |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3150 } |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3151 else |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3152 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3153 if (EQ (new_drivers, Qt) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3154 || ! NILP (Fmemq (list->driver->type, new_drivers))) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3155 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3156 if (! list->driver->start_for_frame |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3157 || list->driver->start_for_frame (f) == 0) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3158 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3159 font_prepare_cache (f, list->driver); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3160 list->on = 1; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3161 active_drivers = nconc2 (active_drivers, |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3162 Fcons (list->driver->type, Qnil)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3163 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3164 } |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3165 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3166 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3167 return active_drivers; |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3168 } |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3169 |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3170 int |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3171 font_put_frame_data (f, driver, data) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3172 FRAME_PTR f; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3173 struct font_driver *driver; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3174 void *data; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3175 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3176 struct font_data_list *list, *prev; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3177 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3178 for (prev = NULL, list = f->font_data_list; list; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3179 prev = list, list = list->next) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3180 if (list->driver == driver) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3181 break; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3182 if (! data) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3183 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3184 if (list) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3185 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3186 if (prev) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3187 prev->next = list->next; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3188 else |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3189 f->font_data_list = list->next; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3190 free (list); |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3191 } |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3192 return 0; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3193 } |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3194 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3195 if (! list) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3196 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3197 list = malloc (sizeof (struct font_data_list)); |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3198 if (! list) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3199 return -1; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3200 list->driver = driver; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3201 list->next = f->font_data_list; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3202 f->font_data_list = list; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3203 } |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3204 list->data = data; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3205 return 0; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3206 } |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3207 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3208 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3209 void * |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3210 font_get_frame_data (f, driver) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3211 FRAME_PTR f; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3212 struct font_driver *driver; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3213 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3214 struct font_data_list *list; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3215 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3216 for (list = f->font_data_list; list; list = list->next) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3217 if (list->driver == driver) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3218 break; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3219 if (! list) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3220 return NULL; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3221 return list->data; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3222 } |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3223 |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3224 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3225 /* Return the font used to draw character C by FACE at buffer position |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3226 POS in window W. If STRING is non-nil, it is a string containing C |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3227 at index POS. If C is negative, get C from the current buffer or |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3228 STRING. */ |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3229 |
| 90541 | 3230 Lisp_Object |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3231 font_at (c, pos, face, w, string) |
| 90541 | 3232 int c; |
| 3233 EMACS_INT pos; | |
| 3234 struct face *face; | |
| 3235 struct window *w; | |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3236 Lisp_Object string; |
| 90541 | 3237 { |
| 3238 FRAME_PTR f; | |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3239 int multibyte; |
| 94926 | 3240 Lisp_Object font_object; |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3241 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3242 if (c < 0) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3243 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3244 if (NILP (string)) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3245 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3246 multibyte = ! NILP (current_buffer->enable_multibyte_characters); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3247 if (multibyte) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3248 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3249 EMACS_INT pos_byte = CHAR_TO_BYTE (pos); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3250 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3251 c = FETCH_CHAR (pos_byte); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3252 } |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3253 else |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3254 c = FETCH_BYTE (pos); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3255 } |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3256 else |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3257 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3258 unsigned char *str; |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3259 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3260 multibyte = STRING_MULTIBYTE (string); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3261 if (multibyte) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3262 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3263 EMACS_INT pos_byte = string_char_to_byte (string, pos); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3264 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3265 str = SDATA (string) + pos_byte; |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3266 c = STRING_CHAR (str, 0); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3267 } |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3268 else |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3269 c = SDATA (string)[pos]; |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3270 } |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3271 } |
| 90541 | 3272 |
| 3273 f = XFRAME (w->frame); | |
|
90811
c1ed0fd37416
(font_at): If the window W is not on a window system,
Kenichi Handa <handa@m17n.org>
parents:
90695
diff
changeset
|
3274 if (! FRAME_WINDOW_P (f)) |
|
c1ed0fd37416
(font_at): If the window W is not on a window system,
Kenichi Handa <handa@m17n.org>
parents:
90695
diff
changeset
|
3275 return Qnil; |
| 90541 | 3276 if (! face) |
| 3277 { | |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3278 int face_id; |
|
92237
ce06567a933d
* dispextern.h (face_at_buffer_position, face_for_overlay_string)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92233
diff
changeset
|
3279 EMACS_INT endptr; |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3280 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3281 if (STRINGP (string)) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3282 face_id = face_at_string_position (w, string, pos, 0, -1, -1, &endptr, |
| 90541 | 3283 DEFAULT_FACE_ID, 0); |
| 3284 else | |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3285 face_id = face_at_buffer_position (w, pos, -1, -1, &endptr, |
| 90541 | 3286 pos + 100, 0); |
| 3287 face = FACE_FROM_ID (f, face_id); | |
| 3288 } | |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3289 if (multibyte) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3290 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3291 int face_id = FACE_FOR_CHAR (f, face, c, pos, string); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3292 face = FACE_FROM_ID (f, face_id); |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3293 } |
| 94926 | 3294 if (! face->font) |
| 90541 | 3295 return Qnil; |
| 94926 | 3296 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3297 font_assert (font_check_object ((struct font *) face->font)); |
| 94926 | 3298 XSETFONT (font_object, face->font); |
| 3299 return font_object; | |
| 3300 } | |
| 3301 | |
| 3302 | |
| 3303 /* Check how many characters after POS (at most to LIMIT) can be | |
| 3304 displayed by the same font. FACE is the face selected for the | |
| 3305 character as POS on frame F. STRING, if not nil, is the string to | |
| 3306 check instead of the current buffer. | |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3307 |
| 94926 | 3308 The return value is the position of the character that is displayed |
| 3309 by the differnt font than that of the character as POS. */ | |
| 3310 | |
| 3311 EMACS_INT | |
| 3312 font_range (pos, limit, face, f, string) | |
| 3313 EMACS_INT pos, limit; | |
| 3314 struct face *face; | |
| 3315 FRAME_PTR f; | |
| 3316 Lisp_Object string; | |
| 3317 { | |
| 3318 int multibyte; | |
| 3319 EMACS_INT pos_byte; | |
| 3320 int c; | |
| 3321 struct font *font; | |
| 3322 int first = 1; | |
| 3323 | |
| 3324 if (NILP (string)) | |
| 3325 { | |
| 3326 multibyte = ! NILP (current_buffer->enable_multibyte_characters); | |
| 3327 pos_byte = CHAR_TO_BYTE (pos); | |
| 3328 } | |
| 3329 else | |
| 3330 { | |
| 3331 multibyte = STRING_MULTIBYTE (string); | |
| 3332 pos_byte = string_char_to_byte (string, pos); | |
| 3333 } | |
| 3334 | |
| 3335 if (! multibyte) | |
| 3336 /* All unibyte character are displayed by the same font. */ | |
| 3337 return limit; | |
| 3338 | |
| 3339 while (pos < limit) | |
| 3340 { | |
| 3341 int face_id; | |
| 3342 | |
| 3343 if (NILP (string)) | |
| 3344 FETCH_CHAR_ADVANCE_NO_CHECK (c, pos, pos_byte); | |
| 3345 else | |
| 3346 FETCH_STRING_CHAR_ADVANCE_NO_CHECK (c, string, pos, pos_byte); | |
| 3347 face_id = FACE_FOR_CHAR (f, face, c, pos, string); | |
| 3348 face = FACE_FROM_ID (f, face_id); | |
| 3349 if (first) | |
| 3350 { | |
| 3351 font = face->font; | |
| 3352 first = 0; | |
| 3353 continue; | |
| 3354 } | |
| 3355 else if (font != face->font) | |
| 3356 { | |
| 3357 pos--; | |
| 3358 break; | |
| 3359 } | |
| 3360 } | |
| 3361 return pos; | |
| 90541 | 3362 } |
| 3363 | |
| 90400 | 3364 |
| 3365 /* Lisp API */ | |
| 3366 | |
| 94926 | 3367 DEFUN ("fontp", Ffontp, Sfontp, 1, 2, 0, |
|
91353
b93ade1a3602
(font_find_for_lface): Check if the character C is
Kenichi Handa <handa@m17n.org>
parents:
91350
diff
changeset
|
3368 doc: /* Return t if OBJECT is a font-spec, font-entity, or font-object. |
| 94926 | 3369 Return nil otherwise. |
| 3370 Optional 2nd argument EXTRA-TYPE, if non-nil, specifies to check | |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3371 which kind of font it is. It must be one of `font-spec', `font-entity', |
| 94926 | 3372 `font-object'. */) |
| 3373 (object, extra_type) | |
| 3374 Lisp_Object object, extra_type; | |
| 90400 | 3375 { |
| 94926 | 3376 if (NILP (extra_type)) |
| 3377 return (FONTP (object) ? Qt : Qnil); | |
| 3378 if (EQ (extra_type, Qfont_spec)) | |
| 3379 return (FONT_SPEC_P (object) ? Qt : Qnil); | |
| 3380 if (EQ (extra_type, Qfont_entity)) | |
| 3381 return (FONT_ENTITY_P (object) ? Qt : Qnil); | |
| 3382 if (EQ (extra_type, Qfont_object)) | |
| 3383 return (FONT_OBJECT_P (object) ? Qt : Qnil); | |
| 3384 wrong_type_argument (intern ("font-extra-type"), extra_type); | |
| 90400 | 3385 } |
| 3386 | |
| 3387 DEFUN ("font-spec", Ffont_spec, Sfont_spec, 0, MANY, 0, | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3388 doc: /* Return a newly created font-spec with arguments as properties. |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3389 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3390 ARGS must come in pairs KEY VALUE of font properties. KEY must be a |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3391 valid font property name listed below: |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3392 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3393 `:family', `:weight', `:slant', `:width' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3394 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3395 They are the same as face attributes of the same name. See |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3396 `set-face-attribute'. |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3397 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3398 `:foundry' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3399 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3400 VALUE must be a string or a symbol specifying the font foundry, e.g. ``misc''. |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3401 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3402 `:adstyle' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3403 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3404 VALUE must be a string or a symbol specifying the additional |
| 94926 | 3405 typographic style information of a font, e.g. ``sans''. |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3406 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3407 `:registry' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3408 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3409 VALUE must be a string or a symbol specifying the charset registry and |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3410 encoding of a font, e.g. ``iso8859-1''. |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3411 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3412 `:size' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3413 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3414 VALUE must be a non-negative integer or a floating point number |
| 94926 | 3415 specifying the font size. It specifies the font size in pixels |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3416 (if VALUE is an integer), or in points (if VALUE is a float). |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3417 usage: (font-spec ARGS ...) */) |
| 90400 | 3418 (nargs, args) |
| 3419 int nargs; | |
| 3420 Lisp_Object *args; | |
| 3421 { | |
| 94926 | 3422 Lisp_Object spec = font_make_spec (); |
| 90400 | 3423 int i; |
| 3424 | |
| 3425 for (i = 0; i < nargs; i += 2) | |
| 3426 { | |
| 3427 Lisp_Object key = args[i], val = args[i + 1]; | |
| 3428 | |
| 94926 | 3429 if (EQ (key, QCname)) |
| 3430 { | |
| 3431 CHECK_STRING (val); | |
| 3432 font_parse_name ((char *) SDATA (val), spec); | |
| 3433 font_put_extra (spec, key, val); | |
| 3434 } | |
| 3435 else if (EQ (key, QCfamily)) | |
| 3436 { | |
| 3437 CHECK_STRING (val); | |
| 3438 font_parse_family_registry (val, Qnil, spec); | |
| 3439 } | |
| 90400 | 3440 else |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
3441 { |
| 94926 | 3442 int idx = get_font_prop_index (key); |
| 3443 | |
| 3444 if (idx >= 0) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
3445 { |
| 94926 | 3446 val = font_prop_validate (idx, Qnil, val); |
| 3447 if (idx < FONT_EXTRA_INDEX) | |
| 3448 ASET (spec, idx, val); | |
| 3449 else | |
| 3450 font_put_extra (spec, key, val); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
3451 } |
| 94926 | 3452 else |
| 3453 font_put_extra (spec, key, font_prop_validate (0, key, val)); | |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
3454 } |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3455 } |
| 90400 | 3456 return spec; |
| 3457 } | |
| 3458 | |
| 94926 | 3459 DEFUN ("copy-font-spec", Fcopy_font_spec, Scopy_font_spec, 1, 1, 0, |
| 3460 doc: /* Return a copy of FONT as a font-spec. */) | |
| 3461 (font) | |
| 3462 Lisp_Object font; | |
| 3463 { | |
| 3464 Lisp_Object new_spec, tail, extra; | |
| 3465 int i; | |
| 3466 | |
| 3467 CHECK_FONT (font); | |
| 3468 new_spec = font_make_spec (); | |
| 3469 for (i = 1; i < FONT_EXTRA_INDEX; i++) | |
| 3470 ASET (new_spec, i, AREF (font, i)); | |
| 3471 extra = Qnil; | |
| 3472 for (tail = AREF (font, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail)) | |
| 3473 { | |
| 3474 if (! EQ (XCAR (XCAR (tail)), QCfont_entity)) | |
| 3475 extra = Fcons (Fcons (XCAR (XCAR (tail)), XCDR (XCAR (tail))), extra); | |
| 3476 } | |
| 3477 ASET (new_spec, FONT_EXTRA_INDEX, extra); | |
| 3478 return new_spec; | |
| 3479 } | |
| 3480 | |
| 3481 DEFUN ("merge-font-spec", Fmerge_font_spec, Smerge_font_spec, 2, 2, 0, | |
| 3482 doc: /* Merge font-specs FROM and TO, and return a new font-spec. | |
| 3483 Every specified properties in FROM override the corresponding | |
| 3484 properties in TO. */) | |
| 3485 (from, to) | |
| 3486 Lisp_Object from, to; | |
| 3487 { | |
| 3488 Lisp_Object extra, tail; | |
| 3489 int i; | |
| 3490 | |
| 3491 CHECK_FONT (from); | |
| 3492 CHECK_FONT (to); | |
| 3493 to = Fcopy_font_spec (to); | |
| 3494 for (i = 0; i < FONT_EXTRA_INDEX; i++) | |
| 3495 ASET (to, i, AREF (from, i)); | |
| 3496 extra = AREF (to, FONT_EXTRA_INDEX); | |
| 3497 for (tail = AREF (from, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail)) | |
| 3498 if (! EQ (XCAR (XCAR (tail)), Qfont_entity)) | |
| 3499 { | |
| 3500 Lisp_Object slot = assq_no_quit (XCAR (XCAR (tail)), extra); | |
| 3501 | |
| 3502 if (! NILP (slot)) | |
| 3503 XSETCDR (slot, XCDR (XCAR (tail))); | |
| 3504 else | |
| 3505 extra = Fcons (Fcons (XCAR (XCAR (tail)), XCDR (XCAR (tail))), extra); | |
| 3506 } | |
| 3507 ASET (to, FONT_EXTRA_INDEX, extra); | |
| 3508 return to; | |
| 3509 } | |
| 90400 | 3510 |
| 3511 DEFUN ("font-get", Ffont_get, Sfont_get, 2, 2, 0, | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3512 doc: /* Return the value of FONT's property KEY. |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3513 FONT is a font-spec, a font-entity, or a font-object. */) |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3514 (font, key) |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3515 Lisp_Object font, key; |
| 90400 | 3516 { |
| 94926 | 3517 int idx; |
| 3518 | |
| 3519 CHECK_FONT (font); | |
| 3520 CHECK_SYMBOL (key); | |
| 3521 | |
| 3522 idx = get_font_prop_index (key); | |
| 3523 if (idx >= 0 && idx < FONT_EXTRA_INDEX) | |
| 90400 | 3524 return AREF (font, idx); |
| 94926 | 3525 return Fcdr (Fassq (key, AREF (font, FONT_EXTRA_INDEX))); |
| 90400 | 3526 } |
| 3527 | |
| 3528 | |
| 3529 DEFUN ("font-put", Ffont_put, Sfont_put, 3, 3, 0, | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3530 doc: /* Set one property of FONT-SPEC: give property PROP value VAL. */) |
| 90400 | 3531 (font_spec, prop, val) |
| 3532 Lisp_Object font_spec, prop, val; | |
| 3533 { | |
| 94926 | 3534 int idx; |
| 90400 | 3535 |
| 3536 CHECK_FONT_SPEC (font_spec); | |
| 94926 | 3537 idx = get_font_prop_index (prop); |
| 3538 if (idx >= 0 && idx < FONT_EXTRA_INDEX) | |
| 3539 { | |
| 3540 if (idx == FONT_FAMILY_INDEX | |
| 3541 && STRINGP (val)) | |
| 3542 font_parse_family_registry (val, Qnil, font_spec); | |
| 3543 else | |
| 3544 ASET (font_spec, idx, font_prop_validate (idx, Qnil, val)); | |
| 3545 } | |
| 90400 | 3546 else |
| 94926 | 3547 font_put_extra (font_spec, prop, font_prop_validate (0, prop, val)); |
| 90400 | 3548 return val; |
| 3549 } | |
| 3550 | |
| 3551 DEFUN ("list-fonts", Flist_fonts, Slist_fonts, 1, 4, 0, | |
| 3552 doc: /* List available fonts matching FONT-SPEC on the current frame. | |
| 3553 Optional 2nd argument FRAME specifies the target frame. | |
| 3554 Optional 3rd argument NUM, if non-nil, limits the number of returned fonts. | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3555 Optional 4th argument PREFER, if non-nil, is a font-spec to |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3556 control the order of the returned list. Fonts are sorted by |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3557 how close they are to PREFER. */) |
| 90400 | 3558 (font_spec, frame, num, prefer) |
| 3559 Lisp_Object font_spec, frame, num, prefer; | |
| 3560 { | |
| 3561 Lisp_Object vec, list, tail; | |
| 3562 int n = 0, i, len; | |
| 3563 | |
| 3564 if (NILP (frame)) | |
| 3565 frame = selected_frame; | |
| 3566 CHECK_LIVE_FRAME (frame); | |
| 94926 | 3567 CHECK_FONT_SPEC (font_spec); |
| 90400 | 3568 if (! NILP (num)) |
| 3569 { | |
| 3570 CHECK_NUMBER (num); | |
| 3571 n = XINT (num); | |
| 3572 if (n <= 0) | |
| 3573 return Qnil; | |
| 3574 } | |
| 3575 if (! NILP (prefer)) | |
| 94926 | 3576 CHECK_FONT_SPEC (prefer); |
| 90400 | 3577 |
| 3578 vec = font_list_entities (frame, font_spec); | |
| 3579 len = ASIZE (vec); | |
| 3580 if (len == 0) | |
| 3581 return Qnil; | |
| 3582 if (len == 1) | |
| 3583 return Fcons (AREF (vec, 0), Qnil); | |
| 3584 | |
| 3585 if (! NILP (prefer)) | |
| 94926 | 3586 vec = font_sort_entites (vec, prefer, frame, font_spec, 0); |
| 90400 | 3587 |
| 3588 list = tail = Fcons (AREF (vec, 0), Qnil); | |
| 3589 if (n == 0 || n > len) | |
| 3590 n = len; | |
| 3591 for (i = 1; i < n; i++) | |
| 3592 { | |
| 3593 Lisp_Object val = Fcons (AREF (vec, i), Qnil); | |
| 3594 | |
| 3595 XSETCDR (tail, val); | |
| 3596 tail = val; | |
| 3597 } | |
| 3598 return list; | |
| 3599 } | |
| 3600 | |
| 94926 | 3601 DEFUN ("font-family-list", Ffont_family_list, Sfont_family_list, 0, 1, 0, |
| 90400 | 3602 doc: /* List available font families on the current frame. |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3603 Optional argument FRAME, if non-nil, specifies the target frame. */) |
| 90400 | 3604 (frame) |
| 3605 Lisp_Object frame; | |
| 3606 { | |
| 3607 FRAME_PTR f; | |
| 3608 struct font_driver_list *driver_list; | |
| 3609 Lisp_Object list; | |
| 3610 | |
| 3611 if (NILP (frame)) | |
| 3612 frame = selected_frame; | |
| 3613 CHECK_LIVE_FRAME (frame); | |
| 3614 f = XFRAME (frame); | |
| 3615 list = Qnil; | |
| 3616 for (driver_list = f->font_driver_list; driver_list; | |
| 3617 driver_list = driver_list->next) | |
| 3618 if (driver_list->driver->list_family) | |
| 3619 { | |
| 3620 Lisp_Object val = driver_list->driver->list_family (frame); | |
| 3621 | |
| 3622 if (NILP (list)) | |
| 3623 list = val; | |
| 3624 else | |
| 3625 { | |
| 3626 Lisp_Object tail = list; | |
| 3627 | |
| 3628 for (; CONSP (val); val = XCDR (val)) | |
| 3629 if (NILP (Fmemq (XCAR (val), tail))) | |
| 3630 list = Fcons (XCAR (val), list); | |
| 3631 } | |
| 3632 } | |
| 3633 return list; | |
| 3634 } | |
| 3635 | |
| 3636 DEFUN ("find-font", Ffind_font, Sfind_font, 1, 2, 0, | |
| 3637 doc: /* Return a font-entity matching with FONT-SPEC on the current frame. | |
| 3638 Optional 2nd argument FRAME, if non-nil, specifies the target frame. */) | |
| 3639 (font_spec, frame) | |
| 3640 Lisp_Object font_spec, frame; | |
| 3641 { | |
| 3642 Lisp_Object val = Flist_fonts (font_spec, frame, make_number (1), Qnil); | |
| 3643 | |
| 3644 if (CONSP (val)) | |
| 3645 val = XCAR (val); | |
| 3646 return val; | |
| 3647 } | |
| 3648 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3649 DEFUN ("font-xlfd-name", Ffont_xlfd_name, Sfont_xlfd_name, 1, 2, 0, |
| 90400 | 3650 doc: /* Return XLFD name of FONT. |
| 3651 FONT is a font-spec, font-entity, or font-object. | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3652 If the name is too long for XLFD (maximum 255 chars), return nil. |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3653 If the 2nd optional arg FOLD-WILDCARDS is non-nil, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3654 the consecutive wildcards are folded to one. */) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3655 (font, fold_wildcards) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3656 Lisp_Object font, fold_wildcards; |
| 90400 | 3657 { |
| 3658 char name[256]; | |
| 3659 int pixel_size = 0; | |
| 3660 | |
| 94926 | 3661 CHECK_FONT (font); |
| 3662 | |
| 3663 if (FONT_OBJECT_P (font)) | |
| 90400 | 3664 { |
| 94926 | 3665 Lisp_Object font_name = AREF (font, FONT_NAME_INDEX); |
| 3666 | |
| 3667 if (STRINGP (font_name) | |
| 3668 && SDATA (font_name)[0] == '-') | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3669 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3670 if (NILP (fold_wildcards)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3671 return font_name; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3672 strcpy (name, (char *) SDATA (font_name)); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3673 goto done; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3674 } |
| 94926 | 3675 pixel_size = XFONT_OBJECT (font)->pixel_size; |
| 90400 | 3676 } |
| 3677 if (font_unparse_xlfd (font, pixel_size, name, 256) < 0) | |
| 3678 return Qnil; | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3679 done: |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3680 if (! NILP (fold_wildcards)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3681 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3682 char *p0 = name, *p1; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3683 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3684 while ((p1 = strstr (p0, "-*-*"))) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3685 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3686 strcpy (p1, p1 + 2); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3687 p0 = p1; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3688 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3689 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3690 |
| 90400 | 3691 return build_string (name); |
| 3692 } | |
| 3693 | |
| 3694 DEFUN ("clear-font-cache", Fclear_font_cache, Sclear_font_cache, 0, 0, 0, | |
| 3695 doc: /* Clear font cache. */) | |
| 3696 () | |
| 3697 { | |
| 3698 Lisp_Object list, frame; | |
| 3699 | |
| 3700 FOR_EACH_FRAME (list, frame) | |
| 3701 { | |
| 3702 FRAME_PTR f = XFRAME (frame); | |
| 3703 struct font_driver_list *driver_list = f->font_driver_list; | |
| 3704 | |
| 3705 for (; driver_list; driver_list = driver_list->next) | |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3706 if (driver_list->on) |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3707 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3708 Lisp_Object cache = driver_list->driver->get_cache (f); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3709 Lisp_Object val; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3710 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3711 val = XCDR (cache); |
| 91909 | 3712 while (! NILP (val) |
| 3713 && ! EQ (XCAR (XCAR (val)), driver_list->driver->type)) | |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3714 val = XCDR (val); |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3715 font_assert (! NILP (val)); |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3716 val = XCDR (XCAR (val)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3717 if (XINT (XCAR (val)) == 0) |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3718 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3719 font_clear_cache (f, XCAR (val), driver_list->driver); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3720 XSETCDR (cache, XCDR (val)); |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3721 } |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3722 } |
| 90400 | 3723 } |
| 3724 | |
| 3725 return Qnil; | |
| 3726 } | |
| 3727 | |
| 95177 | 3728 /* The following three functions are still experimental. */ |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3729 |
| 90400 | 3730 DEFUN ("font-make-gstring", Ffont_make_gstring, Sfont_make_gstring, 2, 2, 0, |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3731 doc: /* Return a newly created g-string for FONT-OBJECT with NUM glyphs. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3732 FONT-OBJECT may be nil if it is not yet known. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3733 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3734 G-string is sequence of glyphs of a specific font, |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3735 and is a vector of this form: |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3736 [ HEADER GLYPH ... ] |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3737 HEADER is a vector of this form: |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3738 [FONT-OBJECT WIDTH LBEARING RBEARING ASCENT DESCENT] |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3739 where |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
3740 FONT-OBJECT is a font-object for all glyphs in the g-string, |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3741 WIDTH thru DESCENT are the metrics (in pixels) of the whole G-string. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3742 GLYPH is a vector of this form: |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3743 [ FROM-IDX TO-IDX C CODE WIDTH LBEARING RBEARING ASCENT DESCENT |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3744 [ [X-OFF Y-OFF WADJUST] | nil] ] |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3745 where |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3746 FROM-IDX and TO-IDX are used internally and should not be touched. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3747 C is the character of the glyph. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3748 CODE is the glyph-code of C in FONT-OBJECT. |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3749 WIDTH thru DESCENT are the metrics (in pixels) of the glyph. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3750 X-OFF and Y-OFF are offests to the base position for the glyph. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3751 WADJUST is the adjustment to the normal width of the glyph. */) |
| 90400 | 3752 (font_object, num) |
| 3753 Lisp_Object font_object, num; | |
| 3754 { | |
| 3755 Lisp_Object gstring, g; | |
| 3756 int len; | |
| 3757 int i; | |
| 3758 | |
| 3759 if (! NILP (font_object)) | |
| 3760 CHECK_FONT_OBJECT (font_object); | |
| 3761 CHECK_NATNUM (num); | |
| 3762 | |
| 3763 len = XINT (num) + 1; | |
| 3764 gstring = Fmake_vector (make_number (len), Qnil); | |
| 3765 g = Fmake_vector (make_number (6), Qnil); | |
| 3766 ASET (g, 0, font_object); | |
| 3767 ASET (gstring, 0, g); | |
| 3768 for (i = 1; i < len; i++) | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3769 ASET (gstring, i, Fmake_vector (make_number (10), Qnil)); |
| 90400 | 3770 return gstring; |
| 3771 } | |
| 3772 | |
| 3773 DEFUN ("font-fill-gstring", Ffont_fill_gstring, Sfont_fill_gstring, 4, 5, 0, | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3774 doc: /* Fill in glyph-string GSTRING by characters for FONT-OBJECT. |
|
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3775 START and END specify the region to extract characters. |
|
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3776 If optional 5rd argument OBJECT is non-nil, it is a buffer or a string from |
| 90400 | 3777 where to extract characters. |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3778 FONT-OBJECT may be nil if GSTRING already contains one. */) |
| 90400 | 3779 (gstring, font_object, start, end, object) |
| 3780 Lisp_Object gstring, font_object, start, end, object; | |
| 3781 { | |
| 3782 int len, i, c; | |
| 3783 unsigned code; | |
| 3784 struct font *font; | |
| 3785 | |
| 3786 CHECK_VECTOR (gstring); | |
| 3787 if (NILP (font_object)) | |
| 90541 | 3788 font_object = LGSTRING_FONT (gstring); |
| 94926 | 3789 font = XFONT_OBJECT (font_object); |
| 90400 | 3790 |
| 3791 if (STRINGP (object)) | |
| 3792 { | |
| 3793 const unsigned char *p; | |
| 3794 | |
| 3795 CHECK_NATNUM (start); | |
| 3796 CHECK_NATNUM (end); | |
| 3797 if (XINT (start) > XINT (end) | |
| 3798 || XINT (end) > ASIZE (object) | |
| 90541 | 3799 || XINT (end) - XINT (start) > LGSTRING_LENGTH (gstring)) |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3800 args_out_of_range_3 (object, start, end); |
| 90400 | 3801 |
| 3802 len = XINT (end) - XINT (start); | |
| 3803 p = SDATA (object) + string_char_to_byte (object, XINT (start)); | |
| 3804 for (i = 0; i < len; i++) | |
| 3805 { | |
| 3806 Lisp_Object g = LGSTRING_GLYPH (gstring, i); | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3807 /* Shut up GCC warning in comparison with |
|
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3808 MOST_POSITIVE_FIXNUM below. */ |
|
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3809 EMACS_INT cod; |
| 90400 | 3810 |
| 3811 c = STRING_CHAR_ADVANCE (p); | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3812 cod = code = font->driver->encode_char (font, c); |
|
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3813 if (cod > MOST_POSITIVE_FIXNUM || code == FONT_INVALID_CODE) |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3814 break; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3815 LGLYPH_SET_FROM (g, i); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3816 LGLYPH_SET_TO (g, i); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3817 LGLYPH_SET_CHAR (g, c); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3818 LGLYPH_SET_CODE (g, code); |
| 90400 | 3819 } |
| 3820 } | |
| 3821 else | |
| 3822 { | |
| 3823 int pos, pos_byte; | |
| 3824 | |
| 3825 if (! NILP (object)) | |
| 3826 Fset_buffer (object); | |
| 3827 validate_region (&start, &end); | |
| 90541 | 3828 if (XINT (end) - XINT (start) > LGSTRING_LENGTH (gstring)) |
| 90400 | 3829 args_out_of_range (start, end); |
| 3830 len = XINT (end) - XINT (start); | |
| 3831 pos = XINT (start); | |
| 3832 pos_byte = CHAR_TO_BYTE (pos); | |
| 3833 for (i = 0; i < len; i++) | |
| 3834 { | |
| 3835 Lisp_Object g = LGSTRING_GLYPH (gstring, i); | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3836 /* Shut up GCC warning in comparison with |
|
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3837 MOST_POSITIVE_FIXNUM below. */ |
|
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3838 EMACS_INT cod; |
| 90400 | 3839 |
| 3840 FETCH_CHAR_ADVANCE (c, pos, pos_byte); | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3841 cod = code = font->driver->encode_char (font, c); |
|
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3842 if (cod > MOST_POSITIVE_FIXNUM || code == FONT_INVALID_CODE) |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3843 break; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3844 LGLYPH_SET_FROM (g, i); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3845 LGLYPH_SET_TO (g, i); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3846 LGLYPH_SET_CHAR (g, c); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3847 LGLYPH_SET_CODE (g, code); |
| 90400 | 3848 } |
| 3849 } | |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3850 for (; i < LGSTRING_LENGTH (gstring); i++) |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3851 LGSTRING_SET_GLYPH (gstring, i, Qnil); |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3852 return Qnil; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3853 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3854 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3855 DEFUN ("font-shape-text", Ffont_shape_text, Sfont_shape_text, 3, 4, 0, |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3856 doc: /* Shape text between FROM and TO by FONT-OBJECT. |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3857 If optional 4th argument STRING is non-nil, it is a string to shape, |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3858 and FROM and TO are indices to the string. |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3859 The value is the end position of the text that can be shaped by |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3860 FONT-OBJECT. */) |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3861 (from, to, font_object, string) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3862 Lisp_Object from, to, font_object, string; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3863 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3864 struct font *font; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3865 struct font_metrics metrics; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3866 EMACS_INT start, end; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3867 Lisp_Object gstring, n; |
| 94926 | 3868 int len, i; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3869 |
|
92183
275e5e980fc4
If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents:
92113
diff
changeset
|
3870 if (! FONT_OBJECT_P (font_object)) |
|
275e5e980fc4
If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents:
92113
diff
changeset
|
3871 return Qnil; |
| 94926 | 3872 font = XFONT_OBJECT (font_object); |
|
92183
275e5e980fc4
If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents:
92113
diff
changeset
|
3873 if (! font->driver->shape) |
|
275e5e980fc4
If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents:
92113
diff
changeset
|
3874 return Qnil; |
|
275e5e980fc4
If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents:
92113
diff
changeset
|
3875 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3876 if (NILP (string)) |
| 90541 | 3877 { |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3878 validate_region (&from, &to); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3879 start = XFASTINT (from); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3880 end = XFASTINT (to); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3881 modify_region (current_buffer, start, end, 0); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3882 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3883 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3884 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3885 CHECK_STRING (string); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3886 start = XINT (from); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3887 end = XINT (to); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3888 if (start < 0 || start > end || end > SCHARS (string)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3889 args_out_of_range_3 (string, from, to); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3890 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3891 |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3892 len = end - start; |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3893 gstring = Ffont_make_gstring (font_object, make_number (len)); |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3894 Ffont_fill_gstring (gstring, font_object, from, to, string); |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3895 |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3896 /* Try at most three times with larger gstring each time. */ |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3897 for (i = 0; i < 3; i++) |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3898 { |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3899 Lisp_Object args[2]; |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3900 |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3901 n = font->driver->shape (gstring); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3902 if (INTEGERP (n)) |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3903 break; |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3904 args[0] = gstring; |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3905 args[1] = Fmake_vector (make_number (len), Qnil); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3906 gstring = Fvconcat (2, args); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3907 } |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3908 if (! INTEGERP (n) || XINT (n) == 0) |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3909 return Qnil; |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3910 len = XINT (n); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3911 |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3912 for (i = 0; i < len;) |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3913 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3914 Lisp_Object gstr; |
| 90541 | 3915 Lisp_Object g = LGSTRING_GLYPH (gstring, i); |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3916 EMACS_INT this_from = LGLYPH_FROM (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3917 EMACS_INT this_to = LGLYPH_TO (g) + 1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3918 int j, k; |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3919 int need_composition = 0; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3920 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3921 metrics.lbearing = LGLYPH_LBEARING (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3922 metrics.rbearing = LGLYPH_RBEARING (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3923 metrics.ascent = LGLYPH_ASCENT (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3924 metrics.descent = LGLYPH_DESCENT (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3925 if (NILP (LGLYPH_ADJUSTMENT (g))) |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3926 { |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3927 metrics.width = LGLYPH_WIDTH (g); |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
3928 if (LGLYPH_CHAR (g) == 0 || metrics.width == 0) |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3929 need_composition = 1; |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3930 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3931 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3932 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3933 metrics.width = LGLYPH_WADJUST (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3934 metrics.lbearing += LGLYPH_XOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3935 metrics.rbearing += LGLYPH_XOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3936 metrics.ascent -= LGLYPH_YOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3937 metrics.descent += LGLYPH_YOFF (g); |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3938 need_composition = 1; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3939 } |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3940 for (j = i + 1; j < len; j++) |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3941 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3942 int x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3943 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3944 g = LGSTRING_GLYPH (gstring, j); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3945 if (this_from != LGLYPH_FROM (g)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3946 break; |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3947 need_composition = 1; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3948 x = metrics.width + LGLYPH_LBEARING (g) + LGLYPH_XOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3949 if (metrics.lbearing > x) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3950 metrics.lbearing = x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3951 x = metrics.width + LGLYPH_RBEARING (g) + LGLYPH_XOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3952 if (metrics.rbearing < x) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3953 metrics.rbearing = x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3954 x = LGLYPH_ASCENT (g) - LGLYPH_YOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3955 if (metrics.ascent < x) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3956 metrics.ascent = x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3957 x = LGLYPH_DESCENT (g) - LGLYPH_YOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3958 if (metrics.descent < x) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3959 metrics.descent = x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3960 if (NILP (LGLYPH_ADJUSTMENT (g))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3961 metrics.width += LGLYPH_WIDTH (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3962 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3963 metrics.width += LGLYPH_WADJUST (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3964 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3965 |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3966 if (need_composition) |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3967 { |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3968 gstr = Ffont_make_gstring (font_object, make_number (j - i)); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3969 LGSTRING_SET_WIDTH (gstr, metrics.width); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3970 LGSTRING_SET_LBEARING (gstr, metrics.lbearing); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3971 LGSTRING_SET_RBEARING (gstr, metrics.rbearing); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3972 LGSTRING_SET_ASCENT (gstr, metrics.ascent); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3973 LGSTRING_SET_DESCENT (gstr, metrics.descent); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3974 for (k = i; i < j; i++) |
|
91307
0afaa00ae397
(Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents:
91273
diff
changeset
|
3975 { |
|
0afaa00ae397
(Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents:
91273
diff
changeset
|
3976 Lisp_Object g = LGSTRING_GLYPH (gstring, i); |
|
0afaa00ae397
(Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents:
91273
diff
changeset
|
3977 |
|
0afaa00ae397
(Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents:
91273
diff
changeset
|
3978 LGLYPH_SET_FROM (g, LGLYPH_FROM (g) - this_from); |
|
91309
3f56aab091ed
(Ffont_shape_text): Fix setting of `to' field of glyphs.
Kenichi Handa <handa@m17n.org>
parents:
91307
diff
changeset
|
3979 LGLYPH_SET_TO (g, LGLYPH_TO (g) - this_from); |
|
91307
0afaa00ae397
(Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents:
91273
diff
changeset
|
3980 LGSTRING_SET_GLYPH (gstr, i - k, LGSTRING_GLYPH (gstring, i)); |
|
0afaa00ae397
(Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents:
91273
diff
changeset
|
3981 } |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3982 from = make_number (start + this_from); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3983 to = make_number (start + this_to); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3984 if (NILP (string)) |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3985 Fcompose_region_internal (from, to, gstr, Qnil); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3986 else |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3987 Fcompose_string_internal (string, from, to, gstr, Qnil); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3988 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3989 else |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3990 i = j; |
| 90541 | 3991 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3992 |
|
91192
bcad98389aeb
(Ffont_shape_text): Fix the return value.
Kenichi Handa <handa@m17n.org>
parents:
91174
diff
changeset
|
3993 return to; |
| 90400 | 3994 } |
| 3995 | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
3996 DEFUN ("font-drive-otf", Ffont_drive_otf, Sfont_drive_otf, 6, 6, 0, |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
3997 doc: /* Apply OpenType features on glyph-string GSTRING-IN. |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3998 OTF-FEATURES specifies which features to apply in this format: |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
3999 (SCRIPT LANGSYS GSUB GPOS) |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4000 where |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4001 SCRIPT is a symbol specifying a script tag of OpenType, |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4002 LANGSYS is a symbol specifying a langsys tag of OpenType, |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4003 GSUB and GPOS, if non-nil, are lists of symbols specifying feature tags. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4004 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4005 If LANGYS is nil, the default langsys is selected. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4006 |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4007 The features are applied in the order they appear in the list. The |
|
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4008 symbol `*' means to apply all available features not present in this |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4009 list, and the remaining features are ignored. For instance, (vatu |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4010 pstf * haln) is to apply vatu and pstf in this order, then to apply |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4011 all available features other than vatu, pstf, and haln. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4012 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4013 The features are applied to the glyphs in the range FROM and TO of |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4014 the glyph-string GSTRING-IN. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4015 |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4016 If some feature is actually applicable, the resulting glyphs are |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4017 produced in the glyph-string GSTRING-OUT from the index INDEX. In |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4018 this case, the value is the number of produced glyphs. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4019 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4020 If no feature is applicable, no glyph is produced in GSTRING-OUT, and |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4021 the value is 0. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4022 |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4023 If GSTRING-OUT is too short to hold produced glyphs, no glyphs are |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4024 produced in GSTRING-OUT, and the value is nil. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4025 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4026 See the documentation of `font-make-gstring' for the format of |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4027 glyph-string. */) |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4028 (otf_features, gstring_in, from, to, gstring_out, index) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4029 Lisp_Object otf_features, gstring_in, from, to, gstring_out, index; |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4030 { |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4031 Lisp_Object font_object = LGSTRING_FONT (gstring_in); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4032 Lisp_Object val; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4033 struct font *font; |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4034 int len, num; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4035 |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4036 check_otf_features (otf_features); |
| 94926 | 4037 CHECK_FONT_OBJECT (font_object); |
| 4038 font = XFONT_OBJECT (font_object); | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4039 if (! font->driver->otf_drive) |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4040 error ("Font backend %s can't drive OpenType GSUB table", |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4041 SDATA (SYMBOL_NAME (font->driver->type))); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4042 CHECK_CONS (otf_features); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4043 CHECK_SYMBOL (XCAR (otf_features)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4044 val = XCDR (otf_features); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4045 CHECK_SYMBOL (XCAR (val)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4046 val = XCDR (otf_features); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4047 if (! NILP (val)) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4048 CHECK_CONS (val); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4049 len = check_gstring (gstring_in); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4050 CHECK_VECTOR (gstring_out); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4051 CHECK_NATNUM (from); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4052 CHECK_NATNUM (to); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4053 CHECK_NATNUM (index); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4054 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4055 if (XINT (from) >= XINT (to) || XINT (to) > len) |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4056 args_out_of_range_3 (from, to, make_number (len)); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4057 if (XINT (index) >= ASIZE (gstring_out)) |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4058 args_out_of_range (index, make_number (ASIZE (gstring_out))); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4059 num = font->driver->otf_drive (font, otf_features, |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4060 gstring_in, XINT (from), XINT (to), |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4061 gstring_out, XINT (index), 0); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4062 if (num < 0) |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4063 return Qnil; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4064 return make_number (num); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4065 } |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4066 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4067 DEFUN ("font-otf-alternates", Ffont_otf_alternates, Sfont_otf_alternates, |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4068 3, 3, 0, |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4069 doc: /* Return a list of alternate glyphs of CHARACTER in FONT-OBJECT. |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4070 OTF-FEATURES specifies which features of the font FONT-OBJECT to apply |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4071 in this format: |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4072 (SCRIPT LANGSYS FEATURE ...) |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4073 See the documentation of `font-drive-otf' for more detail. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4074 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4075 The value is a list of cons cells of the format (GLYPH-ID . CHARACTER), |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4076 where GLYPH-ID is a glyph index of the font, and CHARACTER is a |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4077 character code corresponding to the glyph or nil if there's no |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4078 corresponding character. */) |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4079 (font_object, character, otf_features) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4080 Lisp_Object font_object, character, otf_features; |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4081 { |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4082 struct font *font; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4083 Lisp_Object gstring_in, gstring_out, g; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4084 Lisp_Object alternates; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4085 int i, num; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4086 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4087 CHECK_FONT_GET_OBJECT (font_object, font); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4088 if (! font->driver->otf_drive) |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
4089 error ("Font backend %s can't drive OpenType GSUB table", |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
4090 SDATA (SYMBOL_NAME (font->driver->type))); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4091 CHECK_CHARACTER (character); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4092 CHECK_CONS (otf_features); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4093 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4094 gstring_in = Ffont_make_gstring (font_object, make_number (1)); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4095 g = LGSTRING_GLYPH (gstring_in, 0); |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
4096 LGLYPH_SET_CHAR (g, XINT (character)); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4097 gstring_out = Ffont_make_gstring (font_object, make_number (10)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4098 while ((num = font->driver->otf_drive (font, otf_features, gstring_in, 0, 1, |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4099 gstring_out, 0, 1)) < 0) |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4100 gstring_out = Ffont_make_gstring (font_object, |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4101 make_number (ASIZE (gstring_out) * 2)); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4102 alternates = Qnil; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4103 for (i = 0; i < num; i++) |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4104 { |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4105 Lisp_Object g = LGSTRING_GLYPH (gstring_out, i); |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
4106 int c = LGLYPH_CHAR (g); |
|
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
4107 unsigned code = LGLYPH_CODE (g); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4108 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4109 alternates = Fcons (Fcons (make_number (code), |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4110 c > 0 ? make_number (c) : Qnil), |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4111 alternates); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4112 } |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4113 return Fnreverse (alternates); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4114 } |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4115 |
| 90400 | 4116 |
| 4117 #ifdef FONT_DEBUG | |
| 4118 | |
| 4119 DEFUN ("open-font", Fopen_font, Sopen_font, 1, 3, 0, | |
| 4120 doc: /* Open FONT-ENTITY. */) | |
| 4121 (font_entity, size, frame) | |
| 4122 Lisp_Object font_entity; | |
| 4123 Lisp_Object size; | |
| 4124 Lisp_Object frame; | |
| 4125 { | |
| 4126 int isize; | |
| 4127 | |
| 4128 CHECK_FONT_ENTITY (font_entity); | |
| 4129 if (NILP (frame)) | |
| 4130 frame = selected_frame; | |
| 4131 CHECK_LIVE_FRAME (frame); | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4132 |
| 94926 | 4133 if (NILP (size)) |
| 4134 isize = XINT (AREF (font_entity, FONT_SIZE_INDEX)); | |
| 4135 else | |
| 4136 { | |
| 4137 CHECK_NUMBER_OR_FLOAT (size); | |
| 4138 if (FLOATP (size)) | |
| 4139 isize = POINT_TO_PIXEL (- isize, XFRAME (frame)->resy); | |
| 4140 else | |
| 4141 isize = XINT (size); | |
| 4142 if (isize == 0) | |
| 4143 isize = 120; | |
| 4144 } | |
| 90400 | 4145 return font_open_entity (XFRAME (frame), font_entity, isize); |
| 4146 } | |
| 4147 | |
| 4148 DEFUN ("close-font", Fclose_font, Sclose_font, 1, 2, 0, | |
| 4149 doc: /* Close FONT-OBJECT. */) | |
| 4150 (font_object, frame) | |
| 4151 Lisp_Object font_object, frame; | |
| 4152 { | |
| 4153 CHECK_FONT_OBJECT (font_object); | |
| 4154 if (NILP (frame)) | |
| 4155 frame = selected_frame; | |
| 4156 CHECK_LIVE_FRAME (frame); | |
| 4157 font_close_object (XFRAME (frame), font_object); | |
| 4158 return Qnil; | |
| 4159 } | |
| 4160 | |
| 4161 DEFUN ("query-font", Fquery_font, Squery_font, 1, 1, 0, | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4162 doc: /* Return information about FONT-OBJECT. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4163 The value is a vector: |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4164 [ NAME FILENAME PIXEL-SIZE SIZE ASCENT DESCENT SPACE-WIDTH AVERAGE-WIDTH |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4165 CAPABILITY ] |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4166 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4167 NAME is a string of the font name (or nil if the font backend doesn't |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4168 provide a name). |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4169 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4170 FILENAME is a string of the font file (or nil if the font backend |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4171 doesn't provide a file name). |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4172 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4173 PIXEL-SIZE is a pixel size by which the font is opened. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4174 |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4175 SIZE is a maximum advance width of the font in pixels. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4176 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4177 ASCENT, DESCENT, SPACE-WIDTH, AVERAGE-WIDTH are metrics of the font in |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4178 pixels. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4179 |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4180 CAPABILITY is a list whose first element is a symbol representing the |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4181 font format \(x, opentype, truetype, type1, pcf, or bdf) and the |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4182 remaining elements describe the details of the font capability. |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4183 |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4184 If the font is OpenType font, the form of the list is |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4185 \(opentype GSUB GPOS) |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4186 where GSUB shows which "GSUB" features the font supports, and GPOS |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4187 shows which "GPOS" features the font supports. Both GSUB and GPOS are |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4188 lists of the format: |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4189 \((SCRIPT (LANGSYS FEATURE ...) ...) ...) |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4190 |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4191 If the font is not OpenType font, currently the length of the form is |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4192 one. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4193 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4194 SCRIPT is a symbol representing OpenType script tag. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4195 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4196 LANGSYS is a symbol representing OpenType langsys tag, or nil |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4197 representing the default langsys. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4198 |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4199 FEATURE is a symbol representing OpenType feature tag. |
|
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4200 |
|
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4201 If the font is not OpenType font, CAPABILITY is nil. */) |
| 90400 | 4202 (font_object) |
| 4203 Lisp_Object font_object; | |
| 4204 { | |
| 4205 struct font *font; | |
| 4206 Lisp_Object val; | |
| 4207 | |
| 4208 CHECK_FONT_GET_OBJECT (font_object, font); | |
| 4209 | |
| 4210 val = Fmake_vector (make_number (9), Qnil); | |
| 94926 | 4211 ASET (val, 0, AREF (font_object, FONT_NAME_INDEX)); |
| 4212 ASET (val, 1, AREF (font_object, FONT_FILE_INDEX)); | |
| 90400 | 4213 ASET (val, 2, make_number (font->pixel_size)); |
| 94926 | 4214 ASET (val, 3, make_number (font->max_width)); |
| 90400 | 4215 ASET (val, 4, make_number (font->ascent)); |
| 4216 ASET (val, 5, make_number (font->descent)); | |
| 94926 | 4217 ASET (val, 6, make_number (font->space_width)); |
| 4218 ASET (val, 7, make_number (font->average_width)); | |
| 90400 | 4219 if (font->driver->otf_capability) |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4220 ASET (val, 8, Fcons (Qopentype, font->driver->otf_capability (font))); |
| 90400 | 4221 return val; |
| 4222 } | |
| 4223 | |
| 4224 DEFUN ("get-font-glyphs", Fget_font_glyphs, Sget_font_glyphs, 2, 2, 0, | |
| 4225 doc: /* Return a vector of glyphs of FONT-OBJECT for drawing STRING. | |
| 4226 Each element is a vector [GLYPH-CODE LBEARING RBEARING WIDTH ASCENT DESCENT]. */) | |
| 4227 (font_object, string) | |
| 4228 Lisp_Object font_object, string; | |
| 4229 { | |
| 4230 struct font *font; | |
| 4231 int i, len; | |
| 4232 Lisp_Object vec; | |
| 4233 | |
| 4234 CHECK_FONT_GET_OBJECT (font_object, font); | |
| 4235 CHECK_STRING (string); | |
| 4236 len = SCHARS (string); | |
| 4237 vec = Fmake_vector (make_number (len), Qnil); | |
| 4238 for (i = 0; i < len; i++) | |
| 4239 { | |
| 4240 Lisp_Object ch = Faref (string, make_number (i)); | |
| 4241 Lisp_Object val; | |
| 4242 int c = XINT (ch); | |
| 4243 unsigned code; | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
4244 EMACS_INT cod; |
| 90400 | 4245 struct font_metrics metrics; |
| 4246 | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
4247 cod = code = font->driver->encode_char (font, c); |
| 90400 | 4248 if (code == FONT_INVALID_CODE) |
| 4249 continue; | |
| 4250 val = Fmake_vector (make_number (6), Qnil); | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
4251 if (cod <= MOST_POSITIVE_FIXNUM) |
| 90400 | 4252 ASET (val, 0, make_number (code)); |
| 4253 else | |
| 4254 ASET (val, 0, Fcons (make_number (code >> 16), | |
| 4255 make_number (code & 0xFFFF))); | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4256 font->driver->text_extents (font, &code, 1, &metrics); |
| 90400 | 4257 ASET (val, 1, make_number (metrics.lbearing)); |
| 4258 ASET (val, 2, make_number (metrics.rbearing)); | |
| 4259 ASET (val, 3, make_number (metrics.width)); | |
| 4260 ASET (val, 4, make_number (metrics.ascent)); | |
| 4261 ASET (val, 5, make_number (metrics.descent)); | |
| 4262 ASET (vec, i, val); | |
| 4263 } | |
| 4264 return vec; | |
| 4265 } | |
| 4266 | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4267 DEFUN ("font-match-p", Ffont_match_p, Sfont_match_p, 2, 2, 0, |
|
94745
a995b289585f
(Ffont_match_p): Don't use `iff' in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
94394
diff
changeset
|
4268 doc: /* Return t if and only if font-spec SPEC matches with FONT. |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4269 FONT is a font-spec, font-entity, or font-object. */) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4270 (spec, font) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4271 Lisp_Object spec, font; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4272 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4273 CHECK_FONT_SPEC (spec); |
| 94926 | 4274 CHECK_FONT (font); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4275 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4276 return (font_match_p (spec, font) ? Qt : Qnil); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4277 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4278 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4279 DEFUN ("font-at", Ffont_at, Sfont_at, 1, 3, 0, |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4280 doc: /* Return a font-object for displaying a character at POSITION. |
| 90541 | 4281 Optional second arg WINDOW, if non-nil, is a window displaying |
| 4282 the current buffer. It defaults to the currently selected window. */) | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4283 (position, window, string) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4284 Lisp_Object position, window, string; |
| 90541 | 4285 { |
| 4286 struct window *w; | |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
4287 EMACS_INT pos; |
| 90541 | 4288 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4289 if (NILP (string)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4290 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4291 CHECK_NUMBER_COERCE_MARKER (position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4292 pos = XINT (position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4293 if (pos < BEGV || pos >= ZV) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4294 args_out_of_range_3 (position, make_number (BEGV), make_number (ZV)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4295 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4296 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4297 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4298 CHECK_NUMBER (position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4299 CHECK_STRING (string); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4300 pos = XINT (position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4301 if (pos < 0 || pos >= SCHARS (string)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4302 args_out_of_range (string, position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4303 } |
| 90541 | 4304 if (NILP (window)) |
| 4305 window = selected_window; | |
| 4306 CHECK_LIVE_WINDOW (window); | |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
4307 w = XWINDOW (window); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
4308 |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
4309 return font_at (-1, pos, NULL, w, string); |
| 90541 | 4310 } |
| 4311 | |
| 90400 | 4312 #if 0 |
| 4313 DEFUN ("draw-string", Fdraw_string, Sdraw_string, 2, 2, 0, | |
| 4314 doc: /* Draw STRING by FONT-OBJECT on the top left corner of the current frame. | |
| 4315 The value is a number of glyphs drawn. | |
| 4316 Type C-l to recover what previously shown. */) | |
| 4317 (font_object, string) | |
| 4318 Lisp_Object font_object, string; | |
| 4319 { | |
| 4320 Lisp_Object frame = selected_frame; | |
| 4321 FRAME_PTR f = XFRAME (frame); | |
| 4322 struct font *font; | |
| 4323 struct face *face; | |
| 4324 int i, len, width; | |
| 4325 unsigned *code; | |
| 4326 | |
| 4327 CHECK_FONT_GET_OBJECT (font_object, font); | |
| 4328 CHECK_STRING (string); | |
| 4329 len = SCHARS (string); | |
| 4330 code = alloca (sizeof (unsigned) * len); | |
| 4331 for (i = 0; i < len; i++) | |
| 4332 { | |
| 4333 Lisp_Object ch = Faref (string, make_number (i)); | |
| 4334 Lisp_Object val; | |
| 4335 int c = XINT (ch); | |
| 4336 | |
| 4337 code[i] = font->driver->encode_char (font, c); | |
| 4338 if (code[i] == FONT_INVALID_CODE) | |
| 4339 break; | |
| 4340 } | |
| 4341 face = FACE_FROM_ID (f, DEFAULT_FACE_ID); | |
| 4342 face->fontp = font; | |
| 4343 if (font->driver->prepare_face) | |
| 4344 font->driver->prepare_face (f, face); | |
| 4345 width = font->driver->text_extents (font, code, i, NULL); | |
| 4346 len = font->driver->draw_text (f, face, 0, font->ascent, code, i, width); | |
| 4347 if (font->driver->done_face) | |
| 4348 font->driver->done_face (f, face); | |
| 4349 face->fontp = NULL; | |
| 4350 return make_number (len); | |
| 4351 } | |
| 4352 #endif | |
| 4353 | |
| 4354 #endif /* FONT_DEBUG */ | |
| 4355 | |
| 4356 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4357 #define BUILD_STYLE_TABLE(TBL) \ |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4358 build_style_table ((TBL), sizeof TBL / sizeof (struct table_entry)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4359 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4360 static Lisp_Object |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4361 build_style_table (entry, nelement) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4362 struct table_entry *entry; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4363 int nelement; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4364 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4365 int i, j; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4366 Lisp_Object table, elt; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4367 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4368 table = Fmake_vector (make_number (nelement), Qnil); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4369 for (i = 0; i < nelement; i++) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4370 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4371 for (j = 0; entry[i].names[j]; j++); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4372 elt = Fmake_vector (make_number (j + 1), Qnil); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4373 ASET (elt, 0, make_number (entry[i].numeric)); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4374 for (j = 0; entry[i].names[j]; j++) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4375 ASET (elt, j + 1, intern (entry[i].names[j])); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4376 ASET (table, i, elt); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4377 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4378 return table; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4379 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4380 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4381 static Lisp_Object Vfont_log; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4382 static int font_log_env_checked; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4383 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4384 void |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4385 font_add_log (action, arg, result) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4386 char *action; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4387 Lisp_Object arg, result; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4388 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4389 Lisp_Object tail, val; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4390 int i; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4391 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4392 if (! font_log_env_checked) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4393 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4394 Vfont_log = egetenv ("EMACS_FONT_LOG") ? Qnil : Qt; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4395 font_log_env_checked = 1; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4396 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4397 if (EQ (Vfont_log, Qt)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4398 return; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4399 if (FONTP (arg)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4400 arg = Ffont_xlfd_name (arg, Qt); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4401 if (FONTP (result)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4402 result = Ffont_xlfd_name (result, Qt); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4403 else if (CONSP (result)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4404 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4405 result = Fcopy_sequence (result); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4406 for (tail = result; CONSP (tail); tail = XCDR (tail)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4407 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4408 val = XCAR (tail); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4409 if (FONTP (val)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4410 val = Ffont_xlfd_name (val, Qt); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4411 XSETCAR (tail, val); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4412 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4413 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4414 else if (VECTORP (result)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4415 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4416 result = Fcopy_sequence (result); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4417 for (i = 0; i < ASIZE (result); i++) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4418 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4419 val = AREF (result, i); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4420 if (FONTP (val)) |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4421 val = Ffont_xlfd_name (val, Qt); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4422 ASET (result, i, val); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4423 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4424 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4425 Vfont_log = Fcons (list3 (intern (action), arg, result), Vfont_log); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4426 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4427 |
| 90400 | 4428 extern void syms_of_ftfont P_ (()); |
| 4429 extern void syms_of_xfont P_ (()); | |
| 4430 extern void syms_of_xftfont P_ (()); | |
| 4431 extern void syms_of_ftxfont P_ (()); | |
| 4432 extern void syms_of_bdffont P_ (()); | |
| 4433 extern void syms_of_w32font P_ (()); | |
| 4434 extern void syms_of_atmfont P_ (()); | |
| 4435 | |
| 4436 void | |
| 4437 syms_of_font () | |
| 4438 { | |
| 4439 sort_shift_bits[FONT_SLANT_INDEX] = 0; | |
| 4440 sort_shift_bits[FONT_WEIGHT_INDEX] = 7; | |
| 4441 sort_shift_bits[FONT_SIZE_INDEX] = 14; | |
| 4442 sort_shift_bits[FONT_WIDTH_INDEX] = 21; | |
| 4443 sort_shift_bits[FONT_ADSTYLE_INDEX] = 28; | |
| 4444 sort_shift_bits[FONT_FOUNDRY_INDEX] = 29; | |
| 4445 sort_shift_bits[FONT_FAMILY_INDEX] = 30; | |
| 94926 | 4446 /* Note that sort_shift_bits[FONT_SORT_TYPE] and |
| 4447 sort_shift_bits[FONT_SORT_REGISTRY] are never used. */ | |
| 90400 | 4448 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4449 staticpro (&font_charset_alist); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4450 font_charset_alist = Qnil; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4451 |
| 94926 | 4452 DEFSYM (Qfont_spec, "font-spec"); |
| 4453 DEFSYM (Qfont_entity, "font-entity"); | |
| 4454 DEFSYM (Qfont_object, "font-object"); | |
| 4455 | |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4456 DEFSYM (Qopentype, "opentype"); |
| 90400 | 4457 |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
4458 DEFSYM (Qiso8859_1, "iso8859-1"); |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
4459 DEFSYM (Qiso10646_1, "iso10646-1"); |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
4460 DEFSYM (Qunicode_bmp, "unicode-bmp"); |
|
90622
bb9362e3a03b
(Qunicode_sip): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90590
diff
changeset
|
4461 DEFSYM (Qunicode_sip, "unicode-sip"); |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
4462 |
| 90400 | 4463 DEFSYM (QCotf, ":otf"); |
| 94926 | 4464 DEFSYM (QClang, ":lang"); |
| 90400 | 4465 DEFSYM (QCscript, ":script"); |
|
91125
6c9a19ff6c55
(Qfontp): Remove unused symbol.
Jason Rumney <jasonr@gnu.org>
parents:
91112
diff
changeset
|
4466 DEFSYM (QCantialias, ":antialias"); |
| 90400 | 4467 |
| 4468 DEFSYM (QCfoundry, ":foundry"); | |
| 4469 DEFSYM (QCadstyle, ":adstyle"); | |
| 4470 DEFSYM (QCregistry, ":registry"); | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
4471 DEFSYM (QCspacing, ":spacing"); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
4472 DEFSYM (QCdpi, ":dpi"); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4473 DEFSYM (QCscalable, ":scalable"); |
| 94926 | 4474 DEFSYM (QCavgwidth, ":avgwidth"); |
| 4475 DEFSYM (QCfont_entity, ":font-entity"); | |
| 4476 DEFSYM (QCfc_unknown_spec, ":fc-unknown-spec"); | |
| 90400 | 4477 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4478 DEFSYM (Qc, "c"); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4479 DEFSYM (Qm, "m"); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4480 DEFSYM (Qp, "p"); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4481 DEFSYM (Qd, "d"); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4482 |
| 90400 | 4483 staticpro (&null_vector); |
| 4484 null_vector = Fmake_vector (make_number (0), Qnil); | |
| 4485 | |
| 4486 staticpro (&scratch_font_spec); | |
| 4487 scratch_font_spec = Ffont_spec (0, NULL); | |
| 4488 staticpro (&scratch_font_prefer); | |
| 4489 scratch_font_prefer = Ffont_spec (0, NULL); | |
| 4490 | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4491 #ifdef HAVE_LIBOTF |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4492 staticpro (&otf_list); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4493 otf_list = Qnil; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4494 #endif |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4495 |
| 90400 | 4496 defsubr (&Sfontp); |
| 4497 defsubr (&Sfont_spec); | |
| 4498 defsubr (&Sfont_get); | |
| 4499 defsubr (&Sfont_put); | |
| 4500 defsubr (&Slist_fonts); | |
| 94926 | 4501 defsubr (&Sfont_family_list); |
| 90400 | 4502 defsubr (&Sfind_font); |
| 4503 defsubr (&Sfont_xlfd_name); | |
| 4504 defsubr (&Sclear_font_cache); | |
| 4505 defsubr (&Sfont_make_gstring); | |
| 4506 defsubr (&Sfont_fill_gstring); | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4507 defsubr (&Sfont_shape_text); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4508 defsubr (&Sfont_drive_otf); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4509 defsubr (&Sfont_otf_alternates); |
| 90400 | 4510 |
| 4511 #ifdef FONT_DEBUG | |
| 4512 defsubr (&Sopen_font); | |
| 4513 defsubr (&Sclose_font); | |
| 4514 defsubr (&Squery_font); | |
| 4515 defsubr (&Sget_font_glyphs); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4516 defsubr (&Sfont_match_p); |
| 90541 | 4517 defsubr (&Sfont_at); |
| 90400 | 4518 #if 0 |
| 4519 defsubr (&Sdraw_string); | |
| 4520 #endif | |
| 4521 #endif /* FONT_DEBUG */ | |
| 4522 | |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4523 DEFVAR_LISP ("font-encoding-alist", &Vfont_encoding_alist, |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4524 doc: /* |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4525 Alist of fontname patterns vs the corresponding encoding and repertory info. |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4526 Each element looks like (REGEXP . (ENCODING . REPERTORY)), |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4527 where ENCODING is a charset or a char-table, |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4528 and REPERTORY is a charset, a char-table, or nil. |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4529 |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4530 If ENCODING and REPERTORY are the same, the element can have the form |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4531 \(REGEXP . ENCODING). |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4532 |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4533 ENCODING is for converting a character to a glyph code of the font. |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4534 If ENCODING is a charset, encoding a character by the charset gives |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4535 the corresponding glyph code. If ENCODING is a char-table, looking up |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4536 the table by a character gives the corresponding glyph code. |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4537 |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4538 REPERTORY specifies a repertory of characters supported by the font. |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4539 If REPERTORY is a charset, all characters beloging to the charset are |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4540 supported. If REPERTORY is a char-table, all characters who have a |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4541 non-nil value in the table are supported. If REPERTORY is nil, Emacs |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4542 gets the repertory information by an opened font and ENCODING. */); |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4543 Vfont_encoding_alist = Qnil; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4544 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4545 DEFVAR_LISP_NOPRO ("font-weight-table", &Vfont_weight_table, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4546 doc: /* Vector of valid font weight values. |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4547 Each element has the form: |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4548 [NUMERIC-VALUE SYMBOLIC-NAME ALIAS-NAME ...] |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4549 NUMERIC-VALUE is an integer, and SYMBOLIC-NAME and ALIAS-NAME are symobls. */); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4550 Vfont_weight_table = BUILD_STYLE_TABLE (weight_table); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4551 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4552 DEFVAR_LISP_NOPRO ("font-slant-table", &Vfont_slant_table, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4553 doc: /* Vector of font slant symbols vs the corresponding numeric values. |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4554 See `font-weight_table' for the format of the vector. */); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4555 Vfont_slant_table = BUILD_STYLE_TABLE (slant_table); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4556 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4557 DEFVAR_LISP_NOPRO ("font-width-table", &Vfont_width_table, |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4558 doc: /* Alist of font width symbols vs the corresponding numeric values. |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4559 See `font-weight_table' for the format of the vector. */); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4560 Vfont_width_table = BUILD_STYLE_TABLE (width_table); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4561 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4562 staticpro (&font_style_table); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4563 font_style_table = Fmake_vector (make_number (3), Qnil); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4564 ASET (font_style_table, 0, Vfont_weight_table); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4565 ASET (font_style_table, 1, Vfont_slant_table); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4566 ASET (font_style_table, 2, Vfont_width_table); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4567 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4568 DEFVAR_LISP ("font-log", &Vfont_log, doc: /* |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4569 *Logging list of font related actions and results. |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4570 The value t means to suppress the logging. |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4571 The initial value is set to nil if the environment variable |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4572 EMACS_FONT_LOG is set. Otherwise, it is set to t. */); |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4573 Vfont_log = Qnil; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4574 |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4575 #ifdef HAVE_WINDOW_SYSTEM |
| 90400 | 4576 #ifdef HAVE_FREETYPE |
| 94926 | 4577 syms_of_ftfont (); |
| 90400 | 4578 #ifdef HAVE_X_WINDOWS |
| 94926 | 4579 syms_of_xfont (); |
| 4580 syms_of_ftxfont (); | |
| 90400 | 4581 #ifdef HAVE_XFT |
| 94926 | 4582 syms_of_xftfont (); |
| 90400 | 4583 #endif /* HAVE_XFT */ |
| 4584 #endif /* HAVE_X_WINDOWS */ | |
| 4585 #else /* not HAVE_FREETYPE */ | |
| 4586 #ifdef HAVE_X_WINDOWS | |
| 94926 | 4587 syms_of_xfont (); |
| 90400 | 4588 #endif /* HAVE_X_WINDOWS */ |
| 4589 #endif /* not HAVE_FREETYPE */ | |
| 4590 #ifdef HAVE_BDFFONT | |
| 94926 | 4591 syms_of_bdffont (); |
| 90400 | 4592 #endif /* HAVE_BDFFONT */ |
| 4593 #ifdef WINDOWSNT | |
| 94926 | 4594 syms_of_w32font (); |
| 90400 | 4595 #endif /* WINDOWSNT */ |
| 4596 #ifdef MAC_OS | |
| 94926 | 4597 syms_of_atmfont (); |
| 90400 | 4598 #endif /* MAC_OS */ |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4599 #endif /* HAVE_WINDOW_SYSTEM */ |
| 90400 | 4600 } |
| 90427 | 4601 |
| 4602 /* arch-tag: 74c9475d-5976-4c93-a327-942ae3072846 | |
| 4603 (do not change this comment) */ |
