annotate src/xfont.c @ 107331:973da8561c25

NEWS: Auto composition mode is still a minor mode.
author Chong Yidong <cyd@stupidchicken.com>
date Wed, 03 Mar 2010 11:14:16 -0500
parents 1d1d5d9bd884
children 2bc9a0c04c87 b3326b910a0c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1 /* xfont.c -- X core font driver.
106815
1d1d5d9bd884 Add 2010 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 106085
diff changeset
2 Copyright (C) 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
1d1d5d9bd884 Add 2010 to copyright years.
Glenn Morris <rgm@gnu.org>
parents: 106085
diff changeset
3 Copyright (C) 2006, 2007, 2008, 2009, 2010
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4 National Institute of Advanced Industrial Science and Technology (AIST)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
5 Registration Number H13PRO009
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
6
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
7 This file is part of GNU Emacs.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
8
94963
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94940
diff changeset
9 GNU Emacs is free software: you can redistribute it and/or modify
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
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: 94940
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: 94940
diff changeset
12 (at your option) any later version.
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
13
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
14 GNU Emacs is distributed in the hope that it will be useful,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
17 GNU General Public License for more details.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
18
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
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: 94940
diff changeset
20 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
21
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
22 #include <config.h>
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
23 #include <stdio.h>
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
24 #include <stdlib.h>
105669
68dd71358159 * alloc.c: Do not define struct catchtag.
Dan Nicolaescu <dann@ics.uci.edu>
parents: 104090
diff changeset
25 #include <setjmp.h>
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
26 #include <X11/Xlib.h>
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
27
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
28 #include "lisp.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
29 #include "dispextern.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
30 #include "xterm.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
31 #include "frame.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
32 #include "blockinput.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
33 #include "character.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
34 #include "charset.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
35 #include "fontset.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
36 #include "font.h"
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
37 #include "ccl.h"
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
38
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
39
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
40 /* X core font driver. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
41
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
42 struct xfont_info
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
43 {
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
44 struct font font;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
45 Display *display;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
46 XFontStruct *xfont;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
47 };
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
48
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
49 /* Prototypes of support functions. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
50 extern void x_clear_errors P_ ((Display *));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
51
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
52 static XCharStruct *xfont_get_pcm P_ ((XFontStruct *, XChar2b *));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
53
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
54 /* Get metrics of character CHAR2B in XFONT. Value is null if CHAR2B
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
55 is not contained in the font. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
56
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
57 static XCharStruct *
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
58 xfont_get_pcm (xfont, char2b)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
59 XFontStruct *xfont;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
60 XChar2b *char2b;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
61 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
62 /* The result metric information. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
63 XCharStruct *pcm = NULL;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
64
95180
1520d3ef2a48 (xfont_get_pcm): Change xassert to font_assert.
Kenichi Handa <handa@m17n.org>
parents: 94963
diff changeset
65 font_assert (xfont && char2b);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
66
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
67 if (xfont->per_char != NULL)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
68 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
69 if (xfont->min_byte1 == 0 && xfont->max_byte1 == 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
70 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
71 /* min_char_or_byte2 specifies the linear character index
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
72 corresponding to the first element of the per_char array,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
73 max_char_or_byte2 is the index of the last character. A
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
74 character with non-zero CHAR2B->byte1 is not in the font.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
75 A character with byte2 less than min_char_or_byte2 or
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
76 greater max_char_or_byte2 is not in the font. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
77 if (char2b->byte1 == 0
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
78 && char2b->byte2 >= xfont->min_char_or_byte2
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
79 && char2b->byte2 <= xfont->max_char_or_byte2)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
80 pcm = xfont->per_char + char2b->byte2 - xfont->min_char_or_byte2;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
81 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
82 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
83 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
84 /* If either min_byte1 or max_byte1 are nonzero, both
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
85 min_char_or_byte2 and max_char_or_byte2 are less than
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
86 256, and the 2-byte character index values corresponding
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
87 to the per_char array element N (counting from 0) are:
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
88
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
89 byte1 = N/D + min_byte1
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
90 byte2 = N\D + min_char_or_byte2
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
91
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
92 where:
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
93
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
94 D = max_char_or_byte2 - min_char_or_byte2 + 1
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
95 / = integer division
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
96 \ = integer modulus */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
97 if (char2b->byte1 >= xfont->min_byte1
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
98 && char2b->byte1 <= xfont->max_byte1
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
99 && char2b->byte2 >= xfont->min_char_or_byte2
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
100 && char2b->byte2 <= xfont->max_char_or_byte2)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
101 pcm = (xfont->per_char
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
102 + ((xfont->max_char_or_byte2 - xfont->min_char_or_byte2 + 1)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
103 * (char2b->byte1 - xfont->min_byte1))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
104 + (char2b->byte2 - xfont->min_char_or_byte2));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
105 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
106 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
107 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
108 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
109 /* If the per_char pointer is null, all glyphs between the first
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
110 and last character indexes inclusive have the same
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
111 information, as given by both min_bounds and max_bounds. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
112 if (char2b->byte2 >= xfont->min_char_or_byte2
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
113 && char2b->byte2 <= xfont->max_char_or_byte2)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
114 pcm = &xfont->max_bounds;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
115 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
116
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
117 return ((pcm == NULL
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
118 || (pcm->width == 0 && (pcm->rbearing - pcm->lbearing) == 0))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
119 ? NULL : pcm);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
120 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
121
91245
26541bdcecd0 (xfont_get_cache): Adjust the argument type.
Kenichi Handa <handa@m17n.org>
parents: 91177
diff changeset
122 static Lisp_Object xfont_get_cache P_ ((FRAME_PTR));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
123 static Lisp_Object xfont_list P_ ((Lisp_Object, Lisp_Object));
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
124 static Lisp_Object xfont_match P_ ((Lisp_Object, Lisp_Object));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
125 static Lisp_Object xfont_list_family P_ ((Lisp_Object));
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
126 static Lisp_Object xfont_open P_ ((FRAME_PTR, Lisp_Object, int));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
127 static void xfont_close P_ ((FRAME_PTR, struct font *));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
128 static int xfont_prepare_face P_ ((FRAME_PTR, struct face *));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
129 static int xfont_has_char P_ ((Lisp_Object, int));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
130 static unsigned xfont_encode_char P_ ((struct font *, int));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
131 static int xfont_text_extents P_ ((struct font *, unsigned *, int,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
132 struct font_metrics *));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
133 static int xfont_draw P_ ((struct glyph_string *, int, int, int, int, int));
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
134 static int xfont_check P_ ((FRAME_PTR, struct font *));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
135
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
136 struct font_driver xfont_driver =
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
137 {
90698
a31984e21969 (xfont_driver): Initialize ftfont_driver.type by 0.
Kenichi Handa <handa@m17n.org>
parents: 90679
diff changeset
138 0, /* Qx */
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
139 0, /* case insensitive */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
140 xfont_get_cache,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
141 xfont_list,
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
142 xfont_match,
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
143 xfont_list_family,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
144 NULL,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
145 xfont_open,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
146 xfont_close,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
147 xfont_prepare_face,
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
148 NULL,
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
149 xfont_has_char,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
150 xfont_encode_char,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
151 xfont_text_extents,
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
152 xfont_draw,
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
153 NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
106085
cd4cbab8bb21 Handle system default font and changing font parameters.
Jan Djärv <jan.h.d@swipnet.se>
parents: 105669
diff changeset
154 xfont_check,
cd4cbab8bb21 Handle system default font and changing font parameters.
Jan Djärv <jan.h.d@swipnet.se>
parents: 105669
diff changeset
155 NULL, /* get_variation_glyphs */
cd4cbab8bb21 Handle system default font and changing font parameters.
Jan Djärv <jan.h.d@swipnet.se>
parents: 105669
diff changeset
156 NULL, /* filter_properties */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
157 };
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
158
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
159 extern Lisp_Object QCname;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
160
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
161 static Lisp_Object
91245
26541bdcecd0 (xfont_get_cache): Adjust the argument type.
Kenichi Handa <handa@m17n.org>
parents: 91177
diff changeset
162 xfont_get_cache (f)
26541bdcecd0 (xfont_get_cache): Adjust the argument type.
Kenichi Handa <handa@m17n.org>
parents: 91177
diff changeset
163 FRAME_PTR f;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
164 {
91245
26541bdcecd0 (xfont_get_cache): Adjust the argument type.
Kenichi Handa <handa@m17n.org>
parents: 91177
diff changeset
165 Display_Info *dpyinfo = FRAME_X_DISPLAY_INFO (f);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
166
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
167 return (dpyinfo->name_list_element);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
168 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
169
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
170 extern Lisp_Object Vface_alternative_font_registry_alist;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
171
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
172 static int
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
173 compare_font_names (const void *name1, const void *name2)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
174 {
95568
4fec6e274c04 (xfont_list): Don't set registry to iso8859-1 even if it
Kenichi Handa <handa@m17n.org>
parents: 95503
diff changeset
175 return xstrcasecmp (*(const unsigned char **) name1,
4fec6e274c04 (xfont_list): Don't set registry to iso8859-1 even if it
Kenichi Handa <handa@m17n.org>
parents: 95503
diff changeset
176 *(const unsigned char **) name2);
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
177 }
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
178
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
179 /* Decode XLFD as iso-8859-1 into OUTPUT, and return the byte length
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
180 of the decoding result. LEN is the byte length of XLFD, or -1 if
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
181 XLFD is NULL terminated. The caller must assure that OUTPUT is at
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
182 least twice (plus 1) as large as XLFD. */
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
183
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
184 static int
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
185 xfont_decode_coding_xlfd (char *xlfd, int len, char *output)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
186 {
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
187 char *p0 = xlfd, *p1 = output;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
188 int c;
101943
97c9e9322753 Remove spurious semicolons.
Juanma Barranquero <lekktu@gmail.com>
parents: 100951
diff changeset
189
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
190 while (*p0)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
191 {
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
192 c = *(unsigned char *) p0++;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
193 p1 += CHAR_STRING (c, p1);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
194 if (--len == 0)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
195 break;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
196 }
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
197 *p1 = 0;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
198 return (p1 - output);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
199 }
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
200
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
201 /* Encode XLFD from UTF-8 to iso-8859-1 destructively, and return the
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
202 resulting byte length. If XLFD contains unencodable character,
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
203 return -1. */
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
204
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
205 static int
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
206 xfont_encode_coding_xlfd (char *xlfd)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
207 {
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
208 const unsigned char *p0 = (unsigned char *) xlfd;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
209 unsigned char *p1 = (unsigned char *) xlfd;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
210 int len = 0;
101943
97c9e9322753 Remove spurious semicolons.
Juanma Barranquero <lekktu@gmail.com>
parents: 100951
diff changeset
211
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
212 while (*p0)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
213 {
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
214 int c = STRING_CHAR_ADVANCE (p0);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
215
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
216 if (c >= 0x100)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
217 return -1;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
218 *p1++ = c;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
219 len++;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
220 }
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
221 *p1 = 0;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
222 return len;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
223 }
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
224
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
225 /* Check if CHARS (cons or vector) is supported by XFONT whose
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
226 encoding charset is ENCODING (XFONT is NULL) or by a font whose
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
227 registry corresponds to ENCODING and REPERTORY.
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
228 Return 1 if supported, return 0 otherwise. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
229
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
230 static int
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
231 xfont_chars_supported (Lisp_Object chars, XFontStruct *xfont,
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
232 struct charset *encoding, struct charset *repertory)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
233 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
234 struct charset *charset = repertory ? repertory : encoding;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
235
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
236 if (CONSP (chars))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
237 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
238 for (; CONSP (chars); chars = XCDR (chars))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
239 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
240 int c = XINT (XCAR (chars));
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
241 unsigned code = ENCODE_CHAR (charset, c);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
242 XChar2b char2b;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
243
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
244 if (code == CHARSET_INVALID_CODE (charset))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
245 break;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
246 if (! xfont)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
247 continue;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
248 if (code >= 0x10000)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
249 break;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
250 char2b.byte1 = code >> 8;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
251 char2b.byte2 = code & 0xFF;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
252 if (! xfont_get_pcm (xfont, &char2b))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
253 break;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
254 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
255 return (NILP (chars));
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
256 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
257 else if (VECTORP (chars))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
258 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
259 int i;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
260
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
261 for (i = ASIZE (chars) - 1; i >= 0; i--)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
262 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
263 int c = XINT (AREF (chars, i));
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
264 unsigned code = ENCODE_CHAR (charset, c);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
265 XChar2b char2b;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
266
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
267 if (code == CHARSET_INVALID_CODE (charset))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
268 continue;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
269 if (! xfont)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
270 break;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
271 if (code >= 0x10000)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
272 continue;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
273 char2b.byte1 = code >> 8;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
274 char2b.byte2 = code & 0xFF;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
275 if (xfont_get_pcm (xfont, &char2b))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
276 break;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
277 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
278 return (i >= 0);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
279 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
280 return 0;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
281 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
282
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
283 /* A hash table recoding which font supports which scritps. Each key
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
284 is a vector of characteristic font propertis FOUNDRY to WIDTH and
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
285 ADDSTYLE, and each value is a list of script symbols.
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
286
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
287 We assume that fonts that have the same value in the above
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
288 properties supports the same set of characters on all displays. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
289
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
290 static Lisp_Object xfont_scripts_cache;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
291
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
292 /* Re-usable vector to store characteristic font properites. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
293 static Lisp_Object xfont_scratch_props;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
294
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
295 extern Lisp_Object Qlatin;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
296
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
297 /* Return a list of scripts supported by the font of FONTNAME whose
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
298 characteristic properties are in PROPS and whose encoding charset
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
299 is ENCODING. A caller must call BLOCK_INPUT in advance. */
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
300
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
301 static Lisp_Object
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
302 xfont_supported_scripts (Display *display, char *fontname, Lisp_Object props,
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
303 struct charset *encoding)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
304 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
305 Lisp_Object scripts;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
306
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
307 /* Two special cases to avoid opening rather big fonts. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
308 if (EQ (AREF (props, 2), Qja))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
309 return Fcons (intern ("kana"), Fcons (intern ("han"), Qnil));
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
310 if (EQ (AREF (props, 2), Qko))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
311 return Fcons (intern ("hangul"), Qnil);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
312 scripts = Fgethash (props, xfont_scripts_cache, Qt);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
313 if (EQ (scripts, Qt))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
314 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
315 XFontStruct *xfont;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
316 Lisp_Object val;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
317
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
318 scripts = Qnil;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
319 xfont = XLoadQueryFont (display, fontname);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
320 if (xfont)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
321 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
322 if (xfont->per_char)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
323 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
324 for (val = Vscript_representative_chars; CONSP (val);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
325 val = XCDR (val))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
326 if (CONSP (XCAR (val)) && SYMBOLP (XCAR (XCAR (val))))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
327 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
328 Lisp_Object script = XCAR (XCAR (val));
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
329 Lisp_Object chars = XCDR (XCAR (val));
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
330
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
331 if (xfont_chars_supported (chars, xfont, encoding, NULL))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
332 scripts = Fcons (script, scripts);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
333 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
334 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
335 XFreeFont (display, xfont);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
336 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
337 if (EQ (AREF (props, 3), Qiso10646_1)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
338 && NILP (Fmemq (Qlatin, scripts)))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
339 scripts = Fcons (Qlatin, scripts);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
340 Fputhash (Fcopy_sequence (props), scripts, xfont_scripts_cache);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
341 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
342 return scripts;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
343 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
344
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
345 extern Lisp_Object Vscalable_fonts_allowed;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
346
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
347 static Lisp_Object
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
348 xfont_list_pattern (Display *display, char *pattern,
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
349 Lisp_Object registry, Lisp_Object script)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
350 {
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
351 Lisp_Object list = Qnil;
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
352 Lisp_Object chars = Qnil;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
353 struct charset *encoding, *repertory = NULL;
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
354 int i, limit, num_fonts;
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
355 char **names;
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
356 /* Large enough to decode the longest XLFD (255 bytes). */
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
357 char buf[512];
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
358
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
359 if (! NILP (registry)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
360 && font_registry_charsets (registry, &encoding, &repertory) < 0)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
361 /* Unknown REGISTRY, not supported. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
362 return Qnil;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
363 if (! NILP (script))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
364 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
365 chars = assq_no_quit (script, Vscript_representative_chars);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
366 if (NILP (chars))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
367 /* We can't tell whether or not a font supports SCRIPT. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
368 return Qnil;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
369 chars = XCDR (chars);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
370 if (repertory)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
371 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
372 if (! xfont_chars_supported (chars, NULL, encoding, repertory))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
373 return Qnil;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
374 script = Qnil;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
375 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
376 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
377
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
378 BLOCK_INPUT;
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
379 x_catch_errors (display);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
380
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
381 for (limit = 512; ; limit *= 2)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
382 {
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
383 names = XListFonts (display, pattern, limit, &num_fonts);
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
384 if (x_had_errors_p (display))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
385 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
386 /* This error is perhaps due to insufficient memory on X
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
387 server. Let's just ignore it. */
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
388 x_clear_errors (display);
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
389 num_fonts = 0;
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
390 break;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
391 }
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
392 if (num_fonts < limit)
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
393 break;
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
394 XFreeFontNames (names);
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
395 }
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
396
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
397 if (num_fonts > 0)
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
398 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
399 char **indices = alloca (sizeof (char *) * num_fonts);
103274
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
400 Lisp_Object *props = XVECTOR (xfont_scratch_props)->contents;
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
401 Lisp_Object scripts = Qnil;
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
402
103274
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
403 for (i = 0; i < ASIZE (xfont_scratch_props); i++)
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
404 props[i] = Qnil;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
405 for (i = 0; i < num_fonts; i++)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
406 indices[i] = names[i];
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
407 qsort (indices, num_fonts, sizeof (char *), compare_font_names);
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
408
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
409 for (i = 0; i < num_fonts; i++)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
410 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
411 Lisp_Object entity;
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
412
95222
005a1655f51e * dispextern.h, xfaces.c (xstrcasecmp): Renamed from xstricmp.
Jason Rumney <jasonr@gnu.org>
parents: 95202
diff changeset
413 if (i > 0 && xstrcasecmp (indices[i - 1], indices[i]) == 0)
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
414 continue;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
415 entity = font_make_entity ();
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
416 xfont_decode_coding_xlfd (indices[i], -1, buf);
104090
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
417 if (font_parse_xlfd (buf, entity) < 0)
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
418 continue;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
419 ASET (entity, FONT_TYPE_INDEX, Qx);
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
420 /* Avoid auto-scaled fonts. */
104090
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
421 if (INTEGERP (AREF (entity, FONT_DPI_INDEX))
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
422 && INTEGERP (AREF (entity, FONT_AVGWIDTH_INDEX))
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
423 && XINT (AREF (entity, FONT_DPI_INDEX)) != 0
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
424 && XINT (AREF (entity, FONT_AVGWIDTH_INDEX)) == 0)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
425 continue;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
426 /* Avoid not-allowed scalable fonts. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
427 if (NILP (Vscalable_fonts_allowed))
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
428 {
104090
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
429 int size = 0;
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
430
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
431 if (INTEGERP (AREF (entity, FONT_SIZE_INDEX)))
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
432 size = XINT (AREF (entity, FONT_SIZE_INDEX));
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
433 else if (FLOATP (AREF (entity, FONT_SIZE_INDEX)))
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
434 size = XFLOAT_DATA (AREF (entity, FONT_SIZE_INDEX));
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
435 if (size == 0)
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
436 continue;
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
437 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
438 else if (CONSP (Vscalable_fonts_allowed))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
439 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
440 Lisp_Object tail, elt;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
441
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
442 for (tail = Vscalable_fonts_allowed; CONSP (tail);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
443 tail = XCDR (tail))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
444 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
445 elt = XCAR (tail);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
446 if (STRINGP (elt)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
447 && fast_c_string_match_ignore_case (elt, indices[i]) >= 0)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
448 break;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
449 }
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
450 if (! CONSP (tail))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
451 continue;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
452 }
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
453
104090
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
454 /* Avoid fonts of invalid registry. */
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
455 if (NILP (AREF (entity, FONT_REGISTRY_INDEX)))
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
456 continue;
1d6a73f0d113 (xfont_list_pattern): Don't ignore the return value of
Kenichi Handa <handa@m17n.org>
parents: 103543
diff changeset
457
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
458 /* Update encoding and repertory if necessary. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
459 if (! EQ (registry, AREF (entity, FONT_REGISTRY_INDEX)))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
460 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
461 registry = AREF (entity, FONT_REGISTRY_INDEX);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
462 if (font_registry_charsets (registry, &encoding, &repertory) < 0)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
463 encoding = NULL;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
464 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
465 if (! encoding)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
466 /* Unknown REGISTRY, not supported. */
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
467 continue;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
468 if (repertory)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
469 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
470 if (NILP (script)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
471 || xfont_chars_supported (chars, NULL, encoding, repertory))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
472 list = Fcons (entity, list);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
473 continue;
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
474 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
475 if (memcmp (props, &(AREF (entity, FONT_FOUNDRY_INDEX)),
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
476 sizeof (Lisp_Object) * 7)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
477 || ! EQ (AREF (entity, FONT_SPACING_INDEX), props[7]))
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
478 {
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
479 memcpy (props, &(AREF (entity, FONT_FOUNDRY_INDEX)),
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
480 sizeof (Lisp_Object) * 7);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
481 props[7] = AREF (entity, FONT_SPACING_INDEX);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
482 scripts = xfont_supported_scripts (display, indices[i],
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
483 xfont_scratch_props, encoding);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
484 }
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
485 if (NILP (script)
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
486 || ! NILP (Fmemq (script, scripts)))
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
487 list = Fcons (entity, list);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
488 }
95227
6df485632f28 (xfont_list_pattern): Free names returned from XListFonts.
Kenichi Handa <handa@m17n.org>
parents: 95222
diff changeset
489 XFreeFontNames (names);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
490 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
491
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
492 x_uncatch_errors ();
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
493 UNBLOCK_INPUT;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
494
103543
11b57e1bdb96 Change font_add_log to FONT_ADD_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103274
diff changeset
495 FONT_ADD_LOG ("xfont-list", build_string (pattern), list);
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
496 return list;
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
497 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
498
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
499 static Lisp_Object
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
500 xfont_list (frame, spec)
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
501 Lisp_Object frame, spec;
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
502 {
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
503 FRAME_PTR f = XFRAME (frame);
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
504 Display *display = FRAME_X_DISPLAY_INFO (f)->display;
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
505 Lisp_Object registry, list, val, extra, script;
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
506 int len;
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
507 /* Large enough to contain the longest XLFD (255 bytes) in UTF-8. */
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
508 char name[512];
101943
97c9e9322753 Remove spurious semicolons.
Juanma Barranquero <lekktu@gmail.com>
parents: 100951
diff changeset
509
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
510 extra = AREF (spec, FONT_EXTRA_INDEX);
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
511 if (CONSP (extra))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
512 {
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
513 val = assq_no_quit (QCotf, extra);
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
514 if (! NILP (val))
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
515 return Qnil;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
516 val = assq_no_quit (QClang, extra);
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
517 if (! NILP (val))
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
518 return Qnil;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
519 }
103184
9d9dd35fa21d Cancel previous changes.
Kenichi Handa <handa@m17n.org>
parents: 103181
diff changeset
520
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
521 registry = AREF (spec, FONT_REGISTRY_INDEX);
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
522 len = font_unparse_xlfd (spec, 0, name, 512);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
523 if (len < 0 || (len = xfont_encode_coding_xlfd (name)) < 0)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
524 return Qnil;
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
525
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
526 val = assq_no_quit (QCscript, extra);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
527 script = CDR (val);
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
528 list = xfont_list_pattern (display, name, registry, script);
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
529 if (NILP (list) && NILP (registry))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
530 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
531 /* Try iso10646-1 */
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
532 char *r = name + len - 9; /* 9 == strlen (iso8859-1) */
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
533
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
534 if (r - name + 10 < 256) /* 10 == strlen (iso10646-1) */
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
535 {
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
536 strcpy (r, "iso10646-1");
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
537 list = xfont_list_pattern (display, name, Qiso10646_1, script);
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
538 }
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
539 }
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
540 if (NILP (list) && ! NILP (registry))
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
541 {
95503
1699a530f6a3 (xfont_list): Try an alias.
Kenichi Handa <handa@m17n.org>
parents: 95330
diff changeset
542 /* Try alternate registries. */
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
543 Lisp_Object alter;
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
544
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
545 if ((alter = Fassoc (SYMBOL_NAME (registry),
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
546 Vface_alternative_font_registry_alist),
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
547 CONSP (alter)))
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
548 {
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
549 /* Pointer to REGISTRY-ENCODING field. */
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
550 char *r = name + len - SBYTES (SYMBOL_NAME (registry));
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
551
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
552 for (alter = XCDR (alter); CONSP (alter); alter = XCDR (alter))
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
553 if (STRINGP (XCAR (alter))
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
554 && ((r - name) + SBYTES (XCAR (alter))) < 256)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
555 {
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
556 strcpy (r, (char *) SDATA (XCAR (alter)));
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
557 list = xfont_list_pattern (display, name, registry, script);
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
558 if (! NILP (list))
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
559 break;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
560 }
90501
2ef165ebcc7d (xfont_query_font): Adjusted for the change of
Kenichi Handa <handa@m17n.org>
parents: 90461
diff changeset
561 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
562 }
95503
1699a530f6a3 (xfont_list): Try an alias.
Kenichi Handa <handa@m17n.org>
parents: 95330
diff changeset
563 if (NILP (list))
1699a530f6a3 (xfont_list): Try an alias.
Kenichi Handa <handa@m17n.org>
parents: 95330
diff changeset
564 {
1699a530f6a3 (xfont_list): Try an alias.
Kenichi Handa <handa@m17n.org>
parents: 95330
diff changeset
565 /* Try alias. */
1699a530f6a3 (xfont_list): Try an alias.
Kenichi Handa <handa@m17n.org>
parents: 95330
diff changeset
566 val = assq_no_quit (QCname, AREF (spec, FONT_EXTRA_INDEX));
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
567 if (CONSP (val) && STRINGP (XCDR (val)) && SBYTES (XCDR (val)) < 512)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
568 {
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
569 bcopy (SDATA (XCDR (val)), name, SBYTES (XCDR (val)) + 1);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
570 if (xfont_encode_coding_xlfd (name) < 0)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
571 return Qnil;
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
572 list = xfont_list_pattern (display, name, registry, script);
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
573 }
95503
1699a530f6a3 (xfont_list): Try an alias.
Kenichi Handa <handa@m17n.org>
parents: 95330
diff changeset
574 }
103184
9d9dd35fa21d Cancel previous changes.
Kenichi Handa <handa@m17n.org>
parents: 103181
diff changeset
575
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
576 return list;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
577 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
578
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
579 static Lisp_Object
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
580 xfont_match (frame, spec)
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
581 Lisp_Object frame, spec;
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
582 {
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
583 FRAME_PTR f = XFRAME (frame);
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
584 Display *display = FRAME_X_DISPLAY_INFO (f)->display;
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
585 Lisp_Object extra, val, entity;
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
586 char name[512];
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
587 XFontStruct *xfont;
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
588 unsigned long value;
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
589
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
590 extra = AREF (spec, FONT_EXTRA_INDEX);
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
591 val = assq_no_quit (QCname, extra);
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
592 if (! CONSP (val) || ! STRINGP (XCDR (val)))
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
593 {
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
594 if (font_unparse_xlfd (spec, 0, name, 512) < 0)
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
595 return Qnil;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
596 }
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
597 else if (SBYTES (XCDR (val)) < 512)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
598 bcopy (SDATA (XCDR (val)), name, SBYTES (XCDR (val)) + 1);
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
599 else
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
600 return Qnil;
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
601 if (xfont_encode_coding_xlfd (name) < 0)
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
602 return Qnil;
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
603
90569
0af2dbdeaeb3 (xfont_match): Block and unblock input while callin Xlib.
Kenichi Handa <handa@m17n.org>
parents: 90561
diff changeset
604 BLOCK_INPUT;
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
605 entity = Qnil;
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
606 xfont = XLoadQueryFont (display, name);
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
607 if (xfont)
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
608 {
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
609 if (XGetFontProperty (xfont, XA_FONT, &value))
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
610 {
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
611 int len;
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
612 char *s;
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
613
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
614 s = (char *) XGetAtomName (display, (Atom) value);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
615 len = strlen (s);
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
616
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
617 /* If DXPC (a Differential X Protocol Compressor)
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
618 Ver.3.7 is running, XGetAtomName will return null
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
619 string. We must avoid such a name. */
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
620 if (len > 0)
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
621 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
622 entity = font_make_entity ();
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
623 ASET (entity, FONT_TYPE_INDEX, Qx);
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
624 xfont_decode_coding_xlfd (s, -1, name);
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
625 if (font_parse_xlfd (name, entity) < 0)
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
626 entity = Qnil;
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
627 }
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
628 XFree (s);
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
629 }
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
630 XFreeFont (display, xfont);
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
631 }
90569
0af2dbdeaeb3 (xfont_match): Block and unblock input while callin Xlib.
Kenichi Handa <handa@m17n.org>
parents: 90561
diff changeset
632 UNBLOCK_INPUT;
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
633
103543
11b57e1bdb96 Change font_add_log to FONT_ADD_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103274
diff changeset
634 FONT_ADD_LOG ("xfont-match", spec, entity);
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
635 return entity;
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
636 }
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
637
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
638 static Lisp_Object
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
639 xfont_list_family (frame)
90443
57b847825c30 (xfont_list): If script is specified for a font, return
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
640 Lisp_Object frame;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
641 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
642 FRAME_PTR f = XFRAME (frame);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
643 Display_Info *dpyinfo = FRAME_X_DISPLAY_INFO (f);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
644 char **names;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
645 int num_fonts, i;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
646 Lisp_Object list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
647 char *last_family;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
648 int last_len;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
649
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
650 BLOCK_INPUT;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
651 x_catch_errors (dpyinfo->display);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
652 names = XListFonts (dpyinfo->display, "-*-*-*-*-*-*-*-*-*-*-*-*-*-*",
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
653 0x8000, &num_fonts);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
654 if (x_had_errors_p (dpyinfo->display))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
655 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
656 /* This error is perhaps due to insufficient memory on X server.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
657 Let's just ignore it. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
658 x_clear_errors (dpyinfo->display);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
659 num_fonts = 0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
660 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
661
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
662 list = Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
663 for (i = 0, last_len = 0; i < num_fonts; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
664 {
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
665 char *p0 = names[i], *p1, buf[512];
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
666 Lisp_Object family;
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
667 int decoded_len;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
668
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
669 p0++; /* skip the leading '-' */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
670 while (*p0 && *p0 != '-') p0++; /* skip foundry */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
671 if (! *p0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
672 continue;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
673 p1 = ++p0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
674 while (*p1 && *p1 != '-') p1++; /* find the end of family */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
675 if (! *p1 || p1 == p0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
676 continue;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
677 if (last_len == p1 - p0
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
678 && bcmp (last_family, p0, last_len) == 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
679 continue;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
680 last_len = p1 - p0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
681 last_family = p0;
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
682
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
683 decoded_len = xfont_decode_coding_xlfd (p0, last_len, buf);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
684 family = font_intern_prop (p0, decoded_len, 1);
97327
53bcf54737b2 (xfont_list_family): Return a list of symbols, not
Kenichi Handa <handa@m17n.org>
parents: 96657
diff changeset
685 if (NILP (assq_no_quit (family, list)))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
686 list = Fcons (family, list);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
687 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
688
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
689 XFreeFontNames (names);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
690 x_uncatch_errors ();
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
691 UNBLOCK_INPUT;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
692
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
693 return list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
694 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
695
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
696 extern Lisp_Object QCavgwidth;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
697
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
698 static Lisp_Object
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
699 xfont_open (f, entity, pixel_size)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
700 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
701 Lisp_Object entity;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
702 int pixel_size;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
703 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
704 Display_Info *dpyinfo = FRAME_X_DISPLAY_INFO (f);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
705 Display *display = dpyinfo->display;
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
706 char name[512];
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
707 int len;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
708 unsigned long value;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
709 Lisp_Object registry;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
710 struct charset *encoding, *repertory;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
711 Lisp_Object font_object, fullname;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
712 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
713 XFontStruct *xfont;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
714
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
715 /* At first, check if we know how to encode characters for this
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
716 font. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
717 registry = AREF (entity, FONT_REGISTRY_INDEX);
91142
4bcf0716ddf4 * xfont.c (x_font_charset_alist): Moved to font.c and renamed.
Kenichi Handa <handa@m17n.org>
parents: 90698
diff changeset
718 if (font_registry_charsets (registry, &encoding, &repertory) < 0)
96575
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
719 {
103543
11b57e1bdb96 Change font_add_log to FONT_ADD_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103274
diff changeset
720 FONT_ADD_LOG (" x:unknown registry", registry, Qnil);
96575
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
721 return Qnil;
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
722 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
723
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
724 if (XINT (AREF (entity, FONT_SIZE_INDEX)) != 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
725 pixel_size = XINT (AREF (entity, FONT_SIZE_INDEX));
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
726 else if (pixel_size == 0)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
727 {
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
728 if (FRAME_FONT (f))
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
729 pixel_size = FRAME_FONT (f)->pixel_size;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
730 else
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
731 pixel_size = 14;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
732 }
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
733 len = font_unparse_xlfd (entity, pixel_size, name, 512);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
734 if (len <= 0 || (len = xfont_encode_coding_xlfd (name)) < 0)
96575
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
735 {
103543
11b57e1bdb96 Change font_add_log to FONT_ADD_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103274
diff changeset
736 FONT_ADD_LOG (" x:unparse failed", entity, Qnil);
96575
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
737 return Qnil;
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
738 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
739
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
740 BLOCK_INPUT;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
741 x_catch_errors (display);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
742 xfont = XLoadQueryFont (display, name);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
743 if (x_had_errors_p (display))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
744 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
745 /* This error is perhaps due to insufficient memory on X server.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
746 Let's just ignore it. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
747 x_clear_errors (display);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
748 xfont = NULL;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
749 }
96657
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
750 else if (! xfont)
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
751 {
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
752 /* Some version of X lists:
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
753 -misc-fixed-medium-r-normal--20-*-75-75-c-100-iso8859-1
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
754 -misc-fixed-medium-r-normal--20-*-100-100-c-100-iso8859-1
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
755 but can open only:
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
756 -misc-fixed-medium-r-normal--20-*-100-100-c-100-iso8859-1
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
757 and
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
758 -misc-fixed-medium-r-normal--20-*-*-*-c-100-iso8859-1
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
759 So, we try again with wildcards in RESX and RESY. */
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
760 Lisp_Object temp;
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
761
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
762 temp = Fcopy_font_spec (entity);
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
763 ASET (temp, FONT_DPI_INDEX, Qnil);
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
764 len = font_unparse_xlfd (temp, pixel_size, name, 512);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
765 if (len <= 0 || (len = xfont_encode_coding_xlfd (name)) < 0)
96657
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
766 {
103543
11b57e1bdb96 Change font_add_log to FONT_ADD_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103274
diff changeset
767 FONT_ADD_LOG (" x:unparse failed", temp, Qnil);
96657
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
768 return Qnil;
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
769 }
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
770 xfont = XLoadQueryFont (display, name);
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
771 if (x_had_errors_p (display))
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
772 {
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
773 /* This error is perhaps due to insufficient memory on X server.
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
774 Let's just ignore it. */
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
775 x_clear_errors (display);
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
776 xfont = NULL;
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
777 }
fb9629443416 (xfont_open): Add workaround for X's bug.
Kenichi Handa <handa@m17n.org>
parents: 96575
diff changeset
778 }
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
779 fullname = Qnil;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
780 /* Try to get the full name of FONT. */
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
781 if (xfont && XGetFontProperty (xfont, XA_FONT, &value))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
782 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
783 char *p0, *p;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
784 int dashes = 0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
785
101943
97c9e9322753 Remove spurious semicolons.
Juanma Barranquero <lekktu@gmail.com>
parents: 100951
diff changeset
786 p0 = p = (char *) XGetAtomName (FRAME_X_DISPLAY (f), (Atom) value);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
787 /* Count the number of dashes in the "full name".
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
788 If it is too few, this isn't really the font's full name,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
789 so don't use it.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
790 In X11R4, the fonts did not come with their canonical names
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
791 stored in them. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
792 while (*p)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
793 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
794 if (*p == '-')
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
795 dashes++;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
796 p++;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
797 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
798
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
799 if (dashes >= 13)
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
800 {
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
801 len = xfont_decode_coding_xlfd (p0, -1, name);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
802 fullname = Fdowncase (make_string (name, len));
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
803 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
804 XFree (p0);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
805 }
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
806 x_uncatch_errors ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
807 UNBLOCK_INPUT;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
808
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
809 if (! xfont)
96575
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
810 {
103543
11b57e1bdb96 Change font_add_log to FONT_ADD_LOG.
Kenichi Handa <handa@m17n.org>
parents: 103274
diff changeset
811 FONT_ADD_LOG (" x:open failed", build_string (name), Qnil);
96575
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
812 return Qnil;
2c94c05f0d89 (xfont_open): Log the reason of failure.
Kenichi Handa <handa@m17n.org>
parents: 96570
diff changeset
813 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
814
96560
d87a9f1b9378 (xfont_open): Adjust it for the change of
Kenichi Handa <handa@m17n.org>
parents: 95568
diff changeset
815 font_object = font_make_object (VECSIZE (struct xfont_info),
d87a9f1b9378 (xfont_open): Adjust it for the change of
Kenichi Handa <handa@m17n.org>
parents: 95568
diff changeset
816 entity, pixel_size);
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
817 ASET (font_object, FONT_TYPE_INDEX, Qx);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
818 if (STRINGP (fullname))
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
819 {
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
820 font_parse_xlfd ((char *) SDATA (fullname), font_object);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
821 ASET (font_object, FONT_NAME_INDEX, fullname);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
822 }
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
823 else
100553
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
824 {
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
825 char buf[512];
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
826
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
827 len = xfont_decode_coding_xlfd (name, -1, buf);
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
828 ASET (font_object, FONT_NAME_INDEX, make_string (buf, len));
e42552b2edda (xfont_decode_coding_xlfd): New function.
Kenichi Handa <handa@m17n.org>
parents: 97327
diff changeset
829 }
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
830 ASET (font_object, FONT_FULLNAME_INDEX, fullname);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
831 ASET (font_object, FONT_FILE_INDEX, Qnil);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
832 ASET (font_object, FONT_FORMAT_INDEX, Qx);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
833 font = XFONT_OBJECT (font_object);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
834 ((struct xfont_info *) font)->xfont = xfont;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
835 ((struct xfont_info *) font)->display = FRAME_X_DISPLAY (f);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
836 font->pixel_size = pixel_size;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
837 font->driver = &xfont_driver;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
838 font->encoding_charset = encoding->id;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
839 font->repertory_charset = repertory ? repertory->id : -1;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
840 font->ascent = xfont->ascent;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
841 font->descent = xfont->descent;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
842 font->height = font->ascent + font->descent;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
843 font->min_width = xfont->min_bounds.width;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
844 if (xfont->min_bounds.width == xfont->max_bounds.width)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
845 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
846 /* Fixed width font. */
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
847 font->average_width = font->space_width = xfont->min_bounds.width;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
848 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
849 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
850 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
851 XCharStruct *pcm;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
852 XChar2b char2b;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
853 Lisp_Object val;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
854
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
855 char2b.byte1 = 0x00, char2b.byte2 = 0x20;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
856 pcm = xfont_get_pcm (xfont, &char2b);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
857 if (pcm)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
858 font->space_width = pcm->width;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
859 else
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
860 font->space_width = 0;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
861
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
862 val = Ffont_get (font_object, QCavgwidth);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
863 if (INTEGERP (val))
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
864 font->average_width = XINT (val);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
865 if (font->average_width < 0)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
866 font->average_width = - font->average_width;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
867 if (font->average_width == 0
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
868 && encoding->ascii_compatible_p)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
869 {
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
870 int width = font->space_width, n = pcm != NULL;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
871
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
872 for (char2b.byte2 = 33; char2b.byte2 <= 126; char2b.byte2++)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
873 if ((pcm = xfont_get_pcm (xfont, &char2b)) != NULL)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
874 width += pcm->width, n++;
95330
fe15ab9a9bc7 (xfont_open): Fix calculation of font->average_width.
Kenichi Handa <handa@m17n.org>
parents: 95227
diff changeset
875 if (n > 0)
fe15ab9a9bc7 (xfont_open): Fix calculation of font->average_width.
Kenichi Handa <handa@m17n.org>
parents: 95227
diff changeset
876 font->average_width = width / n;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
877 }
95330
fe15ab9a9bc7 (xfont_open): Fix calculation of font->average_width.
Kenichi Handa <handa@m17n.org>
parents: 95227
diff changeset
878 if (font->average_width == 0)
fe15ab9a9bc7 (xfont_open): Fix calculation of font->average_width.
Kenichi Handa <handa@m17n.org>
parents: 95227
diff changeset
879 /* No easy way other than this to get a reasonable
fe15ab9a9bc7 (xfont_open): Fix calculation of font->average_width.
Kenichi Handa <handa@m17n.org>
parents: 95227
diff changeset
880 average_width. */
fe15ab9a9bc7 (xfont_open): Fix calculation of font->average_width.
Kenichi Handa <handa@m17n.org>
parents: 95227
diff changeset
881 font->average_width
fe15ab9a9bc7 (xfont_open): Fix calculation of font->average_width.
Kenichi Handa <handa@m17n.org>
parents: 95227
diff changeset
882 = (xfont->min_bounds.width + xfont->max_bounds.width) / 2;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
883 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
884
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
885 BLOCK_INPUT;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
886 font->underline_thickness
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
887 = (XGetFontProperty (xfont, XA_UNDERLINE_THICKNESS, &value)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
888 ? (long) value : 0);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
889 font->underline_position
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
890 = (XGetFontProperty (xfont, XA_UNDERLINE_POSITION, &value)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
891 ? (long) value : -1);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
892 font->baseline_offset
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
893 = (XGetFontProperty (xfont, dpyinfo->Xatom_MULE_BASELINE_OFFSET, &value)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
894 ? (long) value : 0);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
895 font->relative_compose
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
896 = (XGetFontProperty (xfont, dpyinfo->Xatom_MULE_RELATIVE_COMPOSE, &value)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
897 ? (long) value : 0);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
898 font->default_ascent
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
899 = (XGetFontProperty (xfont, dpyinfo->Xatom_MULE_DEFAULT_ASCENT, &value)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
900 ? (long) value : 0);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
901 UNBLOCK_INPUT;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
902
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
903 if (NILP (fullname))
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
904 fullname = AREF (font_object, FONT_NAME_INDEX);
96566
dec3815c40d7 (xfont_open): Cancel the previous about font->vertical_centering.
Kenichi Handa <handa@m17n.org>
parents: 96560
diff changeset
905 font->vertical_centering
dec3815c40d7 (xfont_open): Cancel the previous about font->vertical_centering.
Kenichi Handa <handa@m17n.org>
parents: 96560
diff changeset
906 = (STRINGP (Vvertical_centering_font_regexp)
dec3815c40d7 (xfont_open): Cancel the previous about font->vertical_centering.
Kenichi Handa <handa@m17n.org>
parents: 96560
diff changeset
907 && (fast_string_match_ignore_case
dec3815c40d7 (xfont_open): Cancel the previous about font->vertical_centering.
Kenichi Handa <handa@m17n.org>
parents: 96560
diff changeset
908 (Vvertical_centering_font_regexp, fullname) >= 0));
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
909
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
910 return font_object;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
911 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
912
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
913 static void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
914 xfont_close (f, font)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
915 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
916 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
917 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
918 BLOCK_INPUT;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
919 XFreeFont (FRAME_X_DISPLAY (f), ((struct xfont_info *) font)->xfont);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
920 UNBLOCK_INPUT;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
921 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
922
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
923 static int
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
924 xfont_prepare_face (f, face)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
925 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
926 struct face *face;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
927 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
928 BLOCK_INPUT;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
929 XSetFont (FRAME_X_DISPLAY (f), face->gc,
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
930 ((struct xfont_info *) face->font)->xfont->fid);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
931 UNBLOCK_INPUT;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
932
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
933 return 0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
934 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
935
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
936 static int
102993
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
937 xfont_has_char (font, c)
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
938 Lisp_Object font;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
939 int c;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
940 {
102993
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
941 Lisp_Object registry = AREF (font, FONT_REGISTRY_INDEX);
102956
b20a4659fd91 (xfont_has_char): The font has C if C is ASCII and the
Kenichi Handa <handa@m17n.org>
parents: 101943
diff changeset
942 struct charset *encoding;
102993
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
943 struct charset *repertory = NULL;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
944
102993
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
945 if (EQ (registry, Qiso10646_1))
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
946 {
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
947 encoding = CHARSET_FROM_ID (charset_unicode);
102993
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
948 /* We use a font of `ja' and `ko' adstyle only for a character
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
949 in JISX0208 and KSC5601 charsets respectively. */
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
950 if (EQ (AREF (font, FONT_ADSTYLE_INDEX), Qja)
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
951 && charset_jisx0208 >= 0)
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
952 repertory = CHARSET_FROM_ID (charset_jisx0208);
102993
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
953 else if (EQ (AREF (font, FONT_ADSTYLE_INDEX), Qko)
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
954 && charset_ksc5601 >= 0)
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
955 repertory = CHARSET_FROM_ID (charset_ksc5601);
102993
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
956 }
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
957 else if (font_registry_charsets (registry, &encoding, &repertory) < 0)
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
958 /* Unknown REGISTRY, not usable. */
2e2d289b5f6a (xfont_has_char): Special handling of `ja' and `ko' adstyle.
Kenichi Handa <handa@m17n.org>
parents: 102956
diff changeset
959 return 0;
102956
b20a4659fd91 (xfont_has_char): The font has C if C is ASCII and the
Kenichi Handa <handa@m17n.org>
parents: 101943
diff changeset
960 if (ASCII_CHAR_P (c) && encoding->ascii_compatible_p)
b20a4659fd91 (xfont_has_char): The font has C if C is ASCII and the
Kenichi Handa <handa@m17n.org>
parents: 101943
diff changeset
961 return 1;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
962 if (! repertory)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
963 return -1;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
964 return (ENCODE_CHAR (repertory, c) != CHARSET_INVALID_CODE (repertory));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
965 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
966
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
967 static unsigned
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
968 xfont_encode_char (font, c)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
969 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
970 int c;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
971 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
972 XFontStruct *xfont = ((struct xfont_info *) font)->xfont;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
973 struct charset *charset;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
974 unsigned code;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
975 XChar2b char2b;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
976
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
977 charset = CHARSET_FROM_ID (font->encoding_charset);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
978 code = ENCODE_CHAR (charset, c);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
979 if (code == CHARSET_INVALID_CODE (charset))
91270
0dab56b22dca (xfont_encode_char): Use the macro FONT_INVALID_CODE.
Kenichi Handa <handa@m17n.org>
parents: 91245
diff changeset
980 return FONT_INVALID_CODE;
90454
a8b745412821 (xfont_open, xfont_encode_char): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 90443
diff changeset
981 if (font->repertory_charset >= 0)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
982 {
90454
a8b745412821 (xfont_open, xfont_encode_char): Fix typo.
Kenichi Handa <handa@m17n.org>
parents: 90443
diff changeset
983 charset = CHARSET_FROM_ID (font->repertory_charset);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
984 return (ENCODE_CHAR (charset, c) != CHARSET_INVALID_CODE (charset)
91270
0dab56b22dca (xfont_encode_char): Use the macro FONT_INVALID_CODE.
Kenichi Handa <handa@m17n.org>
parents: 91245
diff changeset
985 ? code : FONT_INVALID_CODE);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
986 }
90425
5976e428d68e (xfont_encode_char): Fix calculation of char2b.
Kenichi Handa <handa@m17n.org>
parents: 90400
diff changeset
987 char2b.byte1 = code >> 8;
5976e428d68e (xfont_encode_char): Fix calculation of char2b.
Kenichi Handa <handa@m17n.org>
parents: 90400
diff changeset
988 char2b.byte2 = code & 0xFF;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
989 return (xfont_get_pcm (xfont, &char2b) ? code : FONT_INVALID_CODE);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
990 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
991
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
992 static int
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
993 xfont_text_extents (font, code, nglyphs, metrics)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
994 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
995 unsigned *code;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
996 int nglyphs;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
997 struct font_metrics *metrics;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
998 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
999 XFontStruct *xfont = ((struct xfont_info *) font)->xfont;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1000 int width = 0;
96570
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1001 int i, first, x;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1002
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1003 if (metrics)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1004 bzero (metrics, sizeof (struct font_metrics));
96570
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1005 for (i = 0, x = 0, first = 1; i < nglyphs; i++)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1006 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1007 XChar2b char2b;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1008 static XCharStruct *pcm;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1009
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1010 if (code[i] >= 0x10000)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1011 continue;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1012 char2b.byte1 = code[i] >> 8, char2b.byte2 = code[i] & 0xFF;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1013 pcm = xfont_get_pcm (xfont, &char2b);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1014 if (! pcm)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1015 continue;
96570
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1016 if (first)
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1017 {
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1018 if (metrics)
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1019 {
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1020 metrics->lbearing = pcm->lbearing;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1021 metrics->rbearing = pcm->rbearing;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1022 metrics->ascent = pcm->ascent;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1023 metrics->descent = pcm->descent;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1024 }
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1025 first = 0;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1026 }
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1027 else
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1028 {
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1029 if (metrics)
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1030 {
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1031 if (metrics->lbearing > width + pcm->lbearing)
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1032 metrics->lbearing = width + pcm->lbearing;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1033 if (metrics->rbearing < width + pcm->rbearing)
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1034 metrics->rbearing = width + pcm->rbearing;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1035 if (metrics->ascent < pcm->ascent)
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1036 metrics->ascent = pcm->ascent;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1037 if (metrics->descent < pcm->descent)
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1038 metrics->descent = pcm->descent;
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1039 }
12587e64cfe3 (xfont_text_extents): Fix initial setting of metrics.
Kenichi Handa <handa@m17n.org>
parents: 96566
diff changeset
1040 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1041 width += pcm->width;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1042 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1043 if (metrics)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1044 metrics->width = width;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1045 return width;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1046 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1047
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1048 static int
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1049 xfont_draw (s, from, to, x, y, with_background)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1050 struct glyph_string *s;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1051 int from, to, x, y, with_background;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1052 {
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1053 XFontStruct *xfont = ((struct xfont_info *) s->font)->xfont;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1054 int len = to - from;
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
1055 GC gc = s->gc;
92185
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1056 int i;
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
1057
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1058 if (s->gc != s->face->gc)
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
1059 {
91905
6ae79e72fea7 (xfont_draw): Use BLOCK_INPUT and UNBLOCK_INPUT.
Kenichi Handa <handa@m17n.org>
parents: 91554
diff changeset
1060 BLOCK_INPUT;
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1061 XSetFont (s->display, gc, xfont->fid);
91905
6ae79e72fea7 (xfont_draw): Use BLOCK_INPUT and UNBLOCK_INPUT.
Kenichi Handa <handa@m17n.org>
parents: 91554
diff changeset
1062 UNBLOCK_INPUT;
90561
73750c4e078a (xfont_match): New function.
Kenichi Handa <handa@m17n.org>
parents: 90545
diff changeset
1063 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1064
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1065 if (xfont->min_byte1 == 0 && xfont->max_byte1 == 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1066 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1067 char *str;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1068 USE_SAFE_ALLOCA;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1069
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1070 SAFE_ALLOCA (str, char *, len);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1071 for (i = 0; i < len ; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1072 str[i] = XCHAR2B_BYTE2 (s->char2b + from + i);
91905
6ae79e72fea7 (xfont_draw): Use BLOCK_INPUT and UNBLOCK_INPUT.
Kenichi Handa <handa@m17n.org>
parents: 91554
diff changeset
1073 BLOCK_INPUT;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1074 if (with_background > 0)
92185
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1075 {
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1076 if (s->padding_p)
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1077 for (i = 0; i < len; i++)
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1078 XDrawImageString (FRAME_X_DISPLAY (s->f), FRAME_X_WINDOW (s->f),
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1079 gc, x + i, y, str + i, 1);
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1080 else
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1081 XDrawImageString (FRAME_X_DISPLAY (s->f), FRAME_X_WINDOW (s->f),
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1082 gc, x, y, str, len);
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1083 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1084 else
92185
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1085 {
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1086 if (s->padding_p)
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1087 for (i = 0; i < len; i++)
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1088 XDrawString (FRAME_X_DISPLAY (s->f), FRAME_X_WINDOW (s->f),
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1089 gc, x + i, y, str + i, 1);
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1090 else
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1091 XDrawString (FRAME_X_DISPLAY (s->f), FRAME_X_WINDOW (s->f),
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1092 gc, x, y, str, len);
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1093 }
91905
6ae79e72fea7 (xfont_draw): Use BLOCK_INPUT and UNBLOCK_INPUT.
Kenichi Handa <handa@m17n.org>
parents: 91554
diff changeset
1094 UNBLOCK_INPUT;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1095 SAFE_FREE ();
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1096 return s->nchars;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1097 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1098
91905
6ae79e72fea7 (xfont_draw): Use BLOCK_INPUT and UNBLOCK_INPUT.
Kenichi Handa <handa@m17n.org>
parents: 91554
diff changeset
1099 BLOCK_INPUT;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1100 if (with_background > 0)
92185
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1101 {
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1102 if (s->padding_p)
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1103 for (i = 0; i < len; i++)
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1104 XDrawImageString16 (FRAME_X_DISPLAY (s->f), FRAME_X_WINDOW (s->f),
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1105 gc, x + i, y, s->char2b + from + i, 1);
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1106 else
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1107 XDrawImageString16 (FRAME_X_DISPLAY (s->f), FRAME_X_WINDOW (s->f),
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1108 gc, x, y, s->char2b + from, len);
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1109 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1110 else
92185
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1111 {
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1112 if (s->padding_p)
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1113 for (i = 0; i < len; i++)
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1114 XDrawString16 (FRAME_X_DISPLAY (s->f), FRAME_X_WINDOW (s->f),
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1115 gc, x + i, y, s->char2b + from + i, 1);
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1116 else
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1117 XDrawString16 (FRAME_X_DISPLAY (s->f), FRAME_X_WINDOW (s->f),
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1118 gc, x, y, s->char2b + from, len);
1e28008a13e5 (xfont_draw): Pay attention to s->padding_p.
Kenichi Handa <handa@m17n.org>
parents: 91905
diff changeset
1119 }
91905
6ae79e72fea7 (xfont_draw): Use BLOCK_INPUT and UNBLOCK_INPUT.
Kenichi Handa <handa@m17n.org>
parents: 91554
diff changeset
1120 UNBLOCK_INPUT;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1121
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1122 return len;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1123 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1124
94940
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1125 static int
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1126 xfont_check (f, font)
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1127 FRAME_PTR f;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1128 struct font *font;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1129 {
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1130 struct xfont_info *xfont = (struct xfont_info *) font;
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1131
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1132 return (FRAME_X_DISPLAY (f) == xfont->display ? 0 : -1);
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1133 }
061d44df20b7 Include <stdlib.h> and "ccl.h".
Kenichi Handa <handa@m17n.org>
parents: 92185
diff changeset
1134
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1135
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1136 void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1137 syms_of_xfont ()
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1138 {
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
1139 staticpro (&xfont_scripts_cache);
103274
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
1140 { /* Here we rely on the fact that syms_of_xfont (via syms_of_font)
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
1141 is called fairly late, when QCtest and Qequal are known to be set. */
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
1142 Lisp_Object args[2];
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
1143 args[0] = QCtest;
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
1144 args[1] = Qequal;
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
1145 xfont_scripts_cache = Fmake_hash_table (2, args);
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
1146 }
103270
c4706100caab (xfont_chars_supported, xfont_supported_scripts): New
Kenichi Handa <handa@m17n.org>
parents: 103184
diff changeset
1147 staticpro (&xfont_scratch_props);
103274
0e85983c95eb (xfont_list_pattern): Don't initialize xfont_scripts_cache
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 103270
diff changeset
1148 xfont_scratch_props = Fmake_vector (make_number (8), Qnil);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1149 xfont_driver.type = Qx;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1150 register_font_driver (&xfont_driver, NULL);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1151 }
90427
ddb25860d044 Add arch tagline
Miles Bader <miles@gnu.org>
parents: 90425
diff changeset
1152
ddb25860d044 Add arch tagline
Miles Bader <miles@gnu.org>
parents: 90425
diff changeset
1153 /* arch-tag: 23c5f366-a5ee-44b7-a3b7-90d6da7fd749
ddb25860d044 Add arch tagline
Miles Bader <miles@gnu.org>
parents: 90425
diff changeset
1154 (do not change this comment) */