Mercurial > emacs
annotate src/font.c @ 95746:b490fda95b13
(font_intern_prop): New arg force_symbol.
(font_parse_xlfd): Adjusted for the change of font_intern_prop.
(font_parse_fcname): Likewise.
(font_parse_family_registry): Likewise.
| author | Kenichi Handa <handa@m17n.org> |
|---|---|
| date | Tue, 10 Jun 2008 02:09:15 +0000 |
| parents | 0afdc320716c |
| children | a486132d892c |
| 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. */ |
| 95699 | 58 Lisp_Object Qascii_0, 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. | |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
215 If FORCE_SYMBOL is zero and all characters in STR are digits, it |
|
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
216 returns an integer. Otherwise, it returns a symbol interned from |
|
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
217 STR. */ |
| 94926 | 218 |
| 219 Lisp_Object | |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
220 font_intern_prop (str, len, force_symbol) |
| 94926 | 221 char *str; |
| 222 int len; | |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
223 int force_symbol; |
| 94926 | 224 { |
| 225 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
|
226 Lisp_Object tem; |
| 94926 | 227 Lisp_Object obarray; |
| 228 | |
| 229 if (len == 1 && *str == '*') | |
| 230 return Qnil; | |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
231 if (!force_symbol && len >=1 && isdigit (*str)) |
| 94926 | 232 { |
| 233 for (i = 1; i < len; i++) | |
| 234 if (! isdigit (str[i])) | |
| 235 break; | |
| 236 if (i == len) | |
| 237 return make_number (atoi (str)); | |
| 238 } | |
| 239 | |
| 240 /* The following code is copied from the function intern (in lread.c). */ | |
| 241 obarray = Vobarray; | |
| 242 if (!VECTORP (obarray) || XVECTOR (obarray)->size == 0) | |
| 243 obarray = check_obarray (obarray); | |
| 244 tem = oblookup (obarray, str, len, len); | |
| 245 if (SYMBOLP (tem)) | |
| 246 return tem; | |
| 247 return Fintern (make_unibyte_string (str, len), obarray); | |
| 248 } | |
| 249 | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
250 /* 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
|
251 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
252 static int |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
253 font_pixel_size (f, spec) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
254 FRAME_PTR f; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
255 Lisp_Object spec; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
256 { |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
257 #ifdef HAVE_WINDOW_SYSTEM |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
258 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
|
259 double point_size; |
| 94926 | 260 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
|
261 Lisp_Object val; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
262 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
263 if (INTEGERP (size)) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
264 return XINT (size); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
265 if (NILP (size)) |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
266 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
|
267 font_assert (FLOATP (size)); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
268 point_size = XFLOAT_DATA (size); |
| 94926 | 269 val = AREF (spec, FONT_DPI_INDEX); |
| 270 if (INTEGERP (val)) | |
|
95483
d3cbd7d56845
(font_pixel_size): Don't take cdr of an integer.
Chong Yidong <cyd@stupidchicken.com>
parents:
95475
diff
changeset
|
271 dpi = XINT (val); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
272 else |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
273 dpi = f->resy; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
274 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
|
275 return pixel_size; |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
276 #else |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
277 return 1; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
278 #endif |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
279 } |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
280 |
| 94926 | 281 |
| 282 /* Return a value of PROP's VAL (symbol or integer) to be stored in a | |
| 283 font vector. If VAL is not valid (i.e. not registered in | |
| 284 font_style_table), return -1 if NOERROR is zero, and return a | |
| 285 proper index if NOERROR is nonzero. In that case, register VAL in | |
| 286 font_style_table if VAL is a symbol, and return a closest index if | |
| 287 VAL is an integer. */ | |
| 288 | |
| 289 int | |
| 290 font_style_to_value (prop, val, noerror) | |
| 90400 | 291 enum font_property_index prop; |
| 94926 | 292 Lisp_Object val; |
| 293 int noerror; | |
| 90400 | 294 { |
| 94926 | 295 Lisp_Object table = AREF (font_style_table, prop - FONT_WEIGHT_INDEX); |
| 296 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
|
297 int i, j; |
| 94926 | 298 |
| 299 if (SYMBOLP (val)) | |
| 90400 | 300 { |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
301 unsigned char *s; |
| 94926 | 302 Lisp_Object args[2], elt; |
| 303 | |
| 304 /* At first try exact match. */ | |
| 305 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
|
306 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
|
307 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
|
308 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
|
309 | (i << 4) | (j - 1)); |
| 94926 | 310 /* Try also with case-folding match. */ |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
311 s = SDATA (SYMBOL_NAME (val)); |
| 94926 | 312 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
|
313 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
|
314 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
315 elt = AREF (AREF (table, i), j); |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
316 if (xstrcasecmp (s, 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
|
317 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
|
318 | (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
|
319 } |
| 94926 | 320 if (! noerror) |
| 321 return -1; | |
| 322 if (len == 255) | |
| 323 abort (); | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
324 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
|
325 ASET (elt, 1, val); |
| 94926 | 326 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
|
327 args[1] = Fmake_vector (make_number (1), elt); |
| 94926 | 328 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
|
329 return (255 << 8) | (i << 4); |
| 90400 | 330 } |
| 94926 | 331 else |
| 332 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
333 int i, last_n; |
| 94926 | 334 int numeric = XINT (val); |
| 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 for (i = 0, last_n = -1; i < len; i++) |
| 94926 | 337 { |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
338 int n = XINT (AREF (AREF (table, i), 0)); |
| 94926 | 339 |
| 340 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
|
341 return (n << 8) | (i << 4); |
| 94926 | 342 if (numeric < n) |
| 343 { | |
| 344 if (! noerror) | |
| 345 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
|
346 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
|
347 ? (n << 8) | (i << 4): (last_n << 8 | ((i - 1) << 4))); |
| 94926 | 348 } |
| 349 last_n = n; | |
| 350 } | |
| 351 if (! noerror) | |
| 352 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
|
353 return ((last_n << 8) | ((i - 1) << 4)); |
| 94926 | 354 } |
| 90400 | 355 } |
| 356 | |
| 357 Lisp_Object | |
| 94926 | 358 font_style_symbolic (font, prop, for_face) |
| 359 Lisp_Object font; | |
| 360 enum font_property_index prop; | |
| 361 int for_face; | |
| 90400 | 362 { |
| 94926 | 363 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
|
364 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
|
365 int i; |
| 94926 | 366 |
| 367 if (NILP (val)) | |
| 368 return Qnil; | |
| 369 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
|
370 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
|
371 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
|
372 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
|
373 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
|
374 return (for_face ? AREF (elt, 1) : AREF (elt, (i & 0xF) + 1)); |
| 90400 | 375 } |
| 376 | |
| 377 extern Lisp_Object Vface_alternative_font_family_alist; | |
| 378 | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
379 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
|
380 |
| 94926 | 381 |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
382 /* 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
|
383 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
|
384 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
|
385 |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
386 Lisp_Object |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
387 find_font_encoding (fontname) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
388 Lisp_Object fontname; |
|
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 Lisp_Object tail, elt; |
|
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 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
|
393 { |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
394 elt = XCAR (tail); |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
395 if (CONSP (elt) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
396 && STRINGP (XCAR (elt)) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
397 && 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
|
398 && (SYMBOLP (XCDR (elt)) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
399 ? CHARSETP (XCDR (elt)) |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
400 : 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
|
401 return (XCDR (elt)); |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
402 } |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
403 /* 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
|
404 return Qascii; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
405 } |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
406 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
407 /* 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
|
408 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
|
409 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
|
410 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
411 int |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
412 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
|
413 Lisp_Object registry; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
414 struct charset **encoding, **repertory; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
415 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
416 Lisp_Object val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
417 int encoding_id, repertory_id; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
418 |
| 94926 | 419 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
|
420 if (! NILP (val)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
421 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
422 val = XCDR (val); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
423 if (NILP (val)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
424 return -1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
425 encoding_id = XINT (XCAR (val)); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
426 repertory_id = XINT (XCDR (val)); |
|
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 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
429 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
430 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
|
431 if (SYMBOLP (val) && CHARSETP (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 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
|
434 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
435 else if (CONSP (val)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
436 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
437 if (! CHARSETP (XCAR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
438 goto invalid_entry; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
439 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
|
440 if (NILP (XCDR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
441 repertory_id = -1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
442 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
443 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
444 if (! CHARSETP (XCDR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
445 goto invalid_entry; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
446 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
|
447 } |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
448 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
449 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
450 goto invalid_entry; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
451 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
|
452 font_charset_alist |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
453 = 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
|
454 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
455 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
456 if (encoding) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
457 *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
|
458 if (repertory) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
459 *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
|
460 return 0; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
461 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
462 invalid_entry: |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
463 font_charset_alist |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
464 = 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
|
465 return -1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
466 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
467 |
| 90400 | 468 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
469 /* 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
|
470 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
|
471 |
| 94926 | 472 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
|
473 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
|
474 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
|
475 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
|
476 static Lisp_Object font_prop_validate_spacing P_ ((Lisp_Object, Lisp_Object)); |
| 94926 | 477 static int get_font_prop_index P_ ((Lisp_Object)); |
| 90400 | 478 |
| 479 static Lisp_Object | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
480 font_prop_validate_symbol (prop, val) |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
481 Lisp_Object prop, val; |
| 90400 | 482 { |
| 483 if (STRINGP (val)) | |
| 94926 | 484 val = Fintern (val, Qnil); |
| 485 if (! SYMBOLP (val)) | |
| 486 val = Qerror; | |
| 487 else if (EQ (prop, QCregistry)) | |
| 488 val = Fintern (Fdowncase (SYMBOL_NAME (val)), Qnil); | |
| 489 return val; | |
| 490 } | |
| 491 | |
| 492 | |
| 493 static Lisp_Object | |
| 494 font_prop_validate_style (style, val) | |
| 495 Lisp_Object style, val; | |
| 496 { | |
| 497 enum font_property_index prop = (EQ (style, QCweight) ? FONT_WEIGHT_INDEX | |
| 498 : EQ (style, QCslant) ? FONT_SLANT_INDEX | |
| 499 : FONT_WIDTH_INDEX); | |
| 500 int n; | |
| 501 if (INTEGERP (val)) | |
| 502 { | |
| 503 n = XINT (val); | |
|
95194
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
504 if (((n >> 4) & 0xF) |
| 94926 | 505 >= ASIZE (AREF (font_style_table, prop - FONT_WEIGHT_INDEX))) |
| 506 val = Qerror; | |
| 507 else | |
| 508 { | |
|
95194
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
509 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
|
510 |
|
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
511 if ((n & 0xF) + 1 >= ASIZE (elt)) |
|
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
512 val = Qerror; |
|
6be267398fe5
(font_prop_validate_style): Adjusted for the format
Kenichi Handa <handa@m17n.org>
parents:
95177
diff
changeset
|
513 else if (XINT (AREF (elt, 0)) != (n >> 8)) |
| 94926 | 514 val = Qerror; |
| 515 } | |
| 516 } | |
| 90400 | 517 else if (SYMBOLP (val)) |
| 518 { | |
| 94926 | 519 int n = font_style_to_value (prop, val, 0); |
| 520 | |
| 521 val = n >= 0 ? make_number (n) : Qerror; | |
| 90400 | 522 } |
| 523 else | |
| 524 val = Qerror; | |
| 525 return val; | |
| 526 } | |
| 527 | |
| 528 static Lisp_Object | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
529 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
|
530 Lisp_Object prop, val; |
| 90400 | 531 { |
| 532 return (NATNUMP (val) || (FLOATP (val) && XFLOAT_DATA (val) >= 0) | |
| 533 ? val : Qerror); | |
| 534 } | |
| 535 | |
| 536 static Lisp_Object | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
537 font_prop_validate_spacing (prop, val) |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
538 Lisp_Object prop, val; |
| 90400 | 539 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
540 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
|
541 return val; |
|
95504
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
542 if (SYMBOLP (val) && SBYTES (SYMBOL_NAME (val)) == 1) |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
543 { |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
544 char spacing = SDATA (SYMBOL_NAME (val))[0]; |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
545 |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
546 if (spacing == 'c' || spacing == 'C') |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
547 return make_number (FONT_SPACING_CHARCELL); |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
548 if (spacing == 'm' || spacing == 'M') |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
549 return make_number (FONT_SPACING_MONO); |
|
95523
3c4256715c94
(font_prop_validate_spacing): Fix last change.
Andreas Schwab <schwab@suse.de>
parents:
95516
diff
changeset
|
550 if (spacing == 'p' || spacing == 'P') |
|
95504
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
551 return make_number (FONT_SPACING_PROPORTIONAL); |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
552 if (spacing == 'd' || spacing == 'D') |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
553 return make_number (FONT_SPACING_DUAL); |
|
00bdff60fc10
(font_prop_validate_spacing): Handle uppercase symbols.
Kenichi Handa <handa@m17n.org>
parents:
95483
diff
changeset
|
554 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
555 return Qerror; |
| 90400 | 556 } |
| 557 | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
558 static Lisp_Object |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
559 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
|
560 Lisp_Object prop, val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
561 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
562 Lisp_Object tail, tmp; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
563 int i; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
564 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
565 /* 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
|
566 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
|
567 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
|
568 if (! CONSP (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 if (! SYMBOLP (XCAR (val))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
571 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
572 tail = XCDR (val); |
|
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) || ! SYMBOLP (XCAR (val))) |
|
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 (i = 0; i < 2; i++) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
578 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
579 tail = XCDR (tail); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
580 if (NILP (tail)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
581 return val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
582 if (! CONSP (tail)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
583 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
584 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
|
585 if (! SYMBOLP (XCAR (tmp))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
586 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
587 if (! NILP (tmp)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
588 return Qerror; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
589 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
590 return val; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
591 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
592 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
593 /* 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
|
594 values. */ |
| 90400 | 595 struct |
| 596 { | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
597 /* Pointer to the key symbol. */ |
| 90400 | 598 Lisp_Object *key; |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
599 /* 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
|
600 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
|
601 and Qerror if not. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
602 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
|
603 } font_property_table[] = |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
604 { { &QCtype, font_prop_validate_symbol }, |
| 90400 | 605 { &QCfoundry, font_prop_validate_symbol }, |
| 606 { &QCfamily, font_prop_validate_symbol }, | |
| 607 { &QCadstyle, font_prop_validate_symbol }, | |
| 608 { &QCregistry, font_prop_validate_symbol }, | |
| 609 { &QCweight, font_prop_validate_style }, | |
| 610 { &QCslant, font_prop_validate_style }, | |
| 611 { &QCwidth, font_prop_validate_style }, | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
612 { &QCsize, font_prop_validate_non_neg }, |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
613 { &QCdpi, font_prop_validate_non_neg }, |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
614 { &QCspacing, font_prop_validate_spacing }, |
| 94926 | 615 { &QCavgwidth, font_prop_validate_non_neg }, |
| 616 /* The order of the above entries must match with enum | |
| 617 font_property_index. */ | |
| 618 { &QClang, font_prop_validate_symbol }, | |
| 619 { &QCscript, font_prop_validate_symbol }, | |
| 620 { &QCotf, font_prop_validate_otf } | |
| 90400 | 621 }; |
| 622 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
623 /* 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
|
624 #define FONT_PROPERTY_TABLE_SIZE \ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
625 ((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
|
626 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
627 /* Return an index number of font property KEY or -1 if KEY is not an |
| 94926 | 628 already known property. */ |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
629 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
630 static int |
| 94926 | 631 get_font_prop_index (key) |
| 90400 | 632 Lisp_Object key; |
| 633 { | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
634 int i; |
| 94926 | 635 |
| 636 for (i = 0; i < FONT_PROPERTY_TABLE_SIZE; i++) | |
| 637 if (EQ (key, *font_property_table[i].key)) | |
| 638 return i; | |
| 639 return -1; | |
| 640 } | |
| 641 | |
| 642 /* Validate the font property. The property key is specified by the | |
| 643 symbol PROP, or the index IDX (if PROP is nil). If VAL is invalid, | |
| 644 signal an error. The value is VAL or the regularized one. */ | |
| 645 | |
| 646 static Lisp_Object | |
| 647 font_prop_validate (idx, prop, val) | |
| 648 int idx; | |
| 649 Lisp_Object prop, val; | |
| 650 { | |
| 651 Lisp_Object validated; | |
| 652 | |
|
94964
5ffc88767cc1
(font_prop_validate): Make nil a valid value.
Kenichi Handa <handa@m17n.org>
parents:
94963
diff
changeset
|
653 if (NILP (val)) |
|
5ffc88767cc1
(font_prop_validate): Make nil a valid value.
Kenichi Handa <handa@m17n.org>
parents:
94963
diff
changeset
|
654 return val; |
| 94926 | 655 if (NILP (prop)) |
| 656 prop = *font_property_table[idx].key; | |
| 657 else | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
658 { |
| 94926 | 659 idx = get_font_prop_index (prop); |
| 660 if (idx < 0) | |
| 661 return val; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
662 } |
| 94926 | 663 validated = (font_property_table[idx].validater) (prop, val); |
| 664 if (EQ (validated, Qerror)) | |
| 665 signal_error ("invalid font property", Fcons (prop, val)); | |
| 666 return validated; | |
| 90400 | 667 } |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
668 |
| 94926 | 669 |
| 670 /* Store VAL as a value of extra font property PROP in FONT while | |
| 671 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
|
672 |
|
90888
5f03b3602143
(font_put_extra): Expose externally.
Jason Rumney <jasonr@gnu.org>
parents:
90883
diff
changeset
|
673 Lisp_Object |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
674 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
|
675 Lisp_Object font, prop, val; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
676 { |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
677 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
|
678 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
|
679 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
680 if (NILP (slot)) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
681 { |
| 94926 | 682 Lisp_Object prev = Qnil; |
| 683 | |
| 684 while (CONSP (extra) | |
| 685 && NILP (Fstring_lessp (prop, XCAR (XCAR (extra))))) | |
| 686 prev = extra, extra = XCDR (extra); | |
| 687 if (NILP (prev)) | |
| 688 ASET (font, FONT_EXTRA_INDEX, Fcons (Fcons (prop, val), extra)); | |
| 689 else | |
| 690 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
|
691 return val; |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
692 } |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
693 XSETCDR (slot, val); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
694 return val; |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
695 } |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
696 |
| 90400 | 697 |
| 698 /* Font name parser and unparser */ | |
| 699 | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
700 static int parse_matrix P_ ((char *)); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
701 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
|
702 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
|
703 |
| 90400 | 704 /* An enumerator for each field of an XLFD font name. */ |
| 705 enum xlfd_field_index | |
| 706 { | |
| 707 XLFD_FOUNDRY_INDEX, | |
| 708 XLFD_FAMILY_INDEX, | |
| 709 XLFD_WEIGHT_INDEX, | |
| 710 XLFD_SLANT_INDEX, | |
| 711 XLFD_SWIDTH_INDEX, | |
| 712 XLFD_ADSTYLE_INDEX, | |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
713 XLFD_PIXEL_INDEX, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
714 XLFD_POINT_INDEX, |
| 90400 | 715 XLFD_RESX_INDEX, |
| 716 XLFD_RESY_INDEX, | |
| 717 XLFD_SPACING_INDEX, | |
| 718 XLFD_AVGWIDTH_INDEX, | |
| 719 XLFD_REGISTRY_INDEX, | |
| 720 XLFD_ENCODING_INDEX, | |
| 721 XLFD_LAST_INDEX | |
| 722 }; | |
| 723 | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
724 /* 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
|
725 enum xlfd_field_mask |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
726 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
727 XLFD_FOUNDRY_MASK = 0x0001, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
728 XLFD_FAMILY_MASK = 0x0002, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
729 XLFD_WEIGHT_MASK = 0x0004, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
730 XLFD_SLANT_MASK = 0x0008, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
731 XLFD_SWIDTH_MASK = 0x0010, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
732 XLFD_ADSTYLE_MASK = 0x0020, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
733 XLFD_PIXEL_MASK = 0x0040, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
734 XLFD_POINT_MASK = 0x0080, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
735 XLFD_RESX_MASK = 0x0100, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
736 XLFD_RESY_MASK = 0x0200, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
737 XLFD_SPACING_MASK = 0x0400, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
738 XLFD_AVGWIDTH_MASK = 0x0800, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
739 XLFD_REGISTRY_MASK = 0x1000, |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
740 XLFD_ENCODING_MASK = 0x2000 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
741 }; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
742 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
743 |
| 90400 | 744 /* Parse P pointing the pixel/point size field of the form |
| 745 `[A B C D]' which specifies a transformation matrix: | |
| 746 | |
| 747 A B 0 | |
| 748 C D 0 | |
| 749 0 0 1 | |
| 750 | |
| 751 by which all glyphs of the font are transformed. The spec says | |
| 752 that scalar value N for the pixel/point size is equivalent to: | |
| 753 A = N * resx/resy, B = C = 0, D = N. | |
| 754 | |
| 755 Return the scalar value N if the form is valid. Otherwise return | |
| 756 -1. */ | |
| 757 | |
| 758 static int | |
| 759 parse_matrix (p) | |
| 760 char *p; | |
| 761 { | |
| 762 double matrix[4]; | |
| 763 char *end; | |
| 764 int i; | |
| 765 | |
| 766 for (i = 0, p++; i < 4 && *p && *p != ']'; i++) | |
| 767 { | |
| 768 if (*p == '~') | |
| 769 matrix[i] = - strtod (p + 1, &end); | |
| 770 else | |
| 771 matrix[i] = strtod (p, &end); | |
| 772 p = end; | |
| 773 } | |
| 774 return (i == 4 ? (int) matrix[3] : -1); | |
| 775 } | |
| 776 | |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
777 /* 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
|
778 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
|
779 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
|
780 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
781 static int |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
782 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
|
783 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
|
784 int n; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
785 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
786 /* Copy of FIELD. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
787 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
|
788 /* 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
|
789 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
|
790 struct { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
791 /* Minimum possible field. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
792 int from; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
793 /* Maxinum possible field. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
794 int to; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
795 /* 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
|
796 int mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
797 } range[XLFD_LAST_INDEX]; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
798 int i, j; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
799 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
|
800 unsigned range_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 #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
|
803 | 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
|
804 #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
|
805 #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
|
806 | XLFD_AVGWIDTH_MASK) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
807 #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
|
808 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
809 /* 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
|
810 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
|
811 following loop. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
812 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
|
813 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
|
814 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
815 /* 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
|
816 position-based retriction for FIELD[I]. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
817 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
|
818 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
|
819 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
820 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
|
821 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
822 tmp[i] = val; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
823 if (NILP (val)) |
|
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 /* Wildcard. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
826 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
|
827 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
|
828 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
|
829 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
830 else |
|
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 /* 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
|
833 retriction for FIELD[I]. */ |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
834 int from, to; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
835 unsigned mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
836 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
837 if (INTEGERP (val)) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
838 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
839 int numeric = XINT (val); |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
840 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
841 if (i + 1 == n) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
842 from = to = XLFD_ENCODING_INDEX, |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
843 mask = XLFD_ENCODING_MASK; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
844 else if (numeric == 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
845 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
|
846 mask = XLFD_PIXEL_MASK | XLFD_LARGENUM_MASK; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
847 else if (numeric <= 48) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
848 from = to = XLFD_PIXEL_INDEX, |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
849 mask = XLFD_PIXEL_MASK; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
850 else |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
851 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
|
852 mask = XLFD_LARGENUM_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
853 } |
| 94926 | 854 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
|
855 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
|
856 mask = XLFD_NULL_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
857 else if (i == 0) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
858 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
|
859 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
|
860 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
861 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
|
862 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
863 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
|
864 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
|
865 mask = XLFD_REGENC_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
866 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
867 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
|
868 mask = XLFD_ENCODING_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
869 } |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
870 else if (range_from <= XLFD_WEIGHT_INDEX |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
871 && range_to >= XLFD_WEIGHT_INDEX |
| 94926 | 872 && 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
|
873 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
|
874 else if (range_from <= XLFD_SLANT_INDEX |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
875 && range_to >= XLFD_SLANT_INDEX |
| 94926 | 876 && 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
|
877 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
|
878 else if (range_from <= XLFD_SWIDTH_INDEX |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
879 && range_to >= XLFD_SWIDTH_INDEX |
| 94926 | 880 && 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
|
881 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
|
882 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
883 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
884 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
|
885 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
|
886 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
887 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
|
888 mask = XLFD_SYMBOL_MASK; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
889 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
890 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
891 /* 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
|
892 mask &= range_mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
893 while (from < range_from) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
894 mask &= ~(1 << from++); |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
895 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
|
896 from++; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
897 while (to > range_to) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
898 mask &= ~(1 << to--); |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
899 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
|
900 to--; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
901 if (from > to) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
902 return -1; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
903 range[i].from = from; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
904 range[i].to = to; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
905 range[i].mask = mask; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
906 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
907 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
|
908 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
909 /* 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
|
910 Reflect it to the other fields. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
911 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
912 /* Following fields should be after FROM. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
913 range_from = from; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
914 /* Preceding fields should be before TO. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
915 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
|
916 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
917 /* Check FROM for non-wildcard field. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
918 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
|
919 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
920 while (range[j].from < from) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
921 range[j].mask &= ~(1 << range[j].from++); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
922 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
|
923 from++; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
924 range[j].from = from; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
925 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
926 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
927 from = range[j].from; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
928 if (range[j].to > to) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
929 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
930 while (range[j].to > to) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
931 range[j].mask &= ~(1 << range[j].to--); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
932 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
|
933 to--; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
934 range[j].to = to; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
935 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
936 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
937 to = range[j].to; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
938 if (from > to) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
939 return -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
940 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
941 } |
|
90451
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 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
944 |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
945 /* 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
|
946 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
|
947 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
948 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
|
949 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
950 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
|
951 /* 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
|
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 < range[i].from; 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 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
956 field[j++] = tmp[i]; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
957 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
958 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
|
959 return -1; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
960 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
|
961 field[j] = Qnil; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
962 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
|
963 field[XLFD_ENCODING_INDEX] |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
964 = 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
|
965 return 0; |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
966 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
967 |
|
92113
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 #ifdef ENABLE_CHECKING |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
970 /* 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
|
971 static int |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
972 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
|
973 { |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
974 while (*pattern && *name) |
|
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 if (*pattern == *name) |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
977 pattern++; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
978 else if (*pattern == '*') |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
979 if (*name == pattern[1]) |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
980 pattern += 2; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
981 else |
|
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 else |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
984 return 0; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
985 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 return 1; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
988 } |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
989 |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
990 /* 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
|
991 static int |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
992 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
|
993 { |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
994 char name_check[256]; |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
995 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
|
996 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
|
997 } |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
998 |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
999 #endif |
|
2a9ed1c080b4
(font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91943
diff
changeset
|
1000 |
| 94926 | 1001 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1002 /* 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
|
1003 (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
|
1004 follows: |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1005 specified XLFD fields FONT property |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1006 --------------------- ------------- |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1007 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
|
1008 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
|
1009 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
|
1010 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1011 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
|
1012 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1013 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
|
1014 X font backend driver, it is a font-entity. In that case, NAME is |
| 94926 | 1015 a fully specified XLFD. */ |
| 90400 | 1016 |
| 1017 int | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1018 font_parse_xlfd (name, font) |
| 90400 | 1019 char *name; |
| 1020 Lisp_Object font; | |
| 1021 { | |
| 1022 int len = strlen (name); | |
| 94926 | 1023 int i, j, n; |
|
90695
a1cd7344d6a2
(font_parse_xlfd): Fix the array size of `f'.
Kenichi Handa <handa@m17n.org>
parents:
90677
diff
changeset
|
1024 char *f[XLFD_LAST_INDEX + 1]; |
| 90400 | 1025 Lisp_Object val; |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1026 char *p; |
| 90400 | 1027 |
| 1028 if (len > 255) | |
| 1029 /* Maximum XLFD name length is 255. */ | |
| 1030 return -1; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1031 /* Accept "*-.." as a fully specified XLFD. */ |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1032 if (name[0] == '*' && name[1] == '-') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1033 i = 1, f[XLFD_FOUNDRY_INDEX] = name; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1034 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1035 i = 0; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1036 for (p = name + i; *p; p++) |
| 94926 | 1037 if (*p == '-') |
| 1038 { | |
| 1039 f[i++] = p + 1; | |
| 1040 if (i == XLFD_LAST_INDEX) | |
| 1041 break; | |
| 1042 } | |
| 1043 f[i] = name + len; | |
| 1044 | |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1045 #define INTERN_FIELD(N) font_intern_prop (f[N], f[(N) + 1] - 1 - f[N], 0) |
|
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1046 #define INTERN_FIELD_SYM(N) font_intern_prop (f[N], f[(N) + 1] - 1 - f[N], 1) |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1047 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1048 if (i == XLFD_LAST_INDEX) |
| 90400 | 1049 { |
| 94926 | 1050 /* Fully specified XLFD. */ |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1051 int pixel_size; |
| 94926 | 1052 |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1053 ASET (font, FONT_FOUNDRY_INDEX, INTERN_FIELD_SYM (XLFD_FOUNDRY_INDEX)); |
|
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1054 ASET (font, FONT_FAMILY_INDEX, INTERN_FIELD_SYM (XLFD_FAMILY_INDEX)); |
| 94926 | 1055 for (i = XLFD_WEIGHT_INDEX, j = FONT_WEIGHT_INDEX; |
| 1056 i <= XLFD_SWIDTH_INDEX; i++, j++) | |
| 90400 | 1057 { |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1058 val = INTERN_FIELD_SYM (i); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1059 if (! NILP (val)) |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1060 { |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1061 if ((n = font_style_to_value (j, INTERN_FIELD_SYM (i), 0)) < 0) |
| 94926 | 1062 return -1; |
| 1063 ASET (font, j, make_number (n)); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1064 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1065 } |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1066 ASET (font, FONT_ADSTYLE_INDEX, INTERN_FIELD_SYM (XLFD_ADSTYLE_INDEX)); |
| 94926 | 1067 if (strcmp (f[XLFD_REGISTRY_INDEX], "*-*") == 0) |
| 1068 ASET (font, FONT_REGISTRY_INDEX, Qnil); | |
| 1069 else | |
| 1070 ASET (font, FONT_REGISTRY_INDEX, | |
| 1071 font_intern_prop (f[XLFD_REGISTRY_INDEX], | |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1072 f[XLFD_LAST_INDEX] - f[XLFD_REGISTRY_INDEX], |
|
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1073 1)); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1074 p = f[XLFD_PIXEL_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1075 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
|
1076 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
|
1077 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1078 { |
| 94926 | 1079 val = INTERN_FIELD (XLFD_PIXEL_INDEX); |
| 1080 if (INTEGERP (val)) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1081 ASET (font, FONT_SIZE_INDEX, val); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1082 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1083 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1084 double point_size = -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1085 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1086 font_assert (FONT_SPEC_P (font)); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1087 p = f[XLFD_POINT_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1088 if (*p == '[') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1089 point_size = parse_matrix (p); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1090 else if (isdigit (*p)) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1091 point_size = atoi (p), point_size /= 10; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1092 if (point_size >= 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1093 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
|
1094 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1095 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1096 |
| 94926 | 1097 ASET (font, FONT_DPI_INDEX, INTERN_FIELD (XLFD_RESY_INDEX)); |
| 1098 val = INTERN_FIELD (XLFD_SPACING_INDEX); | |
| 1099 if (! NILP (val)) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1100 { |
| 94926 | 1101 val = font_prop_validate_spacing (QCspacing, val); |
| 1102 if (! INTEGERP (val)) | |
| 1103 return -1; | |
| 1104 ASET (font, FONT_SPACING_INDEX, val); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1105 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1106 p = f[XLFD_AVGWIDTH_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1107 if (*p == '~') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1108 p++; |
| 94926 | 1109 ASET (font, FONT_AVGWIDTH_INDEX, |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1110 font_intern_prop (p, f[XLFD_REGISTRY_INDEX] - 1 - p, 1)); |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1111 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1112 else |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1113 { |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1114 int wild_card_found = 0; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1115 Lisp_Object prop[XLFD_LAST_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1116 |
| 94926 | 1117 if (FONT_ENTITY_P (font)) |
| 1118 return -1; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1119 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
|
1120 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1121 if (*f[j] == '*') |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1122 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1123 if (f[j][1] && f[j][1] != '-') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1124 return -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1125 prop[j] = Qnil; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1126 wild_card_found = 1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1127 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1128 else if (j + 1 < i) |
| 94926 | 1129 prop[j] = INTERN_FIELD (j); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1130 else |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1131 prop[j] = font_intern_prop (f[j], f[i] - f[j], 0); |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1132 } |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1133 if (! wild_card_found) |
|
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
1134 return -1; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1135 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
|
1136 return -1; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1137 |
| 94926 | 1138 ASET (font, FONT_FOUNDRY_INDEX, prop[XLFD_FOUNDRY_INDEX]); |
| 1139 ASET (font, FONT_FAMILY_INDEX, prop[XLFD_FAMILY_INDEX]); | |
| 1140 for (i = XLFD_WEIGHT_INDEX, j = FONT_WEIGHT_INDEX; | |
| 1141 i <= XLFD_SWIDTH_INDEX; i++, j++) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1142 if (! NILP (prop[i])) |
| 94926 | 1143 { |
| 1144 if ((n = font_style_to_value (j, prop[i], 1)) < 0) | |
| 1145 return -1; | |
| 1146 ASET (font, j, make_number (n)); | |
| 1147 } | |
| 1148 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
|
1149 val = prop[XLFD_REGISTRY_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1150 if (NILP (val)) |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1151 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1152 val = prop[XLFD_ENCODING_INDEX]; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1153 if (! NILP (val)) |
| 94926 | 1154 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
|
1155 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1156 else if (NILP (prop[XLFD_ENCODING_INDEX])) |
| 94926 | 1157 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
|
1158 else |
| 94926 | 1159 val = concat3 (SYMBOL_NAME (val), build_string ("-"), |
| 1160 SYMBOL_NAME (prop[XLFD_ENCODING_INDEX])); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1161 if (! NILP (val)) |
| 94926 | 1162 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
|
1163 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1164 if (INTEGERP (prop[XLFD_PIXEL_INDEX])) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1165 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
|
1166 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
|
1167 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1168 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
|
1169 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1170 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
|
1171 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1172 |
| 94926 | 1173 if (INTEGERP (prop[XLFD_RESX_INDEX])) |
| 1174 ASET (font, FONT_DPI_INDEX, prop[XLFD_RESY_INDEX]); | |
| 1175 if (! NILP (prop[XLFD_SPACING_INDEX])) | |
| 1176 { | |
| 1177 val = font_prop_validate_spacing (QCspacing, | |
| 1178 prop[XLFD_SPACING_INDEX]); | |
| 1179 if (! INTEGERP (val)) | |
| 1180 return -1; | |
| 1181 ASET (font, FONT_SPACING_INDEX, val); | |
| 1182 } | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1183 if (INTEGERP (prop[XLFD_AVGWIDTH_INDEX])) |
| 94926 | 1184 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
|
1185 } |
| 90400 | 1186 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1187 return 0; |
| 90400 | 1188 } |
| 1189 | |
| 1190 /* Store XLFD name of FONT (font-spec or font-entity) in NAME (NBYTES | |
| 1191 length), and return the name length. If FONT_SIZE_INDEX of FONT is | |
| 1192 0, use PIXEL_SIZE instead. */ | |
| 1193 | |
| 1194 int | |
| 1195 font_unparse_xlfd (font, pixel_size, name, nbytes) | |
| 1196 Lisp_Object font; | |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1197 int pixel_size; |
| 90400 | 1198 char *name; |
| 1199 int nbytes; | |
| 1200 { | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1201 char *f[XLFD_REGISTRY_INDEX + 1]; |
| 90400 | 1202 Lisp_Object val; |
| 1203 int i, j, len = 0; | |
| 1204 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1205 font_assert (FONTP (font)); |
| 90400 | 1206 |
| 1207 for (i = FONT_FOUNDRY_INDEX, j = XLFD_FOUNDRY_INDEX; i <= FONT_REGISTRY_INDEX; | |
| 1208 i++, j++) | |
| 1209 { | |
| 1210 if (i == FONT_ADSTYLE_INDEX) | |
| 1211 j = XLFD_ADSTYLE_INDEX; | |
| 1212 else if (i == FONT_REGISTRY_INDEX) | |
| 1213 j = XLFD_REGISTRY_INDEX; | |
| 1214 val = AREF (font, i); | |
| 1215 if (NILP (val)) | |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1216 { |
|
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 f[j] = "*-*", len += 4; |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1219 else |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1220 f[j] = "*", len += 2; |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1221 } |
| 90400 | 1222 else |
| 1223 { | |
| 1224 if (SYMBOLP (val)) | |
| 1225 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
|
1226 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
|
1227 && ! strchr ((char *) SDATA (val), '-')) |
|
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 /* 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
|
1230 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
|
1231 { |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1232 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
|
1233 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
|
1234 len += SBYTES (val) + 3; |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1235 } |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1236 else |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1237 { |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1238 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
|
1239 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
|
1240 len += SBYTES (val) + 4; |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1241 } |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1242 } |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1243 else |
|
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
1244 f[j] = (char *) SDATA (val), len += SBYTES (val) + 1; |
| 90400 | 1245 } |
| 1246 } | |
| 1247 | |
| 1248 for (i = FONT_WEIGHT_INDEX, j = XLFD_WEIGHT_INDEX; i <= FONT_WIDTH_INDEX; | |
| 1249 i++, j++) | |
| 1250 { | |
| 94926 | 1251 val = font_style_symbolic (font, i, 0); |
| 90400 | 1252 if (NILP (val)) |
| 1253 f[j] = "*", len += 2; | |
| 1254 else | |
| 1255 { | |
| 94926 | 1256 val = SYMBOL_NAME (val); |
| 90400 | 1257 f[j] = (char *) SDATA (val), len += SBYTES (val) + 1; |
| 1258 } | |
| 1259 } | |
| 1260 | |
| 1261 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
|
1262 font_assert (NUMBERP (val) || NILP (val)); |
| 90400 | 1263 if (INTEGERP (val)) |
| 1264 { | |
| 94926 | 1265 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
|
1266 if (i <= 0) |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1267 i = pixel_size; |
| 90400 | 1268 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
|
1269 { |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1270 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
|
1271 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
|
1272 } |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1273 else |
|
c5e5ad126614
(font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91909
diff
changeset
|
1274 f[XLFD_PIXEL_INDEX] = "*-*", len += 4; |
| 90400 | 1275 } |
| 1276 else if (FLOATP (val)) | |
| 1277 { | |
| 94926 | 1278 i = XFLOAT_DATA (val) * 10; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1279 f[XLFD_PIXEL_INDEX] = alloca (12); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1280 len += sprintf (f[XLFD_PIXEL_INDEX], "*-%d", i) + 1; |
| 90400 | 1281 } |
| 1282 else | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1283 f[XLFD_PIXEL_INDEX] = "*-*", len += 4; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1284 |
| 94926 | 1285 if (INTEGERP (AREF (font, FONT_DPI_INDEX))) |
| 90400 | 1286 { |
| 94926 | 1287 i = XINT (AREF (font, FONT_DPI_INDEX)); |
| 1288 f[XLFD_RESX_INDEX] = alloca (22); | |
| 1289 len += sprintf (f[XLFD_RESX_INDEX], | |
| 1290 "%d-%d", i, i) + 1; | |
| 90400 | 1291 } |
| 1292 else | |
| 94926 | 1293 f[XLFD_RESX_INDEX] = "*-*", len += 4; |
| 1294 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
|
1295 { |
| 94926 | 1296 int spacing = XINT (AREF (font, FONT_SPACING_INDEX)); |
| 1297 | |
| 1298 f[XLFD_SPACING_INDEX] = (spacing <= FONT_SPACING_PROPORTIONAL ? "p" | |
| 1299 : spacing <= FONT_SPACING_DUAL ? "d" | |
| 1300 : spacing <= FONT_SPACING_MONO ? "m" | |
| 1301 : "c"); | |
| 1302 len += 2; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1303 } |
| 94926 | 1304 else |
| 1305 f[XLFD_SPACING_INDEX] = "*", len += 2; | |
| 1306 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX))) | |
| 1307 { | |
| 1308 f[XLFD_AVGWIDTH_INDEX] = alloca (11); | |
| 1309 len += sprintf (f[XLFD_AVGWIDTH_INDEX], | |
| 1310 "%d", XINT (AREF (font, FONT_AVGWIDTH_INDEX))) + 1; | |
| 1311 } | |
| 1312 else | |
| 1313 f[XLFD_AVGWIDTH_INDEX] = "*", len += 2; | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1314 len++; /* for terminating '\0'. */ |
| 90400 | 1315 if (len >= nbytes) |
| 1316 return -1; | |
| 94926 | 1317 return sprintf (name, "-%s-%s-%s-%s-%s-%s-%s-%s-%s-%s-%s", |
| 90400 | 1318 f[XLFD_FOUNDRY_INDEX], f[XLFD_FAMILY_INDEX], |
| 1319 f[XLFD_WEIGHT_INDEX], f[XLFD_SLANT_INDEX], | |
| 94926 | 1320 f[XLFD_SWIDTH_INDEX], f[XLFD_ADSTYLE_INDEX], |
| 1321 f[XLFD_PIXEL_INDEX], f[XLFD_RESX_INDEX], | |
| 1322 f[XLFD_SPACING_INDEX], f[XLFD_AVGWIDTH_INDEX], | |
| 1323 f[XLFD_REGISTRY_INDEX]); | |
| 90400 | 1324 } |
| 1325 | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1326 /* 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
|
1327 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
|
1328 successfully parsed, return 0. Otherwise return -1. */ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1329 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1330 int |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1331 font_parse_fcname (name, font) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1332 char *name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1333 Lisp_Object font; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1334 { |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1335 char *p0, *p1; |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1336 int len = strlen (name); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1337 char *copy; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1338 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1339 if (len == 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1340 return -1; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1341 /* It is assured that (name[0] && name[0] != '-'). */ |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1342 if (name[0] == ':') |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1343 p0 = name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1344 else |
|
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 Lisp_Object family; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1347 double point_size; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1348 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1349 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
|
1350 if (*p0 == '\\' && p0[1]) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1351 p0++; |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1352 family = font_intern_prop (name, p0 - name, 1); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1353 if (*p0 == '-') |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1354 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1355 if (! isdigit (p0[1])) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1356 return -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1357 point_size = strtod (p0 + 1, &p1); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1358 if (*p1 && *p1 != ':') |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1359 return -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1360 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
|
1361 p0 = p1; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1362 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1363 ASET (font, FONT_FAMILY_INDEX, family); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1364 } |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1365 |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1366 len -= p0 - name; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1367 copy = alloca (len + 1); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1368 if (! copy) |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1369 return -1; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1370 name = copy; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
1371 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1372 /* Now parse ":KEY=VAL" patterns. Store known keys and values in |
| 94926 | 1373 extra, copy unknown ones to COPY. It is stored in extra slot by |
| 1374 the key QCfc_unknown_spec. */ | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1375 while (*p0) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1376 { |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1377 Lisp_Object key, val; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1378 int prop; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1379 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1380 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
|
1381 if (*p1 != '=') |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1382 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1383 /* Must be an enumerated value. */ |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1384 val = font_intern_prop (p0 + 1, p1 - p0 - 1, 1); |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1385 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
|
1386 || 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
|
1387 || 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
|
1388 || 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
|
1389 || memcmp (p0 + 1, "black", 5) == 0) |
| 94926 | 1390 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
|
1391 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
|
1392 || 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
|
1393 || memcmp (p0 + 1, "oblique", 7) == 0) |
| 94926 | 1394 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
|
1395 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
|
1396 || 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
|
1397 || 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
|
1398 { |
| 94926 | 1399 int spacing = (p0[1] == 'c' ? FONT_SPACING_CHARCELL |
| 1400 : p0[1] == 'm' ? FONT_SPACING_MONO | |
| 1401 : FONT_SPACING_PROPORTIONAL); | |
| 1402 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
|
1403 } |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1404 else |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1405 { |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1406 /* unknown key */ |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1407 bcopy (p0, copy, p1 - p0); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1408 copy += p1 - p0; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1409 } |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1410 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1411 else |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1412 { |
|
95516
cb48088b99e1
(font_parse_fcname): Fix handling of unknown key.
Kenichi Handa <handa@m17n.org>
parents:
95504
diff
changeset
|
1413 char *keyhead = p0; |
|
cb48088b99e1
(font_parse_fcname): Fix handling of unknown key.
Kenichi Handa <handa@m17n.org>
parents:
95504
diff
changeset
|
1414 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1415 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
|
1416 prop = FONT_SIZE_INDEX; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1417 else |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1418 { |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1419 key = font_intern_prop (p0, p1 - p0, 1); |
| 94926 | 1420 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
|
1421 } |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1422 p0 = p1 + 1; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1423 for (p1 = p0; *p1 && *p1 != ':'; p1++); |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1424 val = font_intern_prop (p0, p1 - p0, 0); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1425 if (! NILP (val)) |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1426 { |
| 94926 | 1427 if (prop >= FONT_FOUNDRY_INDEX && prop < FONT_EXTRA_INDEX) |
| 1428 ASET (font, prop, font_prop_validate (prop, Qnil, val)); | |
| 1429 else if (prop >= 0) | |
| 1430 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
|
1431 else |
|
95516
cb48088b99e1
(font_parse_fcname): Fix handling of unknown key.
Kenichi Handa <handa@m17n.org>
parents:
95504
diff
changeset
|
1432 bcopy (keyhead, copy, p1 - keyhead); |
|
cb48088b99e1
(font_parse_fcname): Fix handling of unknown key.
Kenichi Handa <handa@m17n.org>
parents:
95504
diff
changeset
|
1433 copy += p1 - keyhead; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1434 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1435 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1436 p0 = p1; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1437 } |
| 94926 | 1438 if (name != copy) |
| 1439 font_put_extra (font, QCfc_unknown_spec, | |
| 1440 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
|
1441 |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1442 return 0; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1443 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1444 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1445 /* 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
|
1446 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
|
1447 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
|
1448 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1449 int |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1450 font_unparse_fcname (font, pixel_size, name, nbytes) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1451 Lisp_Object font; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1452 int pixel_size; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1453 char *name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1454 int nbytes; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1455 { |
| 94926 | 1456 Lisp_Object tail, val; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1457 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
|
1458 int dpi; |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1459 int i, len = 1; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1460 char *p; |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
1461 Lisp_Object styles[3]; |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
1462 char *style_names[3] = { "weight", "slant", "width" }; |
| 94926 | 1463 char work[256]; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1464 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1465 val = AREF (font, FONT_FAMILY_INDEX); |
| 94926 | 1466 if (STRINGP (val)) |
| 1467 len += SBYTES (val); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1468 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1469 val = AREF (font, FONT_SIZE_INDEX); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1470 if (INTEGERP (val)) |
|
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 if (XINT (val) != 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1473 pixel_size = XINT (val); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1474 point_size = -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1475 len += 21; /* for ":pixelsize=NUM" */ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1476 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1477 else if (FLOATP (val)) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1478 { |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1479 pixel_size = -1; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1480 point_size = (int) XFLOAT_DATA (val); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1481 len += 11; /* for "-NUM" */ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1482 } |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1483 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1484 val = AREF (font, FONT_FOUNDRY_INDEX); |
| 94926 | 1485 if (STRINGP (val)) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1486 /* ":foundry=NAME" */ |
| 94926 | 1487 len += 9 + SBYTES (val); |
| 1488 | |
| 1489 for (i = 0; i < 3; i++) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1490 { |
| 94926 | 1491 styles[i] = font_style_symbolic (font, FONT_WEIGHT_INDEX + i, 0); |
| 1492 if (! NILP (styles[i])) | |
| 1493 len += sprintf (work, ":%s=%s", style_names[i], | |
| 1494 SDATA (SYMBOL_NAME (styles[i]))); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1495 } |
| 94926 | 1496 |
| 1497 if (INTEGERP (AREF (font, FONT_DPI_INDEX))) | |
| 1498 len += sprintf (work, ":dpi=%d", dpi); | |
| 1499 if (INTEGERP (AREF (font, FONT_SPACING_INDEX))) | |
| 1500 len += strlen (":spacing=100"); | |
| 1501 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX))) | |
| 1502 len += strlen (":scalable=false"); /* or ":scalable=true" */ | |
| 1503 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
|
1504 { |
| 94926 | 1505 Lisp_Object key = XCAR (XCAR (tail)), val = XCDR (XCAR (tail)); |
| 1506 | |
| 1507 len += SBYTES (SYMBOL_NAME (key)) + 1; /* for :KEY= */ | |
| 1508 if (STRINGP (val)) | |
| 1509 len += SBYTES (val); | |
| 1510 else if (INTEGERP (val)) | |
| 1511 len += sprintf (work, "%d", XINT (val)); | |
| 1512 else if (SYMBOLP (val)) | |
| 1513 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
|
1514 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1515 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1516 if (len > nbytes) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1517 return -1; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1518 p = name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1519 if (! NILP (AREF (font, FONT_FAMILY_INDEX))) |
| 94926 | 1520 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
|
1521 if (point_size > 0) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1522 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1523 if (p == name) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1524 p += sprintf (p, "%d", point_size); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1525 else |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1526 p += sprintf (p, "-%d", point_size); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1527 } |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1528 else if (pixel_size > 0) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1529 p += sprintf (p, ":pixelsize=%d", pixel_size); |
| 94926 | 1530 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
|
1531 p += sprintf (p, ":foundry=%s", |
|
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
1532 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
|
1533 for (i = 0; i < 3; i++) |
| 94926 | 1534 if (! NILP (styles[i])) |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
1535 p += sprintf (p, ":%s=%s", style_names[i], |
| 94926 | 1536 SDATA (SYMBOL_NAME (styles[i]))); |
| 1537 if (INTEGERP (AREF (font, FONT_DPI_INDEX))) | |
| 1538 p += sprintf (p, ":dpi=%d", XINT (AREF (font, FONT_DPI_INDEX))); | |
| 1539 if (INTEGERP (AREF (font, FONT_SPACING_INDEX))) | |
| 1540 p += sprintf (p, ":spacing=%d", XINT (AREF (font, FONT_SPACING_INDEX))); | |
| 1541 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX))) | |
| 1542 { | |
| 1543 if (XINT (AREF (font, FONT_AVGWIDTH_INDEX)) == 0) | |
| 1544 p += sprintf (p, ":scalable=true"); | |
| 1545 else | |
| 1546 p += sprintf (p, ":scalable=false"); | |
| 1547 } | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1548 return (p - name); |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1549 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1550 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1551 /* 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
|
1552 (font-spec or font-entity). If NAME is successfully parsed, return |
| 94926 | 1553 0. Otherwise return -1. */ |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1554 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1555 static int |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1556 font_parse_name (name, font) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1557 char *name; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1558 Lisp_Object font; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1559 { |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1560 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
|
1561 return font_parse_xlfd (name, font); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
1562 return font_parse_fcname (name, font); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1563 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
1564 |
| 94926 | 1565 |
| 1566 /* Merge FAMILY and REGISTRY into FONT_SPEC. FAMILY may have the form | |
| 1567 "FAMILY-FOUNDRY". REGISTRY may not contain charset-encoding | |
| 1568 part. */ | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
1569 |
| 90400 | 1570 void |
| 94926 | 1571 font_parse_family_registry (family, registry, font_spec) |
| 1572 Lisp_Object family, registry, font_spec; | |
| 90400 | 1573 { |
| 94926 | 1574 int len; |
| 1575 char *p0, *p1; | |
| 1576 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1577 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
|
1578 && NILP (AREF (font_spec, FONT_FAMILY_INDEX))) |
| 90400 | 1579 { |
| 94926 | 1580 CHECK_STRING (family); |
| 1581 len = SBYTES (family); | |
| 1582 p0 = (char *) SDATA (family); | |
| 1583 p1 = index (p0, '-'); | |
| 1584 if (p1) | |
| 90400 | 1585 { |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
1586 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
|
1587 && NILP (AREF (font_spec, FONT_FOUNDRY_INDEX))) |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1588 Ffont_put (font_spec, QCfoundry, font_intern_prop (p0, p1 - p0, 1)); |
| 94926 | 1589 p1++; |
| 1590 len -= p1 - p0; | |
|
95746
b490fda95b13
(font_intern_prop): New arg force_symbol.
Kenichi Handa <handa@m17n.org>
parents:
95699
diff
changeset
|
1591 Ffont_put (font_spec, QCfamily, font_intern_prop (p1, len, 1)); |
| 90400 | 1592 } |
| 94926 | 1593 else |
| 1594 ASET (font_spec, FONT_FAMILY_INDEX, Fintern (family, Qnil)); | |
| 1595 } | |
| 1596 if (! NILP (registry)) | |
| 1597 { | |
| 1598 /* Convert "XXX" and "XXX*" to "XXX*-*". */ | |
| 1599 CHECK_STRING (registry); | |
| 1600 len = SBYTES (registry); | |
| 1601 p0 = (char *) SDATA (registry); | |
| 1602 p1 = index (p0, '-'); | |
| 1603 if (! p1) | |
| 1604 { | |
| 1605 if (SDATA (registry)[len - 1] == '*') | |
| 1606 registry = concat2 (registry, build_string ("-*")); | |
| 1607 else | |
| 1608 registry = concat2 (registry, build_string ("*-*")); | |
| 1609 } | |
| 1610 registry = Fdowncase (registry); | |
| 1611 ASET (font_spec, FONT_REGISTRY_INDEX, Fintern (registry, Qnil)); | |
| 90400 | 1612 } |
| 1613 } | |
| 1614 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
1615 |
| 94926 | 1616 /* This part (through the next ^L) is still experimental and not |
| 1617 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
|
1618 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
1619 /* OTF handler */ |
| 90541 | 1620 |
|
95290
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
1621 #if 0 |
|
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
1622 |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1623 #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
|
1624 #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
|
1625 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1626 static int |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1627 check_gstring (gstring) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1628 Lisp_Object gstring; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1629 { |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1630 Lisp_Object val; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1631 int i, j; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1632 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1633 CHECK_VECTOR (gstring); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1634 val = AREF (gstring, 0); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1635 CHECK_VECTOR (val); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1636 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
|
1637 goto err; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1638 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
|
1639 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
|
1640 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
|
1641 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
|
1642 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
|
1643 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
|
1644 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
|
1645 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
|
1646 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
|
1647 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
|
1648 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
|
1649 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1650 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
|
1651 { |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1652 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
|
1653 CHECK_VECTOR (val); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1654 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
|
1655 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
|
1656 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
|
1657 break; |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1658 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
|
1659 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
|
1660 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
|
1661 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
|
1662 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
|
1663 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
|
1664 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
|
1665 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
|
1666 { |
|
91550
83267bc0360a
(check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91360
diff
changeset
|
1667 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
|
1668 CHECK_VECTOR (val); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1669 if (ASIZE (val) < 3) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1670 goto err; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1671 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
|
1672 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
|
1673 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1674 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1675 return i; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1676 err: |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1677 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
|
1678 return -1; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1679 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
1680 |
|
90823
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1681 static void |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1682 check_otf_features (otf_features) |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1683 Lisp_Object otf_features; |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1684 { |
| 94926 | 1685 Lisp_Object val; |
|
90823
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 CHECK_CONS (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1688 CHECK_SYMBOL (XCAR (otf_features)); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1689 otf_features = XCDR (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1690 CHECK_CONS (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1691 CHECK_SYMBOL (XCAR (otf_features)); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1692 otf_features = XCDR (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1693 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
|
1694 { |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1695 CHECK_SYMBOL (Fcar (val)); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1696 if (SBYTES (SYMBOL_NAME (XCAR (val))) > 4) |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1697 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
|
1698 } |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1699 otf_features = XCDR (otf_features); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1700 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
|
1701 { |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1702 CHECK_SYMBOL (Fcar (val)); |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1703 if (SBYTES (SYMBOL_NAME (XCAR (val))) > 4) |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1704 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
|
1705 } |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1706 } |
|
b08ad368c328
(check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents:
90817
diff
changeset
|
1707 |
| 90400 | 1708 #ifdef HAVE_LIBOTF |
| 1709 #include <otf.h> | |
| 1710 | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1711 Lisp_Object otf_list; |
| 90400 | 1712 |
| 1713 static Lisp_Object | |
| 1714 otf_tag_symbol (tag) | |
| 1715 OTF_Tag tag; | |
| 1716 { | |
| 1717 char name[5]; | |
| 1718 | |
| 1719 OTF_tag_name (tag, name); | |
| 1720 return Fintern (make_unibyte_string (name, 4), Qnil); | |
| 1721 } | |
| 1722 | |
| 1723 static OTF * | |
| 94926 | 1724 otf_open (file) |
| 1725 Lisp_Object file; | |
| 90400 | 1726 { |
| 94926 | 1727 Lisp_Object val = Fassoc (file, otf_list); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1728 OTF *otf; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1729 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1730 if (! NILP (val)) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1731 otf = XSAVE_VALUE (XCDR (val))->pointer; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1732 else |
| 90400 | 1733 { |
| 94926 | 1734 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
|
1735 val = make_save_value (otf, 0); |
| 94926 | 1736 otf_list = Fcons (Fcons (file, val), otf_list); |
| 90400 | 1737 } |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1738 return otf; |
| 90400 | 1739 } |
| 1740 | |
| 1741 | |
| 1742 /* Return a list describing which scripts/languages FONT supports by | |
| 1743 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
|
1744 (struct font_driver).otf_capability. */ |
| 90400 | 1745 |
| 1746 Lisp_Object | |
| 1747 font_otf_capability (font) | |
| 1748 struct font *font; | |
| 1749 { | |
| 1750 OTF *otf; | |
| 1751 Lisp_Object capability = Fcons (Qnil, Qnil); | |
| 1752 int i; | |
| 1753 | |
| 94926 | 1754 otf = otf_open (font->props[FONT_FILE_INDEX]); |
| 90400 | 1755 if (! otf) |
| 1756 return Qnil; | |
| 1757 for (i = 0; i < 2; i++) | |
| 1758 { | |
| 1759 OTF_GSUB_GPOS *gsub_gpos; | |
| 1760 Lisp_Object script_list = Qnil; | |
| 1761 int j; | |
| 1762 | |
| 1763 if (OTF_get_features (otf, i == 0) < 0) | |
| 1764 continue; | |
| 1765 gsub_gpos = i == 0 ? otf->gsub : otf->gpos; | |
| 1766 for (j = gsub_gpos->ScriptList.ScriptCount - 1; j >= 0; j--) | |
| 1767 { | |
| 1768 OTF_Script *script = gsub_gpos->ScriptList.Script + j; | |
| 1769 Lisp_Object langsys_list = Qnil; | |
| 1770 Lisp_Object script_tag = otf_tag_symbol (script->ScriptTag); | |
| 1771 int k; | |
| 1772 | |
| 1773 for (k = script->LangSysCount; k >= 0; k--) | |
| 1774 { | |
| 1775 OTF_LangSys *langsys; | |
| 1776 Lisp_Object feature_list = Qnil; | |
| 1777 Lisp_Object langsys_tag; | |
| 1778 int l; | |
| 1779 | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1780 if (k == script->LangSysCount) |
| 90400 | 1781 { |
| 1782 langsys = &script->DefaultLangSys; | |
| 1783 langsys_tag = Qnil; | |
| 1784 } | |
| 1785 else | |
| 1786 { | |
| 1787 langsys = script->LangSys + k; | |
| 1788 langsys_tag | |
| 1789 = otf_tag_symbol (script->LangSysRecord[k].LangSysTag); | |
| 1790 } | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1791 for (l = langsys->FeatureCount - 1; l >= 0; l--) |
| 90400 | 1792 { |
| 1793 OTF_Feature *feature | |
| 1794 = gsub_gpos->FeatureList.Feature + langsys->FeatureIndex[l]; | |
| 1795 Lisp_Object feature_tag | |
| 1796 = otf_tag_symbol (feature->FeatureTag); | |
| 1797 | |
| 1798 feature_list = Fcons (feature_tag, feature_list); | |
| 1799 } | |
| 1800 langsys_list = Fcons (Fcons (langsys_tag, feature_list), | |
| 1801 langsys_list); | |
| 1802 } | |
| 1803 script_list = Fcons (Fcons (script_tag, langsys_list), | |
| 1804 script_list); | |
| 1805 } | |
| 1806 | |
| 1807 if (i == 0) | |
| 1808 XSETCAR (capability, script_list); | |
| 1809 else | |
| 1810 XSETCDR (capability, script_list); | |
| 1811 } | |
| 1812 | |
| 1813 return capability; | |
| 1814 } | |
| 1815 | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1816 /* 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
|
1817 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
|
1818 assured that the sufficient memory has already allocated for |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1819 FEATURES. */ |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1820 |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1821 static void |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1822 generate_otf_features (spec, features) |
| 90400 | 1823 Lisp_Object spec; |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1824 char *features; |
| 90400 | 1825 { |
| 1826 Lisp_Object val; | |
| 94926 | 1827 char *p; |
| 90400 | 1828 int asterisk; |
| 1829 | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1830 p = features; |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1831 *p = '\0'; |
| 90400 | 1832 for (asterisk = 0; CONSP (spec); spec = XCDR (spec)) |
| 1833 { | |
| 1834 val = XCAR (spec); | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1835 CHECK_SYMBOL (val); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1836 if (p > features) |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1837 *p++ = ','; |
| 90400 | 1838 if (SREF (SYMBOL_NAME (val), 0) == '*') |
| 1839 { | |
| 1840 asterisk = 1; | |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1841 *p++ = '*'; |
| 90400 | 1842 } |
| 1843 else if (! asterisk) | |
|
90556
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 val = SYMBOL_NAME (val); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1846 p += sprintf (p, "%s", SDATA (val)); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1847 } |
| 90400 | 1848 else |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1849 { |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1850 val = SYMBOL_NAME (val); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1851 p += sprintf (p, "~%s", SDATA (val)); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1852 } |
| 90400 | 1853 } |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1854 if (CONSP (spec)) |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1855 error ("OTF spec too long"); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1856 } |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1857 |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1858 Lisp_Object |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1859 font_otf_DeviceTable (device_table) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1860 OTF_DeviceTable *device_table; |
|
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 int len = device_table->StartSize - device_table->EndSize + 1; |
|
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 return Fcons (make_number (len), |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1865 make_unibyte_string (device_table->DeltaValue, len)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1866 } |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1867 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1868 Lisp_Object |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1869 font_otf_ValueRecord (value_format, value_record) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1870 int value_format; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1871 OTF_ValueRecord *value_record; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1872 { |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1873 Lisp_Object val = Fmake_vector (make_number (8), Qnil); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1874 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1875 if (value_format & OTF_XPlacement) |
| 91909 | 1876 ASET (val, 0, make_number (value_record->XPlacement)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1877 if (value_format & OTF_YPlacement) |
| 91909 | 1878 ASET (val, 1, make_number (value_record->YPlacement)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1879 if (value_format & OTF_XAdvance) |
| 91909 | 1880 ASET (val, 2, make_number (value_record->XAdvance)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1881 if (value_format & OTF_YAdvance) |
| 91909 | 1882 ASET (val, 3, make_number (value_record->YAdvance)); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1883 if (value_format & OTF_XPlaDevice) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1884 ASET (val, 4, font_otf_DeviceTable (&value_record->XPlaDevice)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1885 if (value_format & OTF_YPlaDevice) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1886 ASET (val, 4, font_otf_DeviceTable (&value_record->YPlaDevice)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1887 if (value_format & OTF_XAdvDevice) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1888 ASET (val, 4, font_otf_DeviceTable (&value_record->XAdvDevice)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1889 if (value_format & OTF_YAdvDevice) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1890 ASET (val, 4, font_otf_DeviceTable (&value_record->YAdvDevice)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1891 return val; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1892 } |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1893 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1894 Lisp_Object |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1895 font_otf_Anchor (anchor) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1896 OTF_Anchor *anchor; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1897 { |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1898 Lisp_Object val; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1899 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1900 val = Fmake_vector (make_number (anchor->AnchorFormat + 1), Qnil); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1901 ASET (val, 0, make_number (anchor->XCoordinate)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1902 ASET (val, 1, make_number (anchor->YCoordinate)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1903 if (anchor->AnchorFormat == 2) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1904 ASET (val, 2, make_number (anchor->f.f1.AnchorPoint)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1905 else |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1906 { |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1907 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
|
1908 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
|
1909 } |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1910 return val; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
1911 } |
| 90400 | 1912 #endif /* HAVE_LIBOTF */ |
|
95290
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
1913 #endif /* 0 */ |
| 90400 | 1914 |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1915 /* G-string (glyph string) handler */ |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1916 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
1917 /* 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
|
1918 See the docstring of `font-make-gstring' for more detail. */ |
| 90400 | 1919 |
| 1920 struct font * | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1921 font_prepare_composition (cmp, f) |
| 90400 | 1922 struct composition *cmp; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1923 FRAME_PTR f; |
| 90400 | 1924 { |
| 1925 Lisp_Object gstring | |
| 1926 = AREF (XHASH_TABLE (composition_hash_table)->key_and_value, | |
| 1927 cmp->hash_index * 2); | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1928 |
| 94926 | 1929 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
|
1930 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
|
1931 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
|
1932 cmp->lbearing = LGSTRING_LBEARING (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1933 cmp->rbearing = LGSTRING_RBEARING (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1934 cmp->ascent = LGSTRING_ASCENT (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1935 cmp->descent = LGSTRING_DESCENT (gstring); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1936 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
|
1937 if (cmp->width == 0) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1938 cmp->width = 1; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1939 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
1940 return cmp->font; |
| 90400 | 1941 } |
| 1942 | |
| 1943 | |
| 1944 /* Font sorting */ | |
| 1945 | |
| 94926 | 1946 static unsigned font_score P_ ((Lisp_Object, Lisp_Object *, Lisp_Object)); |
| 90400 | 1947 static int font_compare P_ ((const void *, const void *)); |
| 1948 static Lisp_Object font_sort_entites P_ ((Lisp_Object, Lisp_Object, | |
| 94926 | 1949 Lisp_Object, Lisp_Object, |
| 1950 int)); | |
| 90400 | 1951 |
| 1952 /* We sort fonts by scoring each of them against a specified | |
| 1953 font-spec. The score value is 32 bit (`unsigned'), and the smaller | |
| 1954 the value is, the closer the font is to the font-spec. | |
| 1955 | |
| 94926 | 1956 The highest 2 bits of the score is used for FAMILY. The exact |
| 1957 match is 0, match with one of face-font-family-alternatives is | |
| 1958 nonzero. | |
| 1959 | |
| 1960 The next 2 bits of the score is used for the atomic properties | |
| 1961 FOUNDRY and ADSTYLE respectively. | |
| 1962 | |
| 1963 Each 7-bit in the lower 28 bits are used for numeric properties | |
| 90400 | 1964 WEIGHT, SLANT, WIDTH, and SIZE. */ |
| 1965 | |
| 1966 /* How many bits to shift to store the difference value of each font | |
| 94926 | 1967 property in a score. Note that flots for FONT_TYPE_INDEX and |
| 1968 FONT_REGISTRY_INDEX are not used. */ | |
| 90400 | 1969 static int sort_shift_bits[FONT_SIZE_INDEX + 1]; |
| 1970 | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
1971 /* 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
|
1972 The return value indicates how different ENTITY is compared with |
| 94926 | 1973 SPEC_PROP. |
| 1974 | |
| 1975 ALTERNATE_FAMILIES, if non-nil, is a pre-calculated list of | |
| 1976 alternate family names for AREF (SPEC_PROP, FONT_FAMILY_INDEX). */ | |
| 90400 | 1977 |
| 1978 static unsigned | |
| 94926 | 1979 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
|
1980 Lisp_Object entity, *spec_prop; |
| 94926 | 1981 Lisp_Object alternate_families; |
| 90400 | 1982 { |
| 1983 unsigned score = 0; | |
| 1984 int i; | |
| 94926 | 1985 |
| 1986 /* Score three atomic fields. Maximum difference is 1 (family is 3). */ | |
| 1987 for (i = FONT_FOUNDRY_INDEX; i <= FONT_ADSTYLE_INDEX; i++) | |
| 1988 if (i != FONT_REGISTRY_INDEX | |
| 1989 && ! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i])) | |
| 1990 { | |
| 1991 Lisp_Object entity_str = SYMBOL_NAME (AREF (entity, i)); | |
| 1992 Lisp_Object spec_str = SYMBOL_NAME (spec_prop[i]); | |
| 1993 | |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
1994 if (xstrcasecmp (SDATA (spec_str), SDATA (entity_str))) |
| 94926 | 1995 { |
| 1996 if (i == FONT_FAMILY_INDEX && CONSP (alternate_families)) | |
| 1997 { | |
| 1998 int j; | |
| 1999 | |
| 2000 for (j = 1; CONSP (alternate_families); | |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
2001 j++, alternate_families = XCDR (alternate_families)) |
| 94926 | 2002 { |
| 2003 spec_str = XCAR (alternate_families); | |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
2004 if (xstrcasecmp (SDATA (spec_str), SDATA (entity_str)) == 0) |
| 94926 | 2005 break; |
| 2006 } | |
| 2007 if (j > 3) | |
| 2008 j = 3; | |
| 2009 score |= j << sort_shift_bits[i]; | |
| 2010 } | |
| 2011 else | |
| 2012 score |= 1 << sort_shift_bits[i]; | |
| 2013 } | |
| 2014 } | |
| 2015 | |
| 2016 /* Score three style numeric fields. Maximum difference is 127. */ | |
| 2017 for (i = FONT_WEIGHT_INDEX; i <= FONT_WIDTH_INDEX; i++) | |
| 2018 if (! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i])) | |
| 2019 { | |
| 2020 int diff = (XINT (AREF (entity, i)) >> 8) - (XINT (spec_prop[i]) >> 8); | |
| 2021 | |
| 2022 if (diff < 0) | |
| 2023 diff = - diff; | |
| 2024 /* This is to prefer the exact symbol style. */ | |
| 2025 diff++; | |
| 2026 score |= min (diff, 127) << sort_shift_bits[i]; | |
| 2027 } | |
| 2028 | |
| 2029 /* Score the size. Maximum difference is 127. */ | |
| 2030 i = FONT_SIZE_INDEX; | |
| 2031 if (! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i]) | |
| 2032 && XINT (AREF (entity, i)) > 0) | |
| 90400 | 2033 { |
| 94926 | 2034 /* We use the higher 6-bit for the actual size difference. The |
| 2035 lowest bit is set if the DPI is different. */ | |
| 2036 int diff = XINT (spec_prop[i]) - XINT (AREF (entity, i)); | |
| 2037 | |
| 2038 if (diff < 0) | |
| 2039 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
|
2040 diff <<= 1; |
| 94926 | 2041 if (! NILP (spec_prop[FONT_DPI_INDEX]) |
| 2042 && ! EQ (spec_prop[FONT_DPI_INDEX], AREF (entity, FONT_DPI_INDEX))) | |
| 2043 diff |= 1; | |
| 2044 score |= min (diff, 127) << sort_shift_bits[FONT_SIZE_INDEX]; | |
| 90400 | 2045 } |
| 2046 | |
| 2047 return score; | |
| 2048 } | |
| 2049 | |
| 2050 | |
| 2051 /* The comparison function for qsort. */ | |
| 2052 | |
| 2053 static int | |
| 2054 font_compare (d1, d2) | |
| 2055 const void *d1, *d2; | |
| 2056 { | |
| 94926 | 2057 return (*(unsigned *) d1 - *(unsigned *) d2); |
| 90400 | 2058 } |
| 2059 | |
| 2060 | |
| 2061 /* The structure for elements being sorted by qsort. */ | |
| 2062 struct font_sort_data | |
| 2063 { | |
| 2064 unsigned score; | |
| 2065 Lisp_Object entity; | |
| 2066 }; | |
| 2067 | |
| 2068 | |
| 2069 /* Sort font-entities in vector VEC by closeness to font-spec PREFER. | |
| 2070 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
|
2071 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
|
2072 of FRAME before sorting. If SPEC is not nil, it is a font-spec to |
| 94926 | 2073 get the font-entities in VEC. |
| 2074 | |
| 2075 If BEST-ONLY is nonzero, return the best matching entity. Otherwise, | |
| 2076 return the sorted VEC. */ | |
| 90400 | 2077 |
| 2078 static Lisp_Object | |
| 94926 | 2079 font_sort_entites (vec, prefer, frame, spec, best_only) |
| 90400 | 2080 Lisp_Object vec, prefer, frame, spec; |
| 94926 | 2081 int best_only; |
| 90400 | 2082 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2083 Lisp_Object prefer_prop[FONT_SPEC_MAX]; |
| 90400 | 2084 int len, i; |
| 2085 struct font_sort_data *data; | |
| 94926 | 2086 Lisp_Object alternate_families = Qnil; |
| 2087 unsigned best_score; | |
| 2088 Lisp_Object best_entity; | |
| 90400 | 2089 USE_SAFE_ALLOCA; |
| 2090 | |
| 2091 len = ASIZE (vec); | |
| 2092 if (len <= 1) | |
| 94926 | 2093 return best_only ? AREF (vec, 0) : vec; |
| 2094 | |
| 2095 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
|
2096 prefer_prop[i] = AREF (prefer, i); |
| 90400 | 2097 |
| 2098 if (! NILP (spec)) | |
| 2099 { | |
| 94926 | 2100 /* A font driver may return a font that has a property value |
| 2101 different from the value specified in SPEC if the driver | |
| 2102 thinks they are the same. That happens, for instance, such a | |
| 2103 generic family name as "serif" is specified. So, to ignore | |
| 2104 such a difference, for all properties specified in SPEC, set | |
| 2105 the corresponding properties in PREFER_PROP to nil. */ | |
| 2106 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
|
2107 if (! NILP (AREF (spec, i))) |
| 94926 | 2108 prefer_prop[i] = Qnil; |
| 90400 | 2109 } |
| 2110 | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2111 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
|
2112 prefer_prop[FONT_SIZE_INDEX] |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2113 = make_number (font_pixel_size (XFRAME (frame), prefer)); |
| 94926 | 2114 if (! NILP (prefer_prop[FONT_FAMILY_INDEX])) |
| 2115 { | |
| 2116 alternate_families | |
| 2117 = Fassoc_string (prefer_prop[FONT_FAMILY_INDEX], | |
| 2118 Vface_alternative_font_family_alist, Qt); | |
| 2119 if (CONSP (alternate_families)) | |
| 2120 alternate_families = XCDR (alternate_families); | |
| 2121 } | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2122 |
| 90400 | 2123 /* Scoring and sorting. */ |
| 2124 SAFE_ALLOCA (data, struct font_sort_data *, (sizeof *data) * len); | |
| 94926 | 2125 best_score = 0xFFFFFFFF; |
| 2126 best_entity = Qnil; | |
| 90400 | 2127 for (i = 0; i < len; i++) |
| 2128 { | |
| 2129 data[i].entity = AREF (vec, i); | |
| 94926 | 2130 data[i].score = font_score (data[i].entity, prefer_prop, |
| 2131 alternate_families); | |
| 2132 if (best_only && best_score > data[i].score) | |
| 2133 { | |
| 2134 best_score = data[i].score; | |
| 2135 best_entity = data[i].entity; | |
| 2136 if (best_score == 0) | |
| 2137 break; | |
| 2138 } | |
| 90400 | 2139 } |
| 94926 | 2140 if (NILP (best_entity)) |
| 2141 { | |
| 2142 qsort (data, len, sizeof *data, font_compare); | |
| 2143 for (i = 0; i < len; i++) | |
| 2144 ASET (vec, i, data[i].entity); | |
| 2145 } | |
| 2146 else | |
| 2147 vec = best_entity; | |
| 90400 | 2148 SAFE_FREE (); |
| 2149 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2150 font_add_log ("sort-by", prefer, vec); |
| 90400 | 2151 return vec; |
| 2152 } | |
| 2153 | |
| 2154 | |
| 2155 /* API of Font Service Layer. */ | |
| 2156 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2157 /* 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
|
2158 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
|
2159 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
|
2160 |
| 90400 | 2161 void |
| 2162 font_update_sort_order (order) | |
| 2163 int *order; | |
| 2164 { | |
| 94926 | 2165 int i, shift_bits; |
| 2166 | |
| 2167 for (i = 0, shift_bits = 21; i < 4; i++, shift_bits -= 7) | |
| 90400 | 2168 { |
| 2169 int xlfd_idx = order[i]; | |
| 2170 | |
| 2171 if (xlfd_idx == XLFD_WEIGHT_INDEX) | |
| 2172 sort_shift_bits[FONT_WEIGHT_INDEX] = shift_bits; | |
| 2173 else if (xlfd_idx == XLFD_SLANT_INDEX) | |
| 2174 sort_shift_bits[FONT_SLANT_INDEX] = shift_bits; | |
| 2175 else if (xlfd_idx == XLFD_SWIDTH_INDEX) | |
| 2176 sort_shift_bits[FONT_WIDTH_INDEX] = shift_bits; | |
| 2177 else | |
| 2178 sort_shift_bits[FONT_SIZE_INDEX] = shift_bits; | |
| 2179 } | |
| 2180 } | |
| 2181 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2182 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2183 /* 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
|
2184 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2185 int |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2186 font_match_p (spec, entity) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2187 Lisp_Object spec, entity; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2188 { |
| 94926 | 2189 Lisp_Object prefer_prop[FONT_SPEC_MAX]; |
| 2190 Lisp_Object alternate_families = Qnil; | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2191 int i; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2192 |
| 94926 | 2193 for (i = FONT_FOUNDRY_INDEX; i <= FONT_SIZE_INDEX; i++) |
| 2194 prefer_prop[i] = AREF (spec, i); | |
| 2195 if (FLOATP (prefer_prop[FONT_SIZE_INDEX])) | |
| 2196 prefer_prop[FONT_SIZE_INDEX] | |
| 2197 = make_number (font_pixel_size (XFRAME (selected_frame), spec)); | |
| 2198 if (! NILP (prefer_prop[FONT_FAMILY_INDEX])) | |
| 2199 { | |
| 2200 alternate_families | |
| 2201 = Fassoc_string (prefer_prop[FONT_FAMILY_INDEX], | |
| 2202 Vface_alternative_font_family_alist, Qt); | |
| 2203 if (CONSP (alternate_families)) | |
| 2204 alternate_families = XCDR (alternate_families); | |
| 2205 } | |
| 2206 | |
| 2207 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
|
2208 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2209 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2210 |
| 94926 | 2211 /* CHeck a lispy font object corresponding to FONT. */ |
| 2212 | |
| 2213 int | |
| 2214 font_check_object (font) | |
| 90400 | 2215 struct font *font; |
| 2216 { | |
| 2217 Lisp_Object tail, elt; | |
| 2218 | |
| 94926 | 2219 for (tail = font->props[FONT_OBJLIST_INDEX]; CONSP (tail); |
| 90400 | 2220 tail = XCDR (tail)) |
| 2221 { | |
| 2222 elt = XCAR (tail); | |
| 94926 | 2223 if (font == XFONT_OBJECT (elt)) |
| 2224 return 1; | |
| 90400 | 2225 } |
| 94926 | 2226 return 0; |
| 90400 | 2227 } |
| 2228 | |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2229 |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2230 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2231 /* Font cache |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2232 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2233 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
|
2234 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
|
2235 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
|
2236 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
|
2237 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2238 ((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
|
2239 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2240 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
|
2241 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
|
2242 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
|
2243 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2244 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
|
2245 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
|
2246 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
|
2247 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
|
2248 struct font_driver *)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2249 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2250 static void |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2251 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
|
2252 FRAME_PTR f; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2253 struct font_driver *driver; |
|
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 Lisp_Object cache, val; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2256 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2257 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
|
2258 val = XCDR (cache); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2259 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
|
2260 val = XCDR (val); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2261 if (NILP (val)) |
|
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 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
|
2264 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
|
2265 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2266 else |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2267 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2268 val = XCDR (XCAR (val)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2269 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
|
2270 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2271 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2272 |
| 91909 | 2273 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2274 static void |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2275 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
|
2276 FRAME_PTR f; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2277 struct font_driver *driver; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2278 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2279 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
|
2280 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2281 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2282 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
|
2283 val = XCDR (cache); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2284 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
|
2285 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
|
2286 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
|
2287 tmp = XCDR (XCAR (val)); |
| 91909 | 2288 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
|
2289 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
|
2290 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2291 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
|
2292 XSETCDR (cache, XCDR (val)); |
|
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 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2295 |
| 91909 | 2296 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2297 static Lisp_Object |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2298 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
|
2299 FRAME_PTR f; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2300 struct font_driver *driver; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2301 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2302 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
|
2303 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
|
2304 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2305 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
|
2306 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
|
2307 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
|
2308 /* 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
|
2309 val = XCDR (XCAR (val)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2310 return val; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2311 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2312 |
| 91909 | 2313 static int num_fonts; |
| 2314 | |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2315 static void |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2316 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
|
2317 FRAME_PTR f; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2318 Lisp_Object cache; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2319 struct font_driver *driver; |
|
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 tail, elt; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
2322 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2323 /* 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
|
2324 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
|
2325 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2326 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
|
2327 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
|
2328 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2329 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
|
2330 int i; |
|
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 (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
|
2333 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2334 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
|
2335 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2336 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
|
2337 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2338 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
|
2339 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2340 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
|
2341 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2342 Lisp_Object val = XCAR (objlist); |
| 94926 | 2343 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
|
2344 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2345 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
|
2346 driver->close (f, font); |
| 91909 | 2347 num_fonts--; |
|
91247
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 if (driver->free_entity) |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2350 driver->free_entity (entity); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2351 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2352 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2353 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2354 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2355 XSETCDR (cache, Qnil); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2356 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2357 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2358 |
| 90400 | 2359 static Lisp_Object scratch_font_spec, scratch_font_prefer; |
| 2360 | |
| 94926 | 2361 Lisp_Object |
| 2362 font_delete_unmatched (list, spec, size) | |
| 2363 Lisp_Object list, spec; | |
| 2364 int size; | |
| 2365 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2366 Lisp_Object entity, val; |
| 94926 | 2367 enum font_property_index prop; |
| 2368 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2369 for (val = Qnil; CONSP (list); list = XCDR (list)) |
| 94926 | 2370 { |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2371 entity = XCAR (list); |
| 94926 | 2372 for (prop = FONT_WEIGHT_INDEX; prop < FONT_SIZE_INDEX; prop++) |
| 2373 if (INTEGERP (AREF (spec, prop)) | |
| 2374 && ((XINT (AREF (spec, prop)) >> 8) | |
| 2375 != (XINT (AREF (entity, prop)) >> 8))) | |
| 2376 prop = FONT_SPEC_MAX; | |
| 2377 if (prop++ <= FONT_SIZE_INDEX | |
| 2378 && size | |
| 2379 && XINT (AREF (entity, FONT_SIZE_INDEX)) > 0) | |
| 2380 { | |
| 2381 int diff = XINT (AREF (entity, FONT_SIZE_INDEX)) - size; | |
| 2382 | |
| 2383 if (diff != 0 | |
| 2384 && (diff < 0 ? -diff > FONT_PIXEL_SIZE_QUANTUM | |
| 2385 : diff > FONT_PIXEL_SIZE_QUANTUM)) | |
| 2386 prop = FONT_SPEC_MAX; | |
| 2387 } | |
| 2388 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
|
2389 val = Fcons (entity, val); |
| 94926 | 2390 } |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2391 return val; |
| 94926 | 2392 } |
| 2393 | |
| 2394 | |
| 2395 /* Return a vector of font-entities matching with SPEC on FRAME. */ | |
| 2396 | |
| 2397 Lisp_Object | |
| 90400 | 2398 font_list_entities (frame, spec) |
| 2399 Lisp_Object frame, spec; | |
| 2400 { | |
| 2401 FRAME_PTR f = XFRAME (frame); | |
| 2402 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
|
2403 Lisp_Object ftype, family, alternate_familes, val; |
| 94926 | 2404 Lisp_Object *vec; |
| 2405 int size; | |
| 2406 int need_filtering = 0; | |
| 2407 int n_family = 1; | |
| 90400 | 2408 int i; |
| 2409 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2410 font_assert (FONT_SPEC_P (spec)); |
| 90400 | 2411 |
| 2412 family = AREF (spec, FONT_FAMILY_INDEX); | |
| 2413 if (NILP (family)) | |
| 2414 alternate_familes = Qnil; | |
| 2415 else | |
| 2416 { | |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
2417 alternate_familes = Fassoc_string (family, |
| 94926 | 2418 Vface_alternative_font_family_alist, |
| 2419 Qt); | |
| 90400 | 2420 if (! NILP (alternate_familes)) |
| 2421 alternate_familes = XCDR (alternate_familes); | |
| 94926 | 2422 n_family += XINT (Flength (alternate_familes)); |
| 90400 | 2423 } |
| 94926 | 2424 |
| 2425 if (INTEGERP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2426 size = XINT (AREF (spec, FONT_SIZE_INDEX)); | |
| 2427 else if (FLOATP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2428 size = font_pixel_size (f, spec); | |
| 2429 else | |
| 2430 size = 0; | |
| 2431 | |
| 90400 | 2432 ftype = AREF (spec, FONT_TYPE_INDEX); |
|
95104
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2433 for (i = 1; i <= FONT_REGISTRY_INDEX; i++) |
| 94926 | 2434 ASET (scratch_font_spec, i, AREF (spec, i)); |
|
95359
f6580a4c58da
(font_parse_family_registry): Use Ffont_put to validate
Kenichi Handa <handa@m17n.org>
parents:
95290
diff
changeset
|
2435 for (i = FONT_DPI_INDEX; i < FONT_EXTRA_INDEX; i += 2) |
| 94926 | 2436 { |
| 2437 ASET (scratch_font_spec, i, Qnil); | |
| 2438 if (! NILP (AREF (spec, i))) | |
| 2439 need_filtering = 1; | |
| 2440 } | |
|
95359
f6580a4c58da
(font_parse_family_registry): Use Ffont_put to validate
Kenichi Handa <handa@m17n.org>
parents:
95290
diff
changeset
|
2441 ASET (scratch_font_spec, FONT_SPACING_INDEX, AREF (spec, FONT_SPACING_INDEX)); |
| 94926 | 2442 ASET (scratch_font_spec, FONT_EXTRA_INDEX, AREF (spec, FONT_EXTRA_INDEX)); |
| 2443 | |
| 2444 vec = alloca (sizeof (Lisp_Object) * num_font_drivers * n_family); | |
| 2445 if (! vec) | |
| 2446 return null_vector; | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
2447 |
| 90400 | 2448 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
|
2449 if (driver_list->on |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
2450 && (NILP (ftype) || EQ (driver_list->driver->type, ftype))) |
| 90400 | 2451 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2452 Lisp_Object cache = font_get_cache (f, driver_list->driver); |
| 90400 | 2453 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
|
2454 |
|
95437
6e6db01383e4
(font_list_entities): Fix the car part of data to be
Kenichi Handa <handa@m17n.org>
parents:
95421
diff
changeset
|
2455 ASET (scratch_font_spec, FONT_TYPE_INDEX, driver_list->driver->type); |
|
6e6db01383e4
(font_list_entities): Fix the car part of data to be
Kenichi Handa <handa@m17n.org>
parents:
95421
diff
changeset
|
2456 ASET (scratch_font_spec, FONT_FAMILY_INDEX, family); |
| 90400 | 2457 while (1) |
| 2458 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2459 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
|
2460 if (CONSP (val)) |
| 90400 | 2461 val = XCDR (val); |
| 2462 else | |
| 2463 { | |
| 94926 | 2464 Lisp_Object copy; |
| 2465 | |
| 2466 val = driver_list->driver->list (frame, scratch_font_spec); | |
| 2467 copy = Fcopy_font_spec (scratch_font_spec); | |
|
95437
6e6db01383e4
(font_list_entities): Fix the car part of data to be
Kenichi Handa <handa@m17n.org>
parents:
95421
diff
changeset
|
2468 ASET (copy, FONT_TYPE_INDEX, driver_list->driver->type); |
| 94926 | 2469 XSETCDR (cache, Fcons (Fcons (copy, val), XCDR (cache))); |
| 90400 | 2470 } |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2471 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
|
2472 val = font_delete_unmatched (val, spec, size); |
| 94926 | 2473 if (! NILP (val)) |
| 90400 | 2474 { |
| 2475 vec[i++] = val; | |
| 2476 break; | |
| 2477 } | |
| 2478 if (NILP (tail)) | |
| 2479 break; | |
| 94926 | 2480 ASET (scratch_font_spec, FONT_FAMILY_INDEX, |
| 2481 Fintern (XCAR (tail), Qnil)); | |
| 90400 | 2482 tail = XCDR (tail); |
| 2483 } | |
| 2484 } | |
| 94926 | 2485 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2486 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
|
2487 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
|
2488 return (val); |
| 90400 | 2489 } |
| 2490 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2491 |
| 94926 | 2492 /* Return a font entity matching with SPEC on FRAME. ATTRS, if non |
| 2493 nil, is an array of face's attributes, which specifies preferred | |
| 2494 font-related attributes. */ | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2495 |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2496 static Lisp_Object |
| 94926 | 2497 font_matching_entity (f, attrs, spec) |
| 2498 FRAME_PTR f; | |
| 2499 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
|
2500 { |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2501 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
|
2502 Lisp_Object ftype, size, entity; |
| 94926 | 2503 Lisp_Object frame; |
| 2504 | |
| 2505 XSETFRAME (frame, f); | |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2506 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
|
2507 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
|
2508 if (FLOATP (size)) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2509 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
|
2510 entity = Qnil; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2511 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
|
2512 if (driver_list->on |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2513 && (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
|
2514 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
2515 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
|
2516 Lisp_Object copy; |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2517 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2518 ASET (spec, FONT_TYPE_INDEX, driver_list->driver->type); |
| 94926 | 2519 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
|
2520 if (CONSP (entity)) |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2521 entity = XCDR (entity); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2522 else |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2523 { |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2524 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
|
2525 copy = Fcopy_font_spec (spec); |
|
ae4280e6a166
(font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents:
95013
diff
changeset
|
2526 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
|
2527 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
|
2528 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2529 if (! NILP (entity)) |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2530 break; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2531 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2532 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
|
2533 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
|
2534 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
|
2535 return entity; |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2536 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
2537 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2538 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2539 /* 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
|
2540 opened font object. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2541 |
| 90400 | 2542 static Lisp_Object |
| 2543 font_open_entity (f, entity, pixel_size) | |
| 2544 FRAME_PTR f; | |
| 2545 Lisp_Object entity; | |
| 2546 int pixel_size; | |
| 2547 { | |
| 2548 struct font_driver_list *driver_list; | |
| 91909 | 2549 Lisp_Object objlist, size, val, font_object; |
| 90400 | 2550 struct font *font; |
| 94926 | 2551 int min_width; |
| 2552 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2553 font_assert (FONT_ENTITY_P (entity)); |
| 90400 | 2554 size = AREF (entity, FONT_SIZE_INDEX); |
| 2555 if (XINT (size) != 0) | |
| 2556 pixel_size = XINT (size); | |
| 2557 | |
| 2558 for (objlist = AREF (entity, FONT_OBJLIST_INDEX); CONSP (objlist); | |
| 2559 objlist = XCDR (objlist)) | |
| 94926 | 2560 if (XFONT_OBJECT (XCAR (objlist))->pixel_size == pixel_size) |
| 2561 return XCAR (objlist); | |
| 2562 | |
| 2563 val = AREF (entity, FONT_TYPE_INDEX); | |
| 2564 for (driver_list = f->font_driver_list; | |
| 2565 driver_list && ! EQ (driver_list->driver->type, val); | |
| 2566 driver_list = driver_list->next); | |
| 2567 if (! driver_list) | |
| 2568 return Qnil; | |
| 2569 | |
| 2570 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
|
2571 font_add_log ("open", entity, font_object); |
| 91909 | 2572 if (NILP (font_object)) |
| 94926 | 2573 return Qnil; |
| 2574 ASET (entity, FONT_OBJLIST_INDEX, | |
| 2575 Fcons (font_object, AREF (entity, FONT_OBJLIST_INDEX))); | |
| 2576 ASET (font_object, FONT_OBJLIST_INDEX, AREF (entity, FONT_OBJLIST_INDEX)); | |
| 2577 num_fonts++; | |
| 2578 | |
| 2579 font = XFONT_OBJECT (font_object); | |
| 2580 min_width = (font->min_width ? font->min_width | |
| 2581 : font->average_width ? font->average_width | |
| 2582 : font->space_width ? font->space_width | |
| 2583 : 1); | |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2584 #ifdef HAVE_WINDOW_SYSTEM |
| 94926 | 2585 FRAME_X_DISPLAY_INFO (f)->n_fonts++; |
| 2586 if (FRAME_X_DISPLAY_INFO (f)->n_fonts == 1) | |
| 91909 | 2587 { |
| 94926 | 2588 FRAME_SMALLEST_CHAR_WIDTH (f) = min_width; |
| 2589 FRAME_SMALLEST_FONT_HEIGHT (f) = font->height; | |
| 2590 fonts_changed_p = 1; | |
| 91909 | 2591 } |
| 94926 | 2592 else |
| 2593 { | |
| 2594 if (FRAME_SMALLEST_CHAR_WIDTH (f) > min_width) | |
| 2595 FRAME_SMALLEST_CHAR_WIDTH (f) = min_width, fonts_changed_p = 1; | |
| 2596 if (FRAME_SMALLEST_FONT_HEIGHT (f) > font->height) | |
| 2597 FRAME_SMALLEST_FONT_HEIGHT (f) = font->height, fonts_changed_p = 1; | |
| 2598 } | |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2599 #endif |
| 91909 | 2600 |
| 2601 return font_object; | |
| 90400 | 2602 } |
| 2603 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2604 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2605 /* 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
|
2606 |
| 90400 | 2607 void |
| 2608 font_close_object (f, font_object) | |
| 2609 FRAME_PTR f; | |
| 2610 Lisp_Object font_object; | |
| 2611 { | |
| 94926 | 2612 struct font *font = XFONT_OBJECT (font_object); |
| 90541 | 2613 Lisp_Object objlist; |
| 90400 | 2614 Lisp_Object tail, prev = Qnil; |
| 2615 | |
| 94926 | 2616 objlist = AREF (font_object, FONT_OBJLIST_INDEX); |
| 90400 | 2617 for (prev = Qnil, tail = objlist; CONSP (tail); |
| 2618 prev = tail, tail = XCDR (tail)) | |
| 2619 if (EQ (font_object, XCAR (tail))) | |
| 2620 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2621 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
|
2622 font->driver->close (f, font); |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
2623 #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
|
2624 font_assert (FRAME_X_DISPLAY_INFO (f)->n_fonts); |
| 94926 | 2625 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
|
2626 #endif |
| 90541 | 2627 if (NILP (prev)) |
| 94926 | 2628 ASET (font_object, FONT_OBJLIST_INDEX, XCDR (objlist)); |
| 90541 | 2629 else |
| 2630 XSETCDR (prev, XCDR (objlist)); | |
| 91909 | 2631 num_fonts--; |
| 90541 | 2632 return; |
| 90400 | 2633 } |
| 90541 | 2634 abort (); |
| 90400 | 2635 } |
| 2636 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2637 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2638 /* 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
|
2639 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
|
2640 |
| 90400 | 2641 int |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2642 font_has_char (f, font, c) |
| 90400 | 2643 FRAME_PTR f; |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2644 Lisp_Object font; |
| 90400 | 2645 int c; |
| 2646 { | |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2647 struct font *fontp; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2648 |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2649 if (FONT_ENTITY_P (font)) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2650 { |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2651 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
|
2652 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
|
2653 |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2654 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
|
2655 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
|
2656 driver_list = driver_list->next); |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2657 if (! driver_list) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2658 return 0; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2659 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
|
2660 return -1; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2661 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
|
2662 } |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2663 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2664 font_assert (FONT_OBJECT_P (font)); |
| 94926 | 2665 fontp = XFONT_OBJECT (font); |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2666 if (fontp->driver->has_char) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2667 { |
| 94926 | 2668 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
|
2669 |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2670 if (result >= 0) |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2671 return result; |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2672 } |
|
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2673 return (fontp->driver->encode_char (fontp, c) != FONT_INVALID_CODE); |
| 90400 | 2674 } |
| 2675 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2676 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2677 /* 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
|
2678 |
| 90400 | 2679 unsigned |
| 2680 font_encode_char (font_object, c) | |
| 2681 Lisp_Object font_object; | |
| 2682 int c; | |
| 2683 { | |
| 94926 | 2684 struct font *font; |
| 2685 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2686 font_assert (FONT_OBJECT_P (font_object)); |
| 94926 | 2687 font = XFONT_OBJECT (font_object); |
| 90400 | 2688 return font->driver->encode_char (font, c); |
| 2689 } | |
| 2690 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2691 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2692 /* 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
|
2693 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2694 Lisp_Object |
| 90400 | 2695 font_get_name (font_object) |
| 2696 Lisp_Object font_object; | |
| 2697 { | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2698 font_assert (FONT_OBJECT_P (font_object)); |
| 94926 | 2699 return AREF (font_object, FONT_NAME_INDEX); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2700 } |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2701 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2702 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2703 /* 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
|
2704 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2705 Lisp_Object |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2706 font_get_spec (font_object) |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2707 Lisp_Object font_object; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2708 { |
| 94926 | 2709 Lisp_Object spec = font_make_spec (); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2710 int i; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2711 |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2712 for (i = 0; i < FONT_SIZE_INDEX; i++) |
| 94926 | 2713 ASET (spec, i, AREF (font_object, i)); |
| 2714 ASET (spec, FONT_SIZE_INDEX, | |
| 2715 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
|
2716 return spec; |
| 90400 | 2717 } |
| 2718 | |
| 2719 Lisp_Object | |
| 94926 | 2720 font_spec_from_name (font_name) |
| 2721 Lisp_Object font_name; | |
| 2722 { | |
| 2723 Lisp_Object args[2]; | |
| 2724 | |
| 2725 args[0] = QCname; | |
| 2726 args[1] = font_name; | |
| 2727 return Ffont_spec (2, args); | |
| 2728 } | |
| 2729 | |
| 2730 | |
| 2731 void | |
| 2732 font_clear_prop (attrs, prop) | |
| 2733 Lisp_Object *attrs; | |
| 2734 enum font_property_index prop; | |
| 2735 { | |
| 2736 Lisp_Object font = attrs[LFACE_FONT_INDEX]; | |
| 2737 | |
| 2738 if (! FONTP (font)) | |
| 2739 return; | |
| 2740 if (NILP (AREF (font, prop)) | |
| 2741 && prop != FONT_FAMILY_INDEX && prop != FONT_FAMILY_INDEX) | |
| 2742 return; | |
| 2743 font = Fcopy_font_spec (font); | |
| 2744 ASET (font, prop, Qnil); | |
| 2745 if (prop == FONT_FAMILY_INDEX) | |
| 2746 { | |
| 2747 ASET (font, FONT_FOUNDRY_INDEX, Qnil); | |
| 2748 ASET (font, FONT_ADSTYLE_INDEX, Qnil); | |
| 2749 ASET (font, FONT_SIZE_INDEX, Qnil); | |
| 2750 ASET (font, FONT_DPI_INDEX, Qnil); | |
| 2751 ASET (font, FONT_SPACING_INDEX, Qnil); | |
| 2752 ASET (font, FONT_AVGWIDTH_INDEX, Qnil); | |
| 2753 } | |
| 2754 else if (prop == FONT_SIZE_INDEX) | |
| 2755 { | |
| 2756 ASET (font, FONT_DPI_INDEX, Qnil); | |
| 2757 ASET (font, FONT_SPACING_INDEX, Qnil); | |
| 2758 ASET (font, FONT_AVGWIDTH_INDEX, Qnil); | |
| 2759 } | |
| 2760 attrs[LFACE_FONT_INDEX] = font; | |
| 2761 } | |
| 2762 | |
| 2763 void | |
| 2764 font_update_lface (f, attrs) | |
| 2765 FRAME_PTR f; | |
| 2766 Lisp_Object *attrs; | |
| 90400 | 2767 { |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
2768 Lisp_Object spec; |
| 94926 | 2769 |
| 2770 spec = attrs[LFACE_FONT_INDEX]; | |
| 2771 if (! FONT_SPEC_P (spec)) | |
| 2772 return; | |
| 2773 | |
| 2774 if (! NILP (AREF (spec, FONT_FOUNDRY_INDEX)) | |
| 2775 || ! NILP (AREF (spec, FONT_FAMILY_INDEX))) | |
| 2776 { | |
| 2777 Lisp_Object family; | |
| 2778 | |
| 2779 if (NILP (AREF (spec, FONT_FOUNDRY_INDEX))) | |
| 2780 family = AREF (spec, FONT_FAMILY_INDEX); | |
| 2781 else if (NILP (AREF (spec, FONT_FAMILY_INDEX))) | |
| 2782 family = concat2 (SYMBOL_NAME (AREF (spec, FONT_FOUNDRY_INDEX)), | |
| 2783 build_string ("-*")); | |
| 2784 else | |
| 2785 family = concat3 (SYMBOL_NAME (AREF (spec, FONT_FOUNDRY_INDEX)), | |
| 2786 build_string ("-"), | |
| 2787 SYMBOL_NAME (AREF (spec, FONT_FAMILY_INDEX))); | |
| 2788 attrs[LFACE_FAMILY_INDEX] = family; | |
| 2789 } | |
| 2790 if (! NILP (AREF (spec, FONT_WEIGHT_INDEX))) | |
| 2791 attrs[LFACE_WEIGHT_INDEX] = FONT_WEIGHT_FOR_FACE (spec); | |
| 2792 if (! NILP (AREF (spec, FONT_SLANT_INDEX))) | |
| 2793 attrs[LFACE_SLANT_INDEX] = FONT_SLANT_FOR_FACE (spec);; | |
| 2794 if (! NILP (AREF (spec, FONT_WIDTH_INDEX))) | |
| 2795 attrs[LFACE_SWIDTH_INDEX] = FONT_WIDTH_FOR_FACE (spec); | |
| 2796 if (! NILP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2797 { | |
| 2798 int point; | |
| 2799 | |
| 2800 if (INTEGERP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2801 { | |
| 2802 Lisp_Object val; | |
| 2803 int dpi = f->resy; | |
| 2804 | |
| 2805 val = Ffont_get (spec, QCdpi); | |
| 2806 if (! NILP (val)) | |
| 2807 dpi = XINT (val); | |
| 2808 point = PIXEL_TO_POINT (XINT (AREF (spec, FONT_SIZE_INDEX)) * 10, | |
| 2809 dpi); | |
| 2810 } | |
| 2811 else if (FLOATP (AREF (spec, FONT_SIZE_INDEX))) | |
| 2812 point = XFLOAT_DATA (AREF (spec, FONT_SIZE_INDEX)) * 10; | |
| 2813 attrs[LFACE_HEIGHT_INDEX] = make_number (point); | |
| 2814 } | |
| 90400 | 2815 } |
| 2816 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2817 |
| 94926 | 2818 /* Return a font-entity satisfying SPEC and best matching with face's |
| 2819 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
|
2820 character that the entity must support. */ |
| 90400 | 2821 |
| 2822 Lisp_Object | |
| 94926 | 2823 font_find_for_lface (f, attrs, spec, c) |
| 90400 | 2824 FRAME_PTR f; |
| 94926 | 2825 Lisp_Object *attrs; |
| 90400 | 2826 Lisp_Object spec; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2827 int c; |
| 90400 | 2828 { |
| 94926 | 2829 Lisp_Object frame, entities, val, props[FONT_REGISTRY_INDEX + 1] ; |
| 2830 Lisp_Object size; | |
|
95475
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2831 int pixel_size; |
|
91353
b93ade1a3602
(font_find_for_lface): Check if the character C is
Kenichi Handa <handa@m17n.org>
parents:
91350
diff
changeset
|
2832 int i, result; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
2833 |
| 94926 | 2834 if (c >= 0) |
| 2835 { | |
| 2836 Lisp_Object registry = AREF (spec, FONT_REGISTRY_INDEX); | |
| 2837 struct charset *encoding, *repertory; | |
| 2838 | |
| 2839 if (font_registry_charsets (registry, &encoding, &repertory) < 0) | |
| 2840 return Qnil; | |
| 2841 if (repertory) | |
| 2842 { | |
| 2843 if (ENCODE_CHAR (repertory, c) == CHARSET_INVALID_CODE (repertory)) | |
| 2844 return Qnil; | |
| 2845 /* Any font of this registry support C. So, let's | |
| 2846 suppress the further checking. */ | |
| 2847 c = -1; | |
| 2848 } | |
| 2849 else if (c > encoding->max_char) | |
| 2850 return Qnil; | |
| 2851 } | |
| 2852 | |
|
90507
4a6034a7c870
(font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents:
90503
diff
changeset
|
2853 XSETFRAME (frame, f); |
| 94926 | 2854 size = AREF (spec, FONT_SIZE_INDEX); |
|
95475
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2855 pixel_size = font_pixel_size (f, spec); |
|
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2856 if (pixel_size == 0) |
|
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2857 { |
|
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2858 double pt = XINT (attrs[LFACE_HEIGHT_INDEX]); |
|
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2859 |
|
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2860 pixel_size = POINT_TO_PIXEL (pt / 10, f->resy); |
|
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2861 } |
| 94926 | 2862 ASET (spec, FONT_SIZE_INDEX, Qnil); |
| 2863 entities = font_list_entities (frame, spec); | |
| 2864 ASET (spec, FONT_SIZE_INDEX, size); | |
| 2865 if (ASIZE (entities) == 0) | |
| 2866 return Qnil; | |
| 2867 if (ASIZE (entities) == 1) | |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2868 { |
| 94926 | 2869 if (c < 0) |
| 2870 return AREF (entities, 0); | |
|
90490
8ef2cbaf626a
(font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents:
90483
diff
changeset
|
2871 } |
|
90507
4a6034a7c870
(font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents:
90503
diff
changeset
|
2872 else |
| 90400 | 2873 { |
|
90507
4a6034a7c870
(font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents:
90503
diff
changeset
|
2874 /* 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
|
2875 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
|
2876 |
| 94926 | 2877 for (i = 0; i < FONT_EXTRA_INDEX; i++) |
| 2878 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
|
2879 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
|
2880 { |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2881 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
|
2882 |
|
125a7ecf00db
(font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents:
94968
diff
changeset
|
2883 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
|
2884 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
|
2885 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
|
2886 } |
| 94926 | 2887 if (NILP (AREF (prefer, FONT_FAMILY_INDEX))) |
| 2888 font_parse_family_registry (attrs[LFACE_FAMILY_INDEX], Qnil, prefer); | |
| 2889 if (NILP (AREF (prefer, FONT_WEIGHT_INDEX))) | |
| 2890 FONT_SET_STYLE (prefer, FONT_WEIGHT_INDEX, attrs[LFACE_WEIGHT_INDEX]); | |
| 2891 if (NILP (AREF (prefer, FONT_SLANT_INDEX))) | |
| 2892 FONT_SET_STYLE (prefer, FONT_SLANT_INDEX, attrs[LFACE_SLANT_INDEX]); | |
| 2893 if (NILP (AREF (prefer, FONT_WIDTH_INDEX))) | |
| 2894 FONT_SET_STYLE (prefer, FONT_WIDTH_INDEX, attrs[LFACE_SWIDTH_INDEX]); | |
|
95475
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2895 ASET (prefer, FONT_SIZE_INDEX, make_number (pixel_size)); |
| 94926 | 2896 ASET (spec, FONT_SIZE_INDEX, Qnil); |
| 2897 entities = font_sort_entites (entities, prefer, frame, spec, c < 0); | |
| 2898 ASET (spec, FONT_SIZE_INDEX, size); | |
| 90400 | 2899 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2900 if (c < 0) |
| 94926 | 2901 return entities; |
| 2902 | |
| 2903 for (i = 0; i < ASIZE (entities); i++) | |
| 2904 { | |
| 2905 int j; | |
| 2906 | |
| 2907 val = AREF (entities, i); | |
| 2908 if (i > 0) | |
| 2909 { | |
| 2910 for (j = FONT_FOUNDRY_INDEX; j <= FONT_REGISTRY_INDEX; j++) | |
| 2911 if (! EQ (AREF (val, j), props[j])) | |
| 2912 break; | |
| 2913 if (j > FONT_REGISTRY_INDEX) | |
| 2914 continue; | |
| 2915 } | |
| 2916 for (j = FONT_FOUNDRY_INDEX; j <= FONT_REGISTRY_INDEX; j++) | |
| 2917 props[j] = AREF (val, j); | |
| 2918 result = font_has_char (f, val, c); | |
| 2919 if (result > 0) | |
| 2920 return val; | |
| 2921 if (result == 0) | |
| 2922 return Qnil; | |
| 2923 val = font_open_for_lface (f, val, attrs, spec); | |
| 2924 if (NILP (val)) | |
| 2925 continue; | |
| 2926 result = font_has_char (f, val, c); | |
| 2927 font_close_object (f, val); | |
| 2928 if (result > 0) | |
| 2929 return AREF (entities, i); | |
| 2930 } | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
2931 return Qnil; |
| 90400 | 2932 } |
| 2933 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2934 |
| 90400 | 2935 Lisp_Object |
| 94926 | 2936 font_open_for_lface (f, entity, attrs, spec) |
| 90400 | 2937 FRAME_PTR f; |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2938 Lisp_Object entity; |
| 94926 | 2939 Lisp_Object *attrs; |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2940 Lisp_Object spec; |
| 90400 | 2941 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2942 int size; |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
2943 |
|
95475
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2944 if (FONT_SPEC_P (spec) && ! NILP (AREF (spec, FONT_SIZE_INDEX))) |
|
e1e8d6b9d465
(font_find_for_lface): Handle float font size.
Kenichi Handa <handa@m17n.org>
parents:
95437
diff
changeset
|
2945 size = font_pixel_size (f, spec); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2946 else |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2947 { |
| 94926 | 2948 double pt = XINT (attrs[LFACE_HEIGHT_INDEX]); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2949 |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2950 pt /= 10; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2951 size = POINT_TO_PIXEL (pt, f->resy); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
2952 } |
| 90400 | 2953 return font_open_entity (f, entity, size); |
| 2954 } | |
| 2955 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2956 |
| 94926 | 2957 /* Find a font satisfying SPEC and best matching with face's |
| 2958 attributes in ATTRS on FRAME, and return the opened | |
| 2959 font-object. */ | |
| 2960 | |
| 2961 Lisp_Object | |
| 2962 font_load_for_lface (f, attrs, spec) | |
| 90400 | 2963 FRAME_PTR f; |
| 94926 | 2964 Lisp_Object *attrs, spec; |
| 90400 | 2965 { |
| 94926 | 2966 Lisp_Object entity; |
| 2967 | |
| 2968 entity = font_find_for_lface (f, attrs, spec, -1); | |
| 2969 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
|
2970 { |
| 94926 | 2971 /* No font is listed for SPEC, but each font-backend may have |
| 2972 the different criteria about "font matching". So, try | |
| 2973 it. */ | |
| 2974 entity = font_matching_entity (f, attrs, spec); | |
| 2975 if (NILP (entity)) | |
| 2976 return Qnil; | |
|
91350
9673276f310c
(font_load_for_face): Handle the case that the font in
Kenichi Handa <handa@m17n.org>
parents:
91337
diff
changeset
|
2977 } |
| 94926 | 2978 return font_open_for_lface (f, entity, attrs, spec); |
| 90400 | 2979 } |
| 2980 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2981 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2982 /* 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
|
2983 |
| 90400 | 2984 void |
| 2985 font_prepare_for_face (f, face) | |
| 2986 FRAME_PTR f; | |
| 2987 struct face *face; | |
| 2988 { | |
| 94926 | 2989 if (face->font->driver->prepare_face) |
| 2990 face->font->driver->prepare_face (f, face); | |
| 90400 | 2991 } |
| 2992 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2993 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
2994 /* 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
|
2995 |
| 90400 | 2996 void |
| 2997 font_done_for_face (f, face) | |
| 2998 FRAME_PTR f; | |
| 2999 struct face *face; | |
| 3000 { | |
| 94926 | 3001 if (face->font->driver->done_face) |
| 3002 face->font->driver->done_face (f, face); | |
| 90400 | 3003 face->extra = NULL; |
| 3004 } | |
| 3005 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3006 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3007 /* 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
|
3008 is found, return Qnil. */ |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3009 |
| 90400 | 3010 Lisp_Object |
| 3011 font_open_by_name (f, name) | |
| 3012 FRAME_PTR f; | |
| 3013 char *name; | |
| 3014 { | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3015 Lisp_Object args[2]; |
| 95699 | 3016 Lisp_Object spec, prefer, size, registry, entity, entity_list; |
| 90400 | 3017 Lisp_Object frame; |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3018 int i; |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3019 int pixel_size; |
| 90400 | 3020 |
| 3021 XSETFRAME (frame, f); | |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3022 |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3023 args[0] = QCname; |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3024 args[1] = make_unibyte_string (name, strlen (name)); |
|
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3025 spec = Ffont_spec (2, args); |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3026 prefer = scratch_font_prefer; |
| 94926 | 3027 for (i = 0; i < FONT_SPEC_MAX; i++) |
| 3028 { | |
| 3029 ASET (prefer, i, AREF (spec, i)); | |
| 3030 if (NILP (AREF (prefer, i)) | |
| 3031 && i >= FONT_WEIGHT_INDEX && i <= FONT_WIDTH_INDEX) | |
| 3032 FONT_SET_STYLE (prefer, i, make_number (100)); | |
| 3033 } | |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3034 size = AREF (spec, FONT_SIZE_INDEX); |
|
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3035 if (NILP (size)) |
|
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3036 pixel_size = 0; |
| 94926 | 3037 else |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3038 { |
| 94926 | 3039 if (INTEGERP (size)) |
| 3040 pixel_size = XINT (size); | |
| 3041 else /* FLOATP (size) */ | |
| 3042 { | |
| 3043 double pt = XFLOAT_DATA (size); | |
| 3044 | |
| 3045 pixel_size = POINT_TO_PIXEL (pt, f->resy); | |
| 3046 } | |
| 3047 if (pixel_size == 0) | |
| 3048 ASET (spec, FONT_SIZE_INDEX, Qnil); | |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3049 } |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3050 if (pixel_size == 0) |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3051 { |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
3052 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
|
3053 size = make_number (pixel_size); |
| 94926 | 3054 ASET (prefer, FONT_SIZE_INDEX, size); |
|
90468
5424215feef6
(XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents:
90451
diff
changeset
|
3055 } |
| 95699 | 3056 registry = AREF (spec, FONT_REGISTRY_INDEX); |
| 3057 if (NILP (registry)) | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
3058 ASET (spec, FONT_REGISTRY_INDEX, Qiso8859_1); |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3059 entity_list = Flist_fonts (spec, frame, make_number (1), prefer); |
| 95699 | 3060 if (NILP (entity_list) && NILP (registry)) |
| 3061 { | |
| 3062 ASET (spec, FONT_REGISTRY_INDEX, Qascii_0); | |
| 3063 entity_list = Flist_fonts (spec, frame, make_number (1), prefer); | |
| 3064 } | |
| 3065 ASET (spec, FONT_REGISTRY_INDEX, registry); | |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3066 if (NILP (entity_list)) |
| 94926 | 3067 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
|
3068 else |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3069 entity = XCAR (entity_list); |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3070 return (NILP (entity) |
|
90476
017a6aec5d77
(font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents:
90468
diff
changeset
|
3071 ? Qnil |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3072 : font_open_entity (f, entity, pixel_size)); |
| 90400 | 3073 } |
| 3074 | |
| 3075 | |
| 3076 /* Register font-driver DRIVER. This function is used in two ways. | |
| 3077 | |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3078 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
|
3079 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
|
3080 (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
|
3081 an available font-driver. |
| 90400 | 3082 |
| 3083 The second is with frame F NULL. In this case, DRIVER is globally | |
| 3084 registered in the variable `font_driver_list'. All font-driver | |
| 3085 implementations must call this function in its syms_of_XXXX | |
| 3086 (e.g. syms_of_xfont). */ | |
| 3087 | |
| 3088 void | |
| 3089 register_font_driver (driver, f) | |
| 3090 struct font_driver *driver; | |
| 3091 FRAME_PTR f; | |
| 3092 { | |
| 3093 struct font_driver_list *root = f ? f->font_driver_list : font_driver_list; | |
| 3094 struct font_driver_list *prev, *list; | |
| 3095 | |
| 3096 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
|
3097 error ("Unusable font driver for a frame: %s", |
| 90400 | 3098 SDATA (SYMBOL_NAME (driver->type))); |
| 3099 | |
| 3100 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
|
3101 if (EQ (list->driver->type, driver->type)) |
| 90400 | 3102 error ("Duplicated font driver: %s", SDATA (SYMBOL_NAME (driver->type))); |
| 3103 | |
| 3104 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
|
3105 list->on = 0; |
| 90400 | 3106 list->driver = driver; |
| 3107 list->next = NULL; | |
| 3108 if (prev) | |
| 3109 prev->next = list; | |
| 3110 else if (f) | |
| 3111 f->font_driver_list = list; | |
| 3112 else | |
| 3113 font_driver_list = list; | |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
3114 if (! f) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
3115 num_font_drivers++; |
| 90400 | 3116 } |
| 3117 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3118 |
| 90400 | 3119 /* Free font-driver list on frame F. It doesn't free font-drivers |
| 3120 themselves. */ | |
| 3121 | |
| 3122 void | |
| 3123 free_font_driver_list (f) | |
| 3124 FRAME_PTR f; | |
| 3125 { | |
| 3126 while (f->font_driver_list) | |
| 3127 { | |
| 3128 struct font_driver_list *next = f->font_driver_list->next; | |
| 3129 | |
| 3130 free (f->font_driver_list); | |
| 3131 f->font_driver_list = next; | |
| 3132 } | |
| 3133 } | |
| 3134 | |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3135 |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3136 /* 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
|
3137 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
|
3138 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
|
3139 |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3140 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
|
3141 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
|
3142 F. */ |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3143 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3144 Lisp_Object |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3145 font_update_drivers (f, new_drivers) |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3146 FRAME_PTR f; |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3147 Lisp_Object new_drivers; |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3148 { |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3149 Lisp_Object active_drivers = Qnil; |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3150 struct font_driver_list *list; |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3151 |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3152 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
|
3153 if (list->on) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3154 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3155 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
|
3156 && 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
|
3157 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3158 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
|
3159 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
|
3160 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
|
3161 list->on = 0; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3162 } |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3163 } |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3164 else |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3165 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3166 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
|
3167 || ! 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
|
3168 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3169 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
|
3170 || 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
|
3171 { |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3172 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
|
3173 list->on = 1; |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3174 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
|
3175 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
|
3176 } |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3177 } |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3178 } |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3179 |
|
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3180 return active_drivers; |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3181 } |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3182 |
|
91112
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3183 int |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3184 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
|
3185 FRAME_PTR f; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3186 struct font_driver *driver; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3187 void *data; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3188 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3189 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
|
3190 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3191 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
|
3192 prev = list, list = list->next) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3193 if (list->driver == driver) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3194 break; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3195 if (! data) |
|
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 if (list) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3198 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3199 if (prev) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3200 prev->next = list->next; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3201 else |
|
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->next; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3203 free (list); |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3204 } |
|
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 if (! list) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3209 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3210 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
|
3211 if (! list) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3212 return -1; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3213 list->driver = driver; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3214 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
|
3215 f->font_data_list = list; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3216 } |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3217 list->data = data; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3218 return 0; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3219 } |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3220 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3221 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3222 void * |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3223 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
|
3224 FRAME_PTR f; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3225 struct font_driver *driver; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3226 { |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3227 struct font_data_list *list; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3228 |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3229 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
|
3230 if (list->driver == driver) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3231 break; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3232 if (! list) |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3233 return NULL; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3234 return list->data; |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3235 } |
|
8042dbbb0419
(font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents:
91081
diff
changeset
|
3236 |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3237 |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3238 /* 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
|
3239 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
|
3240 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
|
3241 STRING. */ |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3242 |
| 90541 | 3243 Lisp_Object |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3244 font_at (c, pos, face, w, string) |
| 90541 | 3245 int c; |
| 3246 EMACS_INT pos; | |
| 3247 struct face *face; | |
| 3248 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
|
3249 Lisp_Object string; |
| 90541 | 3250 { |
| 3251 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
|
3252 int multibyte; |
| 94926 | 3253 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
|
3254 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3255 if (c < 0) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3256 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3257 if (NILP (string)) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3258 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3259 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
|
3260 if (multibyte) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3261 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3262 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
|
3263 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3264 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
|
3265 } |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3266 else |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3267 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
|
3268 } |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3269 else |
|
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 unsigned char *str; |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3272 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3273 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
|
3274 if (multibyte) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3275 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3276 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
|
3277 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3278 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
|
3279 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
|
3280 } |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3281 else |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3282 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
|
3283 } |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3284 } |
| 90541 | 3285 |
| 3286 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
|
3287 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
|
3288 return Qnil; |
| 90541 | 3289 if (! face) |
| 3290 { | |
|
91236
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; |
|
92237
ce06567a933d
* dispextern.h (face_at_buffer_position, face_for_overlay_string)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
92233
diff
changeset
|
3292 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
|
3293 |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3294 if (STRINGP (string)) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3295 face_id = face_at_string_position (w, string, pos, 0, -1, -1, &endptr, |
| 90541 | 3296 DEFAULT_FACE_ID, 0); |
| 3297 else | |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3298 face_id = face_at_buffer_position (w, pos, -1, -1, &endptr, |
| 90541 | 3299 pos + 100, 0); |
| 3300 face = FACE_FROM_ID (f, face_id); | |
| 3301 } | |
|
91236
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3302 if (multibyte) |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3303 { |
|
e3ba579aab1f
(font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents:
91192
diff
changeset
|
3304 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
|
3305 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
|
3306 } |
| 94926 | 3307 if (! face->font) |
| 90541 | 3308 return Qnil; |
| 94926 | 3309 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3310 font_assert (font_check_object ((struct font *) face->font)); |
| 94926 | 3311 XSETFONT (font_object, face->font); |
| 3312 return font_object; | |
| 3313 } | |
| 3314 | |
| 3315 | |
| 3316 /* Check how many characters after POS (at most to LIMIT) can be | |
| 3317 displayed by the same font. FACE is the face selected for the | |
| 3318 character as POS on frame F. STRING, if not nil, is the string to | |
| 3319 check instead of the current buffer. | |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3320 |
| 94926 | 3321 The return value is the position of the character that is displayed |
| 3322 by the differnt font than that of the character as POS. */ | |
| 3323 | |
| 3324 EMACS_INT | |
| 3325 font_range (pos, limit, face, f, string) | |
| 3326 EMACS_INT pos, limit; | |
| 3327 struct face *face; | |
| 3328 FRAME_PTR f; | |
| 3329 Lisp_Object string; | |
| 3330 { | |
| 3331 int multibyte; | |
| 3332 EMACS_INT pos_byte; | |
| 3333 int c; | |
| 3334 struct font *font; | |
| 3335 int first = 1; | |
| 3336 | |
| 3337 if (NILP (string)) | |
| 3338 { | |
| 3339 multibyte = ! NILP (current_buffer->enable_multibyte_characters); | |
| 3340 pos_byte = CHAR_TO_BYTE (pos); | |
| 3341 } | |
| 3342 else | |
| 3343 { | |
| 3344 multibyte = STRING_MULTIBYTE (string); | |
| 3345 pos_byte = string_char_to_byte (string, pos); | |
| 3346 } | |
| 3347 | |
| 3348 if (! multibyte) | |
| 3349 /* All unibyte character are displayed by the same font. */ | |
| 3350 return limit; | |
| 3351 | |
| 3352 while (pos < limit) | |
| 3353 { | |
| 3354 int face_id; | |
| 3355 | |
| 3356 if (NILP (string)) | |
| 3357 FETCH_CHAR_ADVANCE_NO_CHECK (c, pos, pos_byte); | |
| 3358 else | |
| 3359 FETCH_STRING_CHAR_ADVANCE_NO_CHECK (c, string, pos, pos_byte); | |
| 3360 face_id = FACE_FOR_CHAR (f, face, c, pos, string); | |
| 3361 face = FACE_FROM_ID (f, face_id); | |
| 3362 if (first) | |
| 3363 { | |
| 3364 font = face->font; | |
| 3365 first = 0; | |
| 3366 continue; | |
| 3367 } | |
| 3368 else if (font != face->font) | |
| 3369 { | |
| 3370 pos--; | |
| 3371 break; | |
| 3372 } | |
| 3373 } | |
| 3374 return pos; | |
| 90541 | 3375 } |
| 3376 | |
| 90400 | 3377 |
| 3378 /* Lisp API */ | |
| 3379 | |
| 94926 | 3380 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
|
3381 doc: /* Return t if OBJECT is a font-spec, font-entity, or font-object. |
| 94926 | 3382 Return nil otherwise. |
| 3383 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
|
3384 which kind of font it is. It must be one of `font-spec', `font-entity', |
| 94926 | 3385 `font-object'. */) |
| 3386 (object, extra_type) | |
| 3387 Lisp_Object object, extra_type; | |
| 90400 | 3388 { |
| 94926 | 3389 if (NILP (extra_type)) |
| 3390 return (FONTP (object) ? Qt : Qnil); | |
| 3391 if (EQ (extra_type, Qfont_spec)) | |
| 3392 return (FONT_SPEC_P (object) ? Qt : Qnil); | |
| 3393 if (EQ (extra_type, Qfont_entity)) | |
| 3394 return (FONT_ENTITY_P (object) ? Qt : Qnil); | |
| 3395 if (EQ (extra_type, Qfont_object)) | |
| 3396 return (FONT_OBJECT_P (object) ? Qt : Qnil); | |
| 3397 wrong_type_argument (intern ("font-extra-type"), extra_type); | |
| 90400 | 3398 } |
| 3399 | |
| 3400 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
|
3401 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
|
3402 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3403 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
|
3404 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
|
3405 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3406 `:family', `:weight', `:slant', `:width' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3407 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3408 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
|
3409 `set-face-attribute'. |
|
91081
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3410 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3411 `:foundry' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3412 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3413 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
|
3414 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3415 `:adstyle' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3416 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3417 VALUE must be a string or a symbol specifying the additional |
| 94926 | 3418 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
|
3419 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3420 `:registry' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3421 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3422 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
|
3423 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
|
3424 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3425 `:size' |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3426 |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3427 VALUE must be a non-negative integer or a floating point number |
| 94926 | 3428 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
|
3429 (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
|
3430 usage: (font-spec ARGS ...) */) |
| 90400 | 3431 (nargs, args) |
| 3432 int nargs; | |
| 3433 Lisp_Object *args; | |
| 3434 { | |
| 94926 | 3435 Lisp_Object spec = font_make_spec (); |
| 90400 | 3436 int i; |
| 3437 | |
| 3438 for (i = 0; i < nargs; i += 2) | |
| 3439 { | |
| 3440 Lisp_Object key = args[i], val = args[i + 1]; | |
| 3441 | |
| 94926 | 3442 if (EQ (key, QCname)) |
| 3443 { | |
| 3444 CHECK_STRING (val); | |
| 3445 font_parse_name ((char *) SDATA (val), spec); | |
| 3446 font_put_extra (spec, key, val); | |
| 3447 } | |
| 90400 | 3448 else |
|
90451
6ffc9b378367
(enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents:
90448
diff
changeset
|
3449 { |
| 94926 | 3450 int idx = get_font_prop_index (key); |
| 3451 | |
| 3452 if (idx >= 0) | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
3453 { |
| 94926 | 3454 val = font_prop_validate (idx, Qnil, val); |
| 3455 if (idx < FONT_EXTRA_INDEX) | |
| 3456 ASET (spec, idx, val); | |
| 3457 else | |
| 3458 font_put_extra (spec, key, val); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
3459 } |
| 94926 | 3460 else |
| 3461 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
|
3462 } |
|
90563
7c29515f7c2a
(font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents:
90556
diff
changeset
|
3463 } |
| 90400 | 3464 return spec; |
| 3465 } | |
| 3466 | |
| 94926 | 3467 DEFUN ("copy-font-spec", Fcopy_font_spec, Scopy_font_spec, 1, 1, 0, |
| 3468 doc: /* Return a copy of FONT as a font-spec. */) | |
| 3469 (font) | |
| 3470 Lisp_Object font; | |
| 3471 { | |
| 3472 Lisp_Object new_spec, tail, extra; | |
| 3473 int i; | |
| 3474 | |
| 3475 CHECK_FONT (font); | |
| 3476 new_spec = font_make_spec (); | |
| 3477 for (i = 1; i < FONT_EXTRA_INDEX; i++) | |
| 3478 ASET (new_spec, i, AREF (font, i)); | |
| 3479 extra = Qnil; | |
| 3480 for (tail = AREF (font, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail)) | |
| 3481 { | |
| 3482 if (! EQ (XCAR (XCAR (tail)), QCfont_entity)) | |
| 3483 extra = Fcons (Fcons (XCAR (XCAR (tail)), XCDR (XCAR (tail))), extra); | |
| 3484 } | |
| 3485 ASET (new_spec, FONT_EXTRA_INDEX, extra); | |
| 3486 return new_spec; | |
| 3487 } | |
| 3488 | |
| 3489 DEFUN ("merge-font-spec", Fmerge_font_spec, Smerge_font_spec, 2, 2, 0, | |
| 3490 doc: /* Merge font-specs FROM and TO, and return a new font-spec. | |
| 3491 Every specified properties in FROM override the corresponding | |
| 3492 properties in TO. */) | |
| 3493 (from, to) | |
| 3494 Lisp_Object from, to; | |
| 3495 { | |
| 3496 Lisp_Object extra, tail; | |
| 3497 int i; | |
| 3498 | |
| 3499 CHECK_FONT (from); | |
| 3500 CHECK_FONT (to); | |
| 3501 to = Fcopy_font_spec (to); | |
| 3502 for (i = 0; i < FONT_EXTRA_INDEX; i++) | |
| 3503 ASET (to, i, AREF (from, i)); | |
| 3504 extra = AREF (to, FONT_EXTRA_INDEX); | |
| 3505 for (tail = AREF (from, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail)) | |
| 3506 if (! EQ (XCAR (XCAR (tail)), Qfont_entity)) | |
| 3507 { | |
| 3508 Lisp_Object slot = assq_no_quit (XCAR (XCAR (tail)), extra); | |
| 3509 | |
| 3510 if (! NILP (slot)) | |
| 3511 XSETCDR (slot, XCDR (XCAR (tail))); | |
| 3512 else | |
| 3513 extra = Fcons (Fcons (XCAR (XCAR (tail)), XCDR (XCAR (tail))), extra); | |
| 3514 } | |
| 3515 ASET (to, FONT_EXTRA_INDEX, extra); | |
| 3516 return to; | |
| 3517 } | |
| 90400 | 3518 |
| 3519 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
|
3520 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
|
3521 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
|
3522 (font, key) |
|
2c767d9f0bb1
(font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents:
90993
diff
changeset
|
3523 Lisp_Object font, key; |
| 90400 | 3524 { |
| 94926 | 3525 int idx; |
| 3526 | |
| 3527 CHECK_FONT (font); | |
| 3528 CHECK_SYMBOL (key); | |
| 3529 | |
| 3530 idx = get_font_prop_index (key); | |
| 3531 if (idx >= 0 && idx < FONT_EXTRA_INDEX) | |
| 90400 | 3532 return AREF (font, idx); |
| 94926 | 3533 return Fcdr (Fassq (key, AREF (font, FONT_EXTRA_INDEX))); |
| 90400 | 3534 } |
| 3535 | |
| 3536 | |
| 3537 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
|
3538 doc: /* Set one property of FONT-SPEC: give property PROP value VAL. */) |
| 90400 | 3539 (font_spec, prop, val) |
| 3540 Lisp_Object font_spec, prop, val; | |
| 3541 { | |
| 94926 | 3542 int idx; |
| 90400 | 3543 |
| 3544 CHECK_FONT_SPEC (font_spec); | |
| 94926 | 3545 idx = get_font_prop_index (prop); |
| 3546 if (idx >= 0 && idx < FONT_EXTRA_INDEX) | |
|
95573
0da1a8e03099
(Ffont_put): Don't use font_parse_family_registry for
Kenichi Handa <handa@m17n.org>
parents:
95572
diff
changeset
|
3547 ASET (font_spec, idx, font_prop_validate (idx, Qnil, val)); |
| 90400 | 3548 else |
| 94926 | 3549 font_put_extra (font_spec, prop, font_prop_validate (0, prop, val)); |
| 90400 | 3550 return val; |
| 3551 } | |
| 3552 | |
| 3553 DEFUN ("list-fonts", Flist_fonts, Slist_fonts, 1, 4, 0, | |
| 3554 doc: /* List available fonts matching FONT-SPEC on the current frame. | |
| 3555 Optional 2nd argument FRAME specifies the target frame. | |
| 3556 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
|
3557 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
|
3558 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
|
3559 how close they are to PREFER. */) |
| 90400 | 3560 (font_spec, frame, num, prefer) |
| 3561 Lisp_Object font_spec, frame, num, prefer; | |
| 3562 { | |
| 3563 Lisp_Object vec, list, tail; | |
| 3564 int n = 0, i, len; | |
| 3565 | |
| 3566 if (NILP (frame)) | |
| 3567 frame = selected_frame; | |
| 3568 CHECK_LIVE_FRAME (frame); | |
| 94926 | 3569 CHECK_FONT_SPEC (font_spec); |
| 90400 | 3570 if (! NILP (num)) |
| 3571 { | |
| 3572 CHECK_NUMBER (num); | |
| 3573 n = XINT (num); | |
| 3574 if (n <= 0) | |
| 3575 return Qnil; | |
| 3576 } | |
| 3577 if (! NILP (prefer)) | |
| 94926 | 3578 CHECK_FONT_SPEC (prefer); |
| 90400 | 3579 |
| 3580 vec = font_list_entities (frame, font_spec); | |
| 3581 len = ASIZE (vec); | |
| 3582 if (len == 0) | |
| 3583 return Qnil; | |
| 3584 if (len == 1) | |
| 3585 return Fcons (AREF (vec, 0), Qnil); | |
| 3586 | |
| 3587 if (! NILP (prefer)) | |
| 94926 | 3588 vec = font_sort_entites (vec, prefer, frame, font_spec, 0); |
| 90400 | 3589 |
| 3590 list = tail = Fcons (AREF (vec, 0), Qnil); | |
| 3591 if (n == 0 || n > len) | |
| 3592 n = len; | |
| 3593 for (i = 1; i < n; i++) | |
| 3594 { | |
| 3595 Lisp_Object val = Fcons (AREF (vec, i), Qnil); | |
| 3596 | |
| 3597 XSETCDR (tail, val); | |
| 3598 tail = val; | |
| 3599 } | |
| 3600 return list; | |
| 3601 } | |
| 3602 | |
| 94926 | 3603 DEFUN ("font-family-list", Ffont_family_list, Sfont_family_list, 0, 1, 0, |
| 90400 | 3604 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
|
3605 Optional argument FRAME, if non-nil, specifies the target frame. */) |
| 90400 | 3606 (frame) |
| 3607 Lisp_Object frame; | |
| 3608 { | |
| 3609 FRAME_PTR f; | |
| 3610 struct font_driver_list *driver_list; | |
| 3611 Lisp_Object list; | |
| 3612 | |
| 3613 if (NILP (frame)) | |
| 3614 frame = selected_frame; | |
| 3615 CHECK_LIVE_FRAME (frame); | |
| 3616 f = XFRAME (frame); | |
| 3617 list = Qnil; | |
| 3618 for (driver_list = f->font_driver_list; driver_list; | |
| 3619 driver_list = driver_list->next) | |
| 3620 if (driver_list->driver->list_family) | |
| 3621 { | |
| 3622 Lisp_Object val = driver_list->driver->list_family (frame); | |
| 3623 | |
| 3624 if (NILP (list)) | |
| 3625 list = val; | |
| 3626 else | |
| 3627 { | |
| 3628 Lisp_Object tail = list; | |
| 3629 | |
| 3630 for (; CONSP (val); val = XCDR (val)) | |
| 3631 if (NILP (Fmemq (XCAR (val), tail))) | |
| 3632 list = Fcons (XCAR (val), list); | |
| 3633 } | |
| 3634 } | |
| 3635 return list; | |
| 3636 } | |
| 3637 | |
| 3638 DEFUN ("find-font", Ffind_font, Sfind_font, 1, 2, 0, | |
| 3639 doc: /* Return a font-entity matching with FONT-SPEC on the current frame. | |
| 3640 Optional 2nd argument FRAME, if non-nil, specifies the target frame. */) | |
| 3641 (font_spec, frame) | |
| 3642 Lisp_Object font_spec, frame; | |
| 3643 { | |
| 3644 Lisp_Object val = Flist_fonts (font_spec, frame, make_number (1), Qnil); | |
| 3645 | |
| 3646 if (CONSP (val)) | |
| 3647 val = XCAR (val); | |
| 3648 return val; | |
| 3649 } | |
| 3650 | |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3651 DEFUN ("font-xlfd-name", Ffont_xlfd_name, Sfont_xlfd_name, 1, 2, 0, |
| 90400 | 3652 doc: /* Return XLFD name of FONT. |
| 3653 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
|
3654 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
|
3655 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
|
3656 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
|
3657 (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
|
3658 Lisp_Object font, fold_wildcards; |
| 90400 | 3659 { |
| 3660 char name[256]; | |
| 3661 int pixel_size = 0; | |
| 3662 | |
| 94926 | 3663 CHECK_FONT (font); |
| 3664 | |
| 3665 if (FONT_OBJECT_P (font)) | |
| 90400 | 3666 { |
| 94926 | 3667 Lisp_Object font_name = AREF (font, FONT_NAME_INDEX); |
| 3668 | |
| 3669 if (STRINGP (font_name) | |
| 3670 && 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
|
3671 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3672 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
|
3673 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
|
3674 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
|
3675 goto done; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3676 } |
| 94926 | 3677 pixel_size = XFONT_OBJECT (font)->pixel_size; |
| 90400 | 3678 } |
| 3679 if (font_unparse_xlfd (font, pixel_size, name, 256) < 0) | |
| 3680 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
|
3681 done: |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3682 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
|
3683 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3684 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
|
3685 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3686 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
|
3687 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3688 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
|
3689 p0 = p1; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3690 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3691 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
3692 |
| 90400 | 3693 return build_string (name); |
| 3694 } | |
| 3695 | |
| 3696 DEFUN ("clear-font-cache", Fclear_font_cache, Sclear_font_cache, 0, 0, 0, | |
| 3697 doc: /* Clear font cache. */) | |
| 3698 () | |
| 3699 { | |
| 3700 Lisp_Object list, frame; | |
| 3701 | |
| 3702 FOR_EACH_FRAME (list, frame) | |
| 3703 { | |
| 3704 FRAME_PTR f = XFRAME (frame); | |
| 3705 struct font_driver_list *driver_list = f->font_driver_list; | |
| 3706 | |
| 3707 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
|
3708 if (driver_list->on) |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3709 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3710 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
|
3711 Lisp_Object val; |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
3712 |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3713 val = XCDR (cache); |
| 91909 | 3714 while (! NILP (val) |
| 3715 && ! 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
|
3716 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
|
3717 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
|
3718 val = XCDR (XCAR (val)); |
|
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3719 if (XINT (XCAR (val)) == 0) |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3720 { |
|
91247
217eabc2db11
(font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents:
91240
diff
changeset
|
3721 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
|
3722 XSETCDR (cache, XCDR (val)); |
|
90549
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3723 } |
|
5dab62a4573c
(font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents:
90541
diff
changeset
|
3724 } |
| 90400 | 3725 } |
| 3726 | |
| 3727 return Qnil; | |
| 3728 } | |
| 3729 | |
| 95177 | 3730 /* 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
|
3731 |
| 90400 | 3732 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
|
3733 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
|
3734 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
|
3735 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3736 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
|
3737 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
|
3738 [ HEADER GLYPH ... ] |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3739 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
|
3740 [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
|
3741 where |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
3742 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
|
3743 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
|
3744 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
|
3745 [ 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
|
3746 [ [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
|
3747 where |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
3748 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
|
3749 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
|
3750 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
|
3751 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
|
3752 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
|
3753 WADJUST is the adjustment to the normal width of the glyph. */) |
| 90400 | 3754 (font_object, num) |
| 3755 Lisp_Object font_object, num; | |
| 3756 { | |
| 3757 Lisp_Object gstring, g; | |
| 3758 int len; | |
| 3759 int i; | |
| 3760 | |
| 3761 if (! NILP (font_object)) | |
| 3762 CHECK_FONT_OBJECT (font_object); | |
| 3763 CHECK_NATNUM (num); | |
| 3764 | |
| 3765 len = XINT (num) + 1; | |
| 3766 gstring = Fmake_vector (make_number (len), Qnil); | |
| 3767 g = Fmake_vector (make_number (6), Qnil); | |
| 3768 ASET (g, 0, font_object); | |
| 3769 ASET (gstring, 0, g); | |
| 3770 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
|
3771 ASET (gstring, i, Fmake_vector (make_number (10), Qnil)); |
| 90400 | 3772 return gstring; |
| 3773 } | |
| 3774 | |
| 3775 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
|
3776 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
|
3777 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
|
3778 If optional 5rd argument OBJECT is non-nil, it is a buffer or a string from |
| 90400 | 3779 where to extract characters. |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
3780 FONT-OBJECT may be nil if GSTRING already contains one. */) |
| 90400 | 3781 (gstring, font_object, start, end, object) |
| 3782 Lisp_Object gstring, font_object, start, end, object; | |
| 3783 { | |
| 3784 int len, i, c; | |
| 3785 unsigned code; | |
| 3786 struct font *font; | |
| 3787 | |
| 3788 CHECK_VECTOR (gstring); | |
| 3789 if (NILP (font_object)) | |
| 90541 | 3790 font_object = LGSTRING_FONT (gstring); |
| 94926 | 3791 font = XFONT_OBJECT (font_object); |
| 90400 | 3792 |
| 3793 if (STRINGP (object)) | |
| 3794 { | |
| 3795 const unsigned char *p; | |
| 3796 | |
| 3797 CHECK_NATNUM (start); | |
| 3798 CHECK_NATNUM (end); | |
| 3799 if (XINT (start) > XINT (end) | |
| 3800 || XINT (end) > ASIZE (object) | |
| 90541 | 3801 || 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
|
3802 args_out_of_range_3 (object, start, end); |
| 90400 | 3803 |
| 3804 len = XINT (end) - XINT (start); | |
| 3805 p = SDATA (object) + string_char_to_byte (object, XINT (start)); | |
| 3806 for (i = 0; i < len; i++) | |
| 3807 { | |
| 3808 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
|
3809 /* 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
|
3810 MOST_POSITIVE_FIXNUM below. */ |
|
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3811 EMACS_INT cod; |
| 90400 | 3812 |
| 3813 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
|
3814 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
|
3815 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
|
3816 break; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3817 LGLYPH_SET_FROM (g, i); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3818 LGLYPH_SET_TO (g, i); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3819 LGLYPH_SET_CHAR (g, c); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3820 LGLYPH_SET_CODE (g, code); |
| 90400 | 3821 } |
| 3822 } | |
| 3823 else | |
| 3824 { | |
| 3825 int pos, pos_byte; | |
| 3826 | |
| 3827 if (! NILP (object)) | |
| 3828 Fset_buffer (object); | |
| 3829 validate_region (&start, &end); | |
| 90541 | 3830 if (XINT (end) - XINT (start) > LGSTRING_LENGTH (gstring)) |
| 90400 | 3831 args_out_of_range (start, end); |
| 3832 len = XINT (end) - XINT (start); | |
| 3833 pos = XINT (start); | |
| 3834 pos_byte = CHAR_TO_BYTE (pos); | |
| 3835 for (i = 0; i < len; i++) | |
| 3836 { | |
| 3837 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
|
3838 /* 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
|
3839 MOST_POSITIVE_FIXNUM below. */ |
|
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
3840 EMACS_INT cod; |
| 90400 | 3841 |
| 3842 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
|
3843 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
|
3844 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
|
3845 break; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3846 LGLYPH_SET_FROM (g, i); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3847 LGLYPH_SET_TO (g, i); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3848 LGLYPH_SET_CHAR (g, c); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3849 LGLYPH_SET_CODE (g, code); |
| 90400 | 3850 } |
| 3851 } | |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3852 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
|
3853 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
|
3854 return Qnil; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3855 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3856 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3857 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
|
3858 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
|
3859 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
|
3860 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
|
3861 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
|
3862 FONT-OBJECT. */) |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3863 (from, to, font_object, string) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3864 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
|
3865 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3866 struct font *font; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3867 struct font_metrics metrics; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3868 EMACS_INT start, end; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3869 Lisp_Object gstring, n; |
| 94926 | 3870 int len, i; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3871 |
|
92183
275e5e980fc4
If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents:
92113
diff
changeset
|
3872 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
|
3873 return Qnil; |
| 94926 | 3874 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
|
3875 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
|
3876 return Qnil; |
|
275e5e980fc4
If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents:
92113
diff
changeset
|
3877 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3878 if (NILP (string)) |
| 90541 | 3879 { |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3880 validate_region (&from, &to); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3881 start = XFASTINT (from); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3882 end = XFASTINT (to); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3883 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
|
3884 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3885 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3886 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3887 CHECK_STRING (string); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3888 start = XINT (from); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3889 end = XINT (to); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3890 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
|
3891 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
|
3892 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3893 |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3894 len = end - start; |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3895 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
|
3896 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
|
3897 |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3898 /* 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
|
3899 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
|
3900 { |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3901 Lisp_Object args[2]; |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3902 |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3903 n = font->driver->shape (gstring); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3904 if (INTEGERP (n)) |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3905 break; |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3906 args[0] = gstring; |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3907 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
|
3908 gstring = Fvconcat (2, args); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3909 } |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3910 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
|
3911 return Qnil; |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3912 len = XINT (n); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3913 |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3914 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
|
3915 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3916 Lisp_Object gstr; |
| 90541 | 3917 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
|
3918 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
|
3919 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
|
3920 int j, k; |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3921 int need_composition = 0; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3922 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3923 metrics.lbearing = LGLYPH_LBEARING (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3924 metrics.rbearing = LGLYPH_RBEARING (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3925 metrics.ascent = LGLYPH_ASCENT (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3926 metrics.descent = LGLYPH_DESCENT (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3927 if (NILP (LGLYPH_ADJUSTMENT (g))) |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3928 { |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3929 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
|
3930 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
|
3931 need_composition = 1; |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3932 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3933 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3934 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3935 metrics.width = LGLYPH_WADJUST (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3936 metrics.lbearing += LGLYPH_XOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3937 metrics.rbearing += LGLYPH_XOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3938 metrics.ascent -= LGLYPH_YOFF (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3939 metrics.descent += LGLYPH_YOFF (g); |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3940 need_composition = 1; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3941 } |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
3942 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
|
3943 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3944 int x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3945 |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3946 g = LGSTRING_GLYPH (gstring, j); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3947 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
|
3948 break; |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3949 need_composition = 1; |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3950 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
|
3951 if (metrics.lbearing > x) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3952 metrics.lbearing = x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3953 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
|
3954 if (metrics.rbearing < x) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3955 metrics.rbearing = x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3956 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
|
3957 if (metrics.ascent < x) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3958 metrics.ascent = x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3959 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
|
3960 if (metrics.descent < x) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3961 metrics.descent = x; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3962 if (NILP (LGLYPH_ADJUSTMENT (g))) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3963 metrics.width += LGLYPH_WIDTH (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3964 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3965 metrics.width += LGLYPH_WADJUST (g); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3966 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3967 |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3968 if (need_composition) |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3969 { |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3970 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
|
3971 LGSTRING_SET_WIDTH (gstr, metrics.width); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3972 LGSTRING_SET_LBEARING (gstr, metrics.lbearing); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3973 LGSTRING_SET_RBEARING (gstr, metrics.rbearing); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3974 LGSTRING_SET_ASCENT (gstr, metrics.ascent); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3975 LGSTRING_SET_DESCENT (gstr, metrics.descent); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3976 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
|
3977 { |
|
0afaa00ae397
(Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents:
91273
diff
changeset
|
3978 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
|
3979 |
|
0afaa00ae397
(Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents:
91273
diff
changeset
|
3980 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
|
3981 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
|
3982 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
|
3983 } |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3984 from = make_number (start + this_from); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3985 to = make_number (start + this_to); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3986 if (NILP (string)) |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3987 Fcompose_region_internal (from, to, gstr, Qnil); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3988 else |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3989 Fcompose_string_internal (string, from, to, gstr, Qnil); |
|
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3990 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3991 else |
|
91267
0fa5916e5871
(Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents:
91261
diff
changeset
|
3992 i = j; |
| 90541 | 3993 } |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
3994 |
|
91192
bcad98389aeb
(Ffont_shape_text): Fix the return value.
Kenichi Handa <handa@m17n.org>
parents:
91174
diff
changeset
|
3995 return to; |
| 90400 | 3996 } |
| 3997 | |
|
95290
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
3998 #if 0 |
|
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
3999 |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4000 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
|
4001 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
|
4002 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
|
4003 (SCRIPT LANGSYS GSUB GPOS) |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4004 where |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4005 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
|
4006 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
|
4007 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
|
4008 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4009 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
|
4010 |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4011 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
|
4012 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
|
4013 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
|
4014 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
|
4015 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
|
4016 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4017 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
|
4018 the glyph-string GSTRING-IN. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4019 |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4020 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
|
4021 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
|
4022 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
|
4023 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4024 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
|
4025 the value is 0. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4026 |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4027 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
|
4028 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
|
4029 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4030 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
|
4031 glyph-string. */) |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4032 (otf_features, gstring_in, from, to, gstring_out, index) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4033 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
|
4034 { |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4035 Lisp_Object font_object = LGSTRING_FONT (gstring_in); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4036 Lisp_Object val; |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4037 struct font *font; |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4038 int len, num; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4039 |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4040 check_otf_features (otf_features); |
| 94926 | 4041 CHECK_FONT_OBJECT (font_object); |
| 4042 font = XFONT_OBJECT (font_object); | |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4043 if (! font->driver->otf_drive) |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4044 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
|
4045 SDATA (SYMBOL_NAME (font->driver->type))); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4046 CHECK_CONS (otf_features); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4047 CHECK_SYMBOL (XCAR (otf_features)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4048 val = XCDR (otf_features); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4049 CHECK_SYMBOL (XCAR (val)); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4050 val = XCDR (otf_features); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4051 if (! NILP (val)) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4052 CHECK_CONS (val); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4053 len = check_gstring (gstring_in); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4054 CHECK_VECTOR (gstring_out); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4055 CHECK_NATNUM (from); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4056 CHECK_NATNUM (to); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4057 CHECK_NATNUM (index); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4058 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4059 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
|
4060 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
|
4061 if (XINT (index) >= ASIZE (gstring_out)) |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4062 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
|
4063 num = font->driver->otf_drive (font, otf_features, |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4064 gstring_in, XINT (from), XINT (to), |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4065 gstring_out, XINT (index), 0); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4066 if (num < 0) |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4067 return Qnil; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4068 return make_number (num); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4069 } |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4070 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4071 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
|
4072 3, 3, 0, |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4073 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
|
4074 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
|
4075 in this format: |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4076 (SCRIPT LANGSYS FEATURE ...) |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4077 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
|
4078 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4079 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
|
4080 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
|
4081 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
|
4082 corresponding character. */) |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4083 (font_object, character, otf_features) |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4084 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
|
4085 { |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4086 struct font *font; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4087 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
|
4088 Lisp_Object alternates; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4089 int i, num; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4090 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4091 CHECK_FONT_GET_OBJECT (font_object, font); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4092 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
|
4093 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
|
4094 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
|
4095 CHECK_CHARACTER (character); |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4096 CHECK_CONS (otf_features); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4097 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4098 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
|
4099 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
|
4100 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
|
4101 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
|
4102 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
|
4103 gstring_out, 0, 1)) < 0) |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4104 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
|
4105 make_number (ASIZE (gstring_out) * 2)); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4106 alternates = Qnil; |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4107 for (i = 0; i < num; i++) |
|
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 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
|
4110 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
|
4111 unsigned code = LGLYPH_CODE (g); |
|
90556
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 alternates = Fcons (Fcons (make_number (code), |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4114 c > 0 ? make_number (c) : Qnil), |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4115 alternates); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4116 } |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4117 return Fnreverse (alternates); |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4118 } |
|
95290
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
4119 #endif /* 0 */ |
| 90400 | 4120 |
| 4121 #ifdef FONT_DEBUG | |
| 4122 | |
| 4123 DEFUN ("open-font", Fopen_font, Sopen_font, 1, 3, 0, | |
| 4124 doc: /* Open FONT-ENTITY. */) | |
| 4125 (font_entity, size, frame) | |
| 4126 Lisp_Object font_entity; | |
| 4127 Lisp_Object size; | |
| 4128 Lisp_Object frame; | |
| 4129 { | |
| 4130 int isize; | |
| 4131 | |
| 4132 CHECK_FONT_ENTITY (font_entity); | |
| 4133 if (NILP (frame)) | |
| 4134 frame = selected_frame; | |
| 4135 CHECK_LIVE_FRAME (frame); | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4136 |
| 94926 | 4137 if (NILP (size)) |
| 4138 isize = XINT (AREF (font_entity, FONT_SIZE_INDEX)); | |
| 4139 else | |
| 4140 { | |
| 4141 CHECK_NUMBER_OR_FLOAT (size); | |
| 4142 if (FLOATP (size)) | |
| 4143 isize = POINT_TO_PIXEL (- isize, XFRAME (frame)->resy); | |
| 4144 else | |
| 4145 isize = XINT (size); | |
| 4146 if (isize == 0) | |
| 4147 isize = 120; | |
| 4148 } | |
| 90400 | 4149 return font_open_entity (XFRAME (frame), font_entity, isize); |
| 4150 } | |
| 4151 | |
| 4152 DEFUN ("close-font", Fclose_font, Sclose_font, 1, 2, 0, | |
| 4153 doc: /* Close FONT-OBJECT. */) | |
| 4154 (font_object, frame) | |
| 4155 Lisp_Object font_object, frame; | |
| 4156 { | |
| 4157 CHECK_FONT_OBJECT (font_object); | |
| 4158 if (NILP (frame)) | |
| 4159 frame = selected_frame; | |
| 4160 CHECK_LIVE_FRAME (frame); | |
| 4161 font_close_object (XFRAME (frame), font_object); | |
| 4162 return Qnil; | |
| 4163 } | |
| 4164 | |
| 4165 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
|
4166 doc: /* Return information about FONT-OBJECT. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4167 The value is a vector: |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4168 [ 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
|
4169 CAPABILITY ] |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4170 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4171 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
|
4172 provide a name). |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4173 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4174 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
|
4175 doesn't provide a file name). |
|
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 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
|
4178 |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4179 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
|
4180 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4181 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
|
4182 pixels. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4183 |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4184 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
|
4185 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
|
4186 remaining elements describe the details of the font capability. |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4187 |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4188 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
|
4189 \(opentype GSUB GPOS) |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4190 where GSUB shows which "GSUB" features the font supports, and GPOS |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4191 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
|
4192 lists of the format: |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4193 \((SCRIPT (LANGSYS FEATURE ...) ...) ...) |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4194 |
|
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4195 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
|
4196 one. |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4197 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4198 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
|
4199 |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4200 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
|
4201 representing the default langsys. |
|
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4202 |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4203 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
|
4204 |
|
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4205 If the font is not OpenType font, CAPABILITY is nil. */) |
| 90400 | 4206 (font_object) |
| 4207 Lisp_Object font_object; | |
| 4208 { | |
| 4209 struct font *font; | |
| 4210 Lisp_Object val; | |
| 4211 | |
| 4212 CHECK_FONT_GET_OBJECT (font_object, font); | |
| 4213 | |
| 4214 val = Fmake_vector (make_number (9), Qnil); | |
| 94926 | 4215 ASET (val, 0, AREF (font_object, FONT_NAME_INDEX)); |
| 4216 ASET (val, 1, AREF (font_object, FONT_FILE_INDEX)); | |
| 90400 | 4217 ASET (val, 2, make_number (font->pixel_size)); |
| 94926 | 4218 ASET (val, 3, make_number (font->max_width)); |
| 90400 | 4219 ASET (val, 4, make_number (font->ascent)); |
| 4220 ASET (val, 5, make_number (font->descent)); | |
| 94926 | 4221 ASET (val, 6, make_number (font->space_width)); |
| 4222 ASET (val, 7, make_number (font->average_width)); | |
| 90400 | 4223 if (font->driver->otf_capability) |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4224 ASET (val, 8, Fcons (Qopentype, font->driver->otf_capability (font))); |
| 90400 | 4225 return val; |
| 4226 } | |
| 4227 | |
| 4228 DEFUN ("get-font-glyphs", Fget_font_glyphs, Sget_font_glyphs, 2, 2, 0, | |
| 4229 doc: /* Return a vector of glyphs of FONT-OBJECT for drawing STRING. | |
| 4230 Each element is a vector [GLYPH-CODE LBEARING RBEARING WIDTH ASCENT DESCENT]. */) | |
| 4231 (font_object, string) | |
| 4232 Lisp_Object font_object, string; | |
| 4233 { | |
| 4234 struct font *font; | |
| 4235 int i, len; | |
| 4236 Lisp_Object vec; | |
| 4237 | |
| 4238 CHECK_FONT_GET_OBJECT (font_object, font); | |
| 4239 CHECK_STRING (string); | |
| 4240 len = SCHARS (string); | |
| 4241 vec = Fmake_vector (make_number (len), Qnil); | |
| 4242 for (i = 0; i < len; i++) | |
| 4243 { | |
| 4244 Lisp_Object ch = Faref (string, make_number (i)); | |
| 4245 Lisp_Object val; | |
| 4246 int c = XINT (ch); | |
| 4247 unsigned code; | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
4248 EMACS_INT cod; |
| 90400 | 4249 struct font_metrics metrics; |
| 4250 | |
|
91871
436548f01688
(Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents:
91553
diff
changeset
|
4251 cod = code = font->driver->encode_char (font, c); |
| 90400 | 4252 if (code == FONT_INVALID_CODE) |
| 4253 continue; | |
| 4254 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
|
4255 if (cod <= MOST_POSITIVE_FIXNUM) |
| 90400 | 4256 ASET (val, 0, make_number (code)); |
| 4257 else | |
| 4258 ASET (val, 0, Fcons (make_number (code >> 16), | |
| 4259 make_number (code & 0xFFFF))); | |
|
92233
3642a8778bbf
(Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents:
92183
diff
changeset
|
4260 font->driver->text_extents (font, &code, 1, &metrics); |
| 90400 | 4261 ASET (val, 1, make_number (metrics.lbearing)); |
| 4262 ASET (val, 2, make_number (metrics.rbearing)); | |
| 4263 ASET (val, 3, make_number (metrics.width)); | |
| 4264 ASET (val, 4, make_number (metrics.ascent)); | |
| 4265 ASET (val, 5, make_number (metrics.descent)); | |
| 4266 ASET (vec, i, val); | |
| 4267 } | |
| 4268 return vec; | |
| 4269 } | |
| 4270 | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4271 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
|
4272 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
|
4273 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
|
4274 (spec, font) |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4275 Lisp_Object spec, font; |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4276 { |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4277 CHECK_FONT_SPEC (spec); |
| 94926 | 4278 CHECK_FONT (font); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4279 |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4280 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
|
4281 } |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4282 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4283 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
|
4284 doc: /* Return a font-object for displaying a character at POSITION. |
| 90541 | 4285 Optional second arg WINDOW, if non-nil, is a window displaying |
| 4286 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
|
4287 (position, window, string) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4288 Lisp_Object position, window, string; |
| 90541 | 4289 { |
| 4290 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
|
4291 EMACS_INT pos; |
| 90541 | 4292 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4293 if (NILP (string)) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4294 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4295 CHECK_NUMBER_COERCE_MARKER (position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4296 pos = XINT (position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4297 if (pos < BEGV || pos >= ZV) |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4298 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
|
4299 } |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4300 else |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4301 { |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4302 CHECK_NUMBER (position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4303 CHECK_STRING (string); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4304 pos = XINT (position); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4305 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
|
4306 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
|
4307 } |
| 90541 | 4308 if (NILP (window)) |
| 4309 window = selected_window; | |
| 4310 CHECK_LIVE_WINDOW (window); | |
|
91273
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
4311 w = XWINDOW (window); |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
4312 |
|
f19e3a3100e2
(Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents:
91267
diff
changeset
|
4313 return font_at (-1, pos, NULL, w, string); |
| 90541 | 4314 } |
| 4315 | |
| 90400 | 4316 #if 0 |
| 4317 DEFUN ("draw-string", Fdraw_string, Sdraw_string, 2, 2, 0, | |
| 4318 doc: /* Draw STRING by FONT-OBJECT on the top left corner of the current frame. | |
| 4319 The value is a number of glyphs drawn. | |
| 4320 Type C-l to recover what previously shown. */) | |
| 4321 (font_object, string) | |
| 4322 Lisp_Object font_object, string; | |
| 4323 { | |
| 4324 Lisp_Object frame = selected_frame; | |
| 4325 FRAME_PTR f = XFRAME (frame); | |
| 4326 struct font *font; | |
| 4327 struct face *face; | |
| 4328 int i, len, width; | |
| 4329 unsigned *code; | |
| 4330 | |
| 4331 CHECK_FONT_GET_OBJECT (font_object, font); | |
| 4332 CHECK_STRING (string); | |
| 4333 len = SCHARS (string); | |
| 4334 code = alloca (sizeof (unsigned) * len); | |
| 4335 for (i = 0; i < len; i++) | |
| 4336 { | |
| 4337 Lisp_Object ch = Faref (string, make_number (i)); | |
| 4338 Lisp_Object val; | |
| 4339 int c = XINT (ch); | |
| 4340 | |
| 4341 code[i] = font->driver->encode_char (font, c); | |
| 4342 if (code[i] == FONT_INVALID_CODE) | |
| 4343 break; | |
| 4344 } | |
| 4345 face = FACE_FROM_ID (f, DEFAULT_FACE_ID); | |
| 4346 face->fontp = font; | |
| 4347 if (font->driver->prepare_face) | |
| 4348 font->driver->prepare_face (f, face); | |
| 4349 width = font->driver->text_extents (font, code, i, NULL); | |
| 4350 len = font->driver->draw_text (f, face, 0, font->ascent, code, i, width); | |
| 4351 if (font->driver->done_face) | |
| 4352 font->driver->done_face (f, face); | |
| 4353 face->fontp = NULL; | |
| 4354 return make_number (len); | |
| 4355 } | |
| 4356 #endif | |
| 4357 | |
| 4358 #endif /* FONT_DEBUG */ | |
| 4359 | |
|
95421
3350c9ac1f37
(Ffont_info): Define only if HAVE_WINDOW_SYSTEM is
Kenichi Handa <handa@m17n.org>
parents:
95403
diff
changeset
|
4360 #ifdef HAVE_WINDOW_SYSTEM |
|
3350c9ac1f37
(Ffont_info): Define only if HAVE_WINDOW_SYSTEM is
Kenichi Handa <handa@m17n.org>
parents:
95403
diff
changeset
|
4361 |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4362 DEFUN ("font-info", Ffont_info, Sfont_info, 1, 2, 0, |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4363 doc: /* Return information about a font named NAME on frame FRAME. |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4364 If FRAME is omitted or nil, use the selected frame. |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4365 The returned value is a vector of OPENED-NAME, FULL-NAME, CHARSET, SIZE, |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4366 HEIGHT, BASELINE-OFFSET, RELATIVE-COMPOSE, and DEFAULT-ASCENT, |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4367 where |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4368 OPENED-NAME is the name used for opening the font, |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4369 FULL-NAME is the full name of the font, |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4370 SIZE is the maximum bound width of the font, |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4371 HEIGHT is the height of the font, |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4372 BASELINE-OFFSET is the upward offset pixels from ASCII baseline, |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4373 RELATIVE-COMPOSE and DEFAULT-ASCENT are the numbers controlling |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4374 how to compose characters. |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4375 If the named font is not yet loaded, return nil. */) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4376 (name, frame) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4377 Lisp_Object name, frame; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4378 { |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4379 FRAME_PTR f; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4380 struct font *font; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4381 Lisp_Object info; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4382 Lisp_Object font_object; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4383 |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4384 (*check_window_system_func) (); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4385 |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4386 if (! FONTP (name)) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4387 CHECK_STRING (name); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4388 if (NILP (frame)) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4389 frame = selected_frame; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4390 CHECK_LIVE_FRAME (frame); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4391 f = XFRAME (frame); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4392 |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4393 if (STRINGP (name)) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4394 { |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4395 int fontset = fs_query_fontset (name, 0); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4396 |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4397 if (fontset >= 0) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4398 name = fontset_ascii (fontset); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4399 font_object = font_open_by_name (f, (char *) SDATA (name)); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4400 } |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4401 else if (FONT_OBJECT_P (name)) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4402 font_object = name; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4403 else if (FONT_ENTITY_P (name)) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4404 font_object = font_open_entity (f, name, 0); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4405 else |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4406 { |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4407 struct face *face = FACE_FROM_ID (f, DEFAULT_FACE_ID); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4408 Lisp_Object entity = font_matching_entity (f, face->lface, name); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4409 |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4410 font_object = ! NILP (entity) ? font_open_entity (f, entity, 0) : Qnil; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4411 } |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4412 if (NILP (font_object)) |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4413 return Qnil; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4414 font = XFONT_OBJECT (font_object); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4415 |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4416 info = Fmake_vector (make_number (7), Qnil); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4417 XVECTOR (info)->contents[0] = AREF (font_object, FONT_NAME_INDEX); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4418 XVECTOR (info)->contents[1] = AREF (font_object, FONT_NAME_INDEX); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4419 XVECTOR (info)->contents[2] = make_number (font->pixel_size); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4420 XVECTOR (info)->contents[3] = make_number (font->height); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4421 XVECTOR (info)->contents[4] = make_number (font->baseline_offset); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4422 XVECTOR (info)->contents[5] = make_number (font->relative_compose); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4423 XVECTOR (info)->contents[6] = make_number (font->default_ascent); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4424 |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4425 #if 0 |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4426 /* As font_object is still in FONT_OBJLIST of the entity, we can't |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4427 close it now. Perhaps, we should manage font-objects |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4428 by `reference-count'. */ |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4429 font_close_object (f, font_object); |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4430 #endif |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4431 return info; |
|
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4432 } |
|
95421
3350c9ac1f37
(Ffont_info): Define only if HAVE_WINDOW_SYSTEM is
Kenichi Handa <handa@m17n.org>
parents:
95403
diff
changeset
|
4433 #endif |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4434 |
| 90400 | 4435 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4436 #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
|
4437 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
|
4438 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4439 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
|
4440 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
|
4441 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
|
4442 int nelement; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4443 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4444 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
|
4445 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
|
4446 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4447 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
|
4448 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
|
4449 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4450 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
|
4451 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
|
4452 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
|
4453 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
|
4454 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
|
4455 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
|
4456 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4457 return table; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4458 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4459 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4460 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
|
4461 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
|
4462 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4463 void |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4464 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
|
4465 char *action; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4466 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
|
4467 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4468 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
|
4469 int i; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4470 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4471 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
|
4472 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4473 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
|
4474 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
|
4475 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4476 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
|
4477 return; |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4478 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
|
4479 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
|
4480 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
|
4481 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
|
4482 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
|
4483 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4484 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
|
4485 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
|
4486 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4487 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
|
4488 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
|
4489 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
|
4490 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
|
4491 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4492 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4493 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
|
4494 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4495 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
|
4496 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
|
4497 { |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4498 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
|
4499 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
|
4500 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
|
4501 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
|
4502 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4503 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4504 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
|
4505 } |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4506 |
| 90400 | 4507 extern void syms_of_ftfont P_ (()); |
| 4508 extern void syms_of_xfont P_ (()); | |
| 4509 extern void syms_of_xftfont P_ (()); | |
| 4510 extern void syms_of_ftxfont P_ (()); | |
| 4511 extern void syms_of_bdffont P_ (()); | |
| 4512 extern void syms_of_w32font P_ (()); | |
| 4513 extern void syms_of_atmfont P_ (()); | |
| 4514 | |
| 4515 void | |
| 4516 syms_of_font () | |
| 4517 { | |
| 4518 sort_shift_bits[FONT_SLANT_INDEX] = 0; | |
| 4519 sort_shift_bits[FONT_WEIGHT_INDEX] = 7; | |
| 4520 sort_shift_bits[FONT_SIZE_INDEX] = 14; | |
| 4521 sort_shift_bits[FONT_WIDTH_INDEX] = 21; | |
| 4522 sort_shift_bits[FONT_ADSTYLE_INDEX] = 28; | |
| 4523 sort_shift_bits[FONT_FOUNDRY_INDEX] = 29; | |
| 4524 sort_shift_bits[FONT_FAMILY_INDEX] = 30; | |
| 94926 | 4525 /* Note that sort_shift_bits[FONT_SORT_TYPE] and |
| 4526 sort_shift_bits[FONT_SORT_REGISTRY] are never used. */ | |
| 90400 | 4527 |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4528 staticpro (&font_charset_alist); |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4529 font_charset_alist = Qnil; |
|
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4530 |
| 94926 | 4531 DEFSYM (Qfont_spec, "font-spec"); |
| 4532 DEFSYM (Qfont_entity, "font-entity"); | |
| 4533 DEFSYM (Qfont_object, "font-object"); | |
| 4534 | |
|
90677
424dec0c7b5d
(Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90640
diff
changeset
|
4535 DEFSYM (Qopentype, "opentype"); |
| 90400 | 4536 |
| 95699 | 4537 DEFSYM (Qascii_0, "ascii-0"); |
|
90439
fb253905e9c3
* font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents:
90427
diff
changeset
|
4538 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
|
4539 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
|
4540 DEFSYM (Qunicode_bmp, "unicode-bmp"); |
|
90622
bb9362e3a03b
(Qunicode_sip): New variable.
Kenichi Handa <handa@m17n.org>
parents:
90590
diff
changeset
|
4541 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
|
4542 |
| 90400 | 4543 DEFSYM (QCotf, ":otf"); |
| 94926 | 4544 DEFSYM (QClang, ":lang"); |
| 90400 | 4545 DEFSYM (QCscript, ":script"); |
|
91125
6c9a19ff6c55
(Qfontp): Remove unused symbol.
Jason Rumney <jasonr@gnu.org>
parents:
91112
diff
changeset
|
4546 DEFSYM (QCantialias, ":antialias"); |
| 90400 | 4547 |
| 4548 DEFSYM (QCfoundry, ":foundry"); | |
| 4549 DEFSYM (QCadstyle, ":adstyle"); | |
| 4550 DEFSYM (QCregistry, ":registry"); | |
|
90481
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
4551 DEFSYM (QCspacing, ":spacing"); |
|
93690200f520
(POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents:
90476
diff
changeset
|
4552 DEFSYM (QCdpi, ":dpi"); |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4553 DEFSYM (QCscalable, ":scalable"); |
| 94926 | 4554 DEFSYM (QCavgwidth, ":avgwidth"); |
| 4555 DEFSYM (QCfont_entity, ":font-entity"); | |
| 4556 DEFSYM (QCfc_unknown_spec, ":fc-unknown-spec"); | |
| 90400 | 4557 |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4558 DEFSYM (Qc, "c"); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4559 DEFSYM (Qm, "m"); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4560 DEFSYM (Qp, "p"); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4561 DEFSYM (Qd, "d"); |
|
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4562 |
| 90400 | 4563 staticpro (&null_vector); |
| 4564 null_vector = Fmake_vector (make_number (0), Qnil); | |
| 4565 | |
| 4566 staticpro (&scratch_font_spec); | |
| 4567 scratch_font_spec = Ffont_spec (0, NULL); | |
| 4568 staticpro (&scratch_font_prefer); | |
| 4569 scratch_font_prefer = Ffont_spec (0, NULL); | |
| 4570 | |
|
95290
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
4571 #if 0 |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4572 #ifdef HAVE_LIBOTF |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4573 staticpro (&otf_list); |
|
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4574 otf_list = Qnil; |
|
95290
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
4575 #endif /* HAVE_LIBOTF */ |
|
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
4576 #endif /* 0 */ |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4577 |
| 90400 | 4578 defsubr (&Sfontp); |
| 4579 defsubr (&Sfont_spec); | |
| 4580 defsubr (&Sfont_get); | |
| 4581 defsubr (&Sfont_put); | |
| 4582 defsubr (&Slist_fonts); | |
| 94926 | 4583 defsubr (&Sfont_family_list); |
| 90400 | 4584 defsubr (&Sfind_font); |
| 4585 defsubr (&Sfont_xlfd_name); | |
| 4586 defsubr (&Sclear_font_cache); | |
| 4587 defsubr (&Sfont_make_gstring); | |
| 4588 defsubr (&Sfont_fill_gstring); | |
|
91135
49dbc35e3f99
* font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents:
91125
diff
changeset
|
4589 defsubr (&Sfont_shape_text); |
|
95290
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
4590 #if 0 |
|
90817
d2c230a67741
(struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents:
90811
diff
changeset
|
4591 defsubr (&Sfont_drive_otf); |
|
90556
e56a86aa94cc
(font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents:
90549
diff
changeset
|
4592 defsubr (&Sfont_otf_alternates); |
|
95290
e3e5f8759ca5
(LGSTRING_HEADER_SIZE, LGSTRING_GLYPH_SIZE)
Kenichi Handa <handa@m17n.org>
parents:
95225
diff
changeset
|
4593 #endif /* 0 */ |
| 90400 | 4594 |
| 4595 #ifdef FONT_DEBUG | |
| 4596 defsubr (&Sopen_font); | |
| 4597 defsubr (&Sclose_font); | |
| 4598 defsubr (&Squery_font); | |
| 4599 defsubr (&Sget_font_glyphs); | |
|
90503
8e3ffc0a529f
(QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents:
90490
diff
changeset
|
4600 defsubr (&Sfont_match_p); |
| 90541 | 4601 defsubr (&Sfont_at); |
| 90400 | 4602 #if 0 |
| 4603 defsubr (&Sdraw_string); | |
| 4604 #endif | |
| 4605 #endif /* FONT_DEBUG */ | |
|
95421
3350c9ac1f37
(Ffont_info): Define only if HAVE_WINDOW_SYSTEM is
Kenichi Handa <handa@m17n.org>
parents:
95403
diff
changeset
|
4606 #ifdef HAVE_WINDOW_SYSTEM |
|
95403
26df7325a6ff
(font_style_to_value, font_score): Delete casting of the
Kenichi Handa <handa@m17n.org>
parents:
95359
diff
changeset
|
4607 defsubr (&Sfont_info); |
|
95421
3350c9ac1f37
(Ffont_info): Define only if HAVE_WINDOW_SYSTEM is
Kenichi Handa <handa@m17n.org>
parents:
95403
diff
changeset
|
4608 #endif |
| 90400 | 4609 |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4610 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
|
4611 doc: /* |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4612 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
|
4613 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
|
4614 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
|
4615 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
|
4616 |
|
95142
f64ddc606a66
(syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents:
95126
diff
changeset
|
4617 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
|
4618 \(REGEXP . ENCODING). |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4619 |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4620 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
|
4621 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
|
4622 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
|
4623 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
|
4624 |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4625 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
|
4626 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
|
4627 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
|
4628 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
|
4629 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
|
4630 Vfont_encoding_alist = Qnil; |
|
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4631 |
|
95176
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4632 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
|
4633 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
|
4634 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
|
4635 [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
|
4636 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
|
4637 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
|
4638 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4639 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
|
4640 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
|
4641 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
|
4642 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
|
4643 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4644 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
|
4645 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
|
4646 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
|
4647 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
|
4648 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4649 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
|
4650 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
|
4651 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
|
4652 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
|
4653 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
|
4654 |
|
686d116f748d
Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents:
95142
diff
changeset
|
4655 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
|
4656 *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
|
4657 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
|
4658 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
|
4659 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
|
4660 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
|
4661 |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4662 #ifdef HAVE_WINDOW_SYSTEM |
| 90400 | 4663 #ifdef HAVE_FREETYPE |
| 94926 | 4664 syms_of_ftfont (); |
| 90400 | 4665 #ifdef HAVE_X_WINDOWS |
| 94926 | 4666 syms_of_xfont (); |
| 4667 syms_of_ftxfont (); | |
| 90400 | 4668 #ifdef HAVE_XFT |
| 94926 | 4669 syms_of_xftfont (); |
| 90400 | 4670 #endif /* HAVE_XFT */ |
| 4671 #endif /* HAVE_X_WINDOWS */ | |
| 4672 #else /* not HAVE_FREETYPE */ | |
| 4673 #ifdef HAVE_X_WINDOWS | |
| 94926 | 4674 syms_of_xfont (); |
| 90400 | 4675 #endif /* HAVE_X_WINDOWS */ |
| 4676 #endif /* not HAVE_FREETYPE */ | |
| 4677 #ifdef HAVE_BDFFONT | |
| 94926 | 4678 syms_of_bdffont (); |
| 90400 | 4679 #endif /* HAVE_BDFFONT */ |
| 4680 #ifdef WINDOWSNT | |
| 94926 | 4681 syms_of_w32font (); |
| 90400 | 4682 #endif /* WINDOWSNT */ |
| 4683 #ifdef MAC_OS | |
| 94926 | 4684 syms_of_atmfont (); |
| 90400 | 4685 #endif /* MAC_OS */ |
|
95126
b7cee987e982
(Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents:
95104
diff
changeset
|
4686 #endif /* HAVE_WINDOW_SYSTEM */ |
| 90400 | 4687 } |
| 90427 | 4688 |
| 4689 /* arch-tag: 74c9475d-5976-4c93-a327-942ae3072846 | |
| 4690 (do not change this comment) */ |
