annotate src/font.c @ 95176:686d116f748d

Checking of FONT_DEBUG is moved to font.h. All calls of xassert are changed to font_assert. Many unused variables deleted. (Vfont_weight_table, Vfont_slant_table, Vfont_width_table): New variables. (struct table_entry): Moved from xfaces.c and modified. (weight_table, slant_table, width_table): Moved from xfaces.c and contents adjusted for the change of struct table_entry. (font_style_to_value, font_style_symbolic): Adjuted for the format change of font_style_table. (font_parse_family_registry): Don't overwrite existing foundry and family of font_spec. (font_score): Fix calculation of diff for sizes. (font_sort_entites): Call font_add_log. (font_delete_unmatched): Return a newly created list. (font_list_entities): Fix previous change. Call font_add_log. (font_matching_entity, font_open_entity, font_close_entity): Call font_add_log. (Ffont_xlfd_name): New arg FOLD-WILDCARDS. (Finternal_set_font_style_table): Deleted. (BUILD_STYLE_TABLE): New macro. (build_style_table): New function. (Vfont_log, font_log_env_checked): New variables. (font_add_log): New function. (syms_of_font): Delete defsubr Sinternal_set_font_style_table. Declare Lisp variables "font-weight-table", "font-slant-table", "font-width-table", and "font-log". Initialize font_style_table.
author Kenichi Handa <handa@m17n.org>
date Thu, 22 May 2008 02:19:21 +0000
parents f64ddc606a66
children 43c13e1346d5
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 /* font.c -- "Font" primitives.
91553
90ccb789a16c Update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 91550
diff changeset
2 Copyright (C) 2006, 2007, 2008 Free Software Foundation, Inc.
90ccb789a16c Update copyright years.
Glenn Morris <rgm@gnu.org>
parents: 91550
diff changeset
3 Copyright (C) 2006, 2007, 2008
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: 94926
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: 94926
diff changeset
11 the Free Software Foundation, either version 3 of the License, or
8971ddf55736 Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents: 94926
diff changeset
12 (at your option) any later version.
90400
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: 94926
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>
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
24 #include <stdlib.h>
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
25 #include <strings.h>
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
26 #include <ctype.h>
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
27 #ifdef HAVE_M17N_FLT
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
28 #include <m17n-flt.h>
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
29 #endif
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
30
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
31 #include "lisp.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
32 #include "buffer.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
33 #include "frame.h"
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
34 #include "window.h"
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
35 #include "dispextern.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
36 #include "charset.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
37 #include "character.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
38 #include "composite.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
39 #include "fontset.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
40 #include "font.h"
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
41
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
42 #ifdef HAVE_X_WINDOWS
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
43 #include "xterm.h"
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
44 #endif /* HAVE_X_WINDOWS */
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
45
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
46 #ifdef HAVE_NTGUI
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
47 #include "w32term.h"
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
48 #endif /* HAVE_NTGUI */
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
49
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
50 #ifdef MAC_OS
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
51 #include "macterm.h"
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
52 #endif /* MAC_OS */
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
53
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
54 Lisp_Object Qfont_spec, Qfont_entity, Qfont_object;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
55
90677
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
56 Lisp_Object Qopentype;
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
57
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
58 /* Important character set strings. */
90622
bb9362e3a03b (Qunicode_sip): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90590
diff changeset
59 Lisp_Object Qiso8859_1, Qiso10646_1, Qunicode_bmp, Qunicode_sip;
90439
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
60
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
61 /* Special vector of zero length. This is repeatedly used by (struct
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
62 font_driver *)->list when a specified font is not found. */
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
63 static Lisp_Object null_vector;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
64
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
65 static Lisp_Object Vfont_weight_table, Vfont_slant_table, Vfont_width_table;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
66
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
67 /* Vector of Vfont_weight_table, Vfont_slant_table, and Vfont_width_table. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
68 static Lisp_Object font_style_table;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
69
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
70 /* Structure used for tables mapping weight, slant, and width numeric
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
71 values and their names. */
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
72
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
73 struct table_entry
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
74 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
75 int numeric;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
76 /* The first one is a valid name as a face attribute.
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
77 The second one (if any) is a typical name in XLFD field. */
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
78 char *names[5];
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
79 Lisp_Object *symbols;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
80 };
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
81
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
82 /* Table of weight numeric values and their names. This table must be
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
83 sorted by numeric values in ascending order. */
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
84
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
85 static struct table_entry weight_table[] =
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
86 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
87 { 0, { "thin" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
88 { 20, { "ultra-light", "ultralight" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
89 { 40, { "extra-light", "extralight" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
90 { 50, { "light" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
91 { 75, { "semi-light", "semilight", "demilight", "book" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
92 { 100, { "normal", "medium", "regular" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
93 { 180, { "semi-bold", "semibold", "demibold", "demi" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
94 { 200, { "bold" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
95 { 205, { "extra-bold", "extrabold" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
96 { 210, { "ultra-bold", "ultrabold", "black" }}
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
97 };
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
98
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
99 /* Table of slant numeric values and their names. This table must be
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
100 sorted by numeric values in ascending order. */
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
101
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
102 static struct table_entry slant_table[] =
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
103 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
104 { 0, { "reverse-oblique", "ro" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
105 { 10, { "reverse-italic", "ri" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
106 { 100, { "normal", "r" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
107 { 200, { "italic" ,"i", "ot" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
108 { 210, { "oblique", "o" }}
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
109 };
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
110
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
111 /* Table of width numeric values and their names. This table must be
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
112 sorted by numeric values in ascending order. */
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
113
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
114 static struct table_entry width_table[] =
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
115 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
116 { 50, { "ultra-condensed", "ultracondensed" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
117 { 63, { "extra-condensed", "extracondensed" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
118 { 75, { "condensed", "compressed", "narrow" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
119 { 87, { "semi-condensed", "semicondensed", "demicondensed" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
120 { 100, { "normal", "medium", "regular" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
121 { 113, { "semi-expanded", "semiexpanded", "demiexpanded" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
122 { 125, { "expanded" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
123 { 150, { "extra-expanded", "extraexpanded" }},
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
124 { 200, { "ultra-expanded", "ultraexpanded", "wide" }}
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
125 };
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
126
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
127 extern Lisp_Object Qnormal;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
128
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
129 /* Symbols representing keys of normal font properties. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
130 extern Lisp_Object QCtype, QCfamily, QCweight, QCslant, QCwidth, QCsize, QCname;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
131 Lisp_Object QCfoundry, QCadstyle, QCregistry;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
132 /* Symbols representing keys of font extra info. */
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
133 Lisp_Object QCspacing, QCdpi, QCscalable, QCotf, QClang, QCscript, QCavgwidth;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
134 Lisp_Object QCantialias, QCfont_entity, QCfc_unknown_spec;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
135 /* Symbols representing values of font spacing property. */
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
136 Lisp_Object Qc, Qm, Qp, Qd;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
137
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
138 Lisp_Object Vfont_encoding_alist;
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
139
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
140 /* Alist of font registry symbol and the corresponding charsets
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
141 information. The information is retrieved from
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
142 Vfont_encoding_alist on demand.
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
143
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
144 Eash element has the form:
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
145 (REGISTRY . (ENCODING-CHARSET-ID . REPERTORY-CHARSET-ID))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
146 or
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
147 (REGISTRY . nil)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
148
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
149 In the former form, ENCODING-CHARSET-ID is an ID of a charset that
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
150 encodes a character code to a glyph code of a font, and
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
151 REPERTORY-CHARSET-ID is an ID of a charset that tells if a
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
152 character is supported by a font.
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
153
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
154 The latter form means that the information for REGISTRY couldn't be
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
155 retrieved. */
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
156 static Lisp_Object font_charset_alist;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
157
91112
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
158 /* List of all font drivers. Each font-backend (XXXfont.c) calls
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
159 register_font_driver in syms_of_XXXfont to register its font-driver
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
160 here. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
161 static struct font_driver_list *font_driver_list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
162
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
163
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
164
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
165 /* Creaters of font-related Lisp object. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
166
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
167 Lisp_Object
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
168 font_make_spec ()
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
169 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
170 Lisp_Object font_spec;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
171 struct font_spec *spec
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
172 = ((struct font_spec *)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
173 allocate_pseudovector (VECSIZE (struct font_spec),
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
174 FONT_SPEC_MAX, PVEC_FONT));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
175 XSETFONT (font_spec, spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
176 return font_spec;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
177 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
178
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
179 Lisp_Object
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
180 font_make_entity ()
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
181 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
182 Lisp_Object font_entity;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
183 struct font_entity *entity
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
184 = ((struct font_entity *)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
185 allocate_pseudovector (VECSIZE (struct font_entity),
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
186 FONT_ENTITY_MAX, PVEC_FONT));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
187 XSETFONT (font_entity, entity);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
188 return font_entity;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
189 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
190
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
191 Lisp_Object
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
192 font_make_object (size)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
193 int size;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
194 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
195 Lisp_Object font_object;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
196 struct font *font
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
197 = (struct font *) allocate_pseudovector (size, FONT_OBJECT_MAX, PVEC_FONT);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
198 XSETFONT (font_object, font);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
199
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
200 return font_object;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
201 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
202
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
203
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
204
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
205 static int font_pixel_size P_ ((FRAME_PTR f, Lisp_Object));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
206 static Lisp_Object font_open_entity P_ ((FRAME_PTR, Lisp_Object, int));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
207 static Lisp_Object font_matching_entity P_ ((FRAME_PTR, Lisp_Object *,
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
208 Lisp_Object));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
209
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
210 /* Number of registered font drivers. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
211 static int num_font_drivers;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
212
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
213
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
214 /* Return a Lispy value of a font property value at STR and LEN bytes.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
215 If STR is "*", it returns nil.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
216 If all characters in STR are digits, it returns an integer.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
217 Otherwise, it returns a symbol interned from STR. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
218
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
219 Lisp_Object
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
220 font_intern_prop (str, len)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
221 char *str;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
222 int len;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
223 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
224 int i;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
225 Lisp_Object tem;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
226 Lisp_Object obarray;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
227
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
228 if (len == 1 && *str == '*')
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
229 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
230 if (len >=1 && isdigit (*str))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
231 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
232 for (i = 1; i < len; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
233 if (! isdigit (str[i]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
234 break;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
235 if (i == len)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
236 return make_number (atoi (str));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
237 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
238
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
239 /* The following code is copied from the function intern (in lread.c). */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
240 obarray = Vobarray;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
241 if (!VECTORP (obarray) || XVECTOR (obarray)->size == 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
242 obarray = check_obarray (obarray);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
243 tem = oblookup (obarray, str, len, len);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
244 if (SYMBOLP (tem))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
245 return tem;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
246 return Fintern (make_unibyte_string (str, len), obarray);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
247 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
248
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
249 /* Return a pixel size of font-spec SPEC on frame F. */
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
250
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
251 static int
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
252 font_pixel_size (f, spec)
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
253 FRAME_PTR f;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
254 Lisp_Object spec;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
255 {
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
256 #ifdef HAVE_WINDOW_SYSTEM
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
257 Lisp_Object size = AREF (spec, FONT_SIZE_INDEX);
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
258 double point_size;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
259 int dpi, pixel_size;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
260 Lisp_Object val;
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
261
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
262 if (INTEGERP (size))
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
263 return XINT (size);
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
264 if (NILP (size))
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
265 return 0;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
266 font_assert (FLOATP (size));
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
267 point_size = XFLOAT_DATA (size);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
268 val = AREF (spec, FONT_DPI_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
269 if (INTEGERP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
270 dpi = XINT (XCDR (val));
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
271 else
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
272 dpi = f->resy;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
273 pixel_size = POINT_TO_PIXEL (point_size, dpi);
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
274 return pixel_size;
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
275 #else
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
276 return 1;
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
277 #endif
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
278 }
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
279
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
280
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
281 /* Return a value of PROP's VAL (symbol or integer) to be stored in a
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
282 font vector. If VAL is not valid (i.e. not registered in
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
283 font_style_table), return -1 if NOERROR is zero, and return a
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
284 proper index if NOERROR is nonzero. In that case, register VAL in
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
285 font_style_table if VAL is a symbol, and return a closest index if
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
286 VAL is an integer. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
287
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
288 int
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
289 font_style_to_value (prop, val, noerror)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
290 enum font_property_index prop;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
291 Lisp_Object val;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
292 int noerror;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
293 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
294 Lisp_Object table = AREF (font_style_table, prop - FONT_WEIGHT_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
295 int len = ASIZE (table);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
296 int i, j;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
297
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
298 if (SYMBOLP (val))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
299 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
300 char *s;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
301 Lisp_Object args[2], elt;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
302
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
303 /* At first try exact match. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
304 for (i = 0; i < len; i++)
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
305 for (j = 1; j < ASIZE (AREF (table, i)); j++)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
306 if (EQ (val, AREF (AREF (table, i), j)))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
307 return ((XINT (AREF (AREF (table, i), 0)) << 8)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
308 | (i << 4) | (j - 1));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
309 /* Try also with case-folding match. */
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
310 s = (char *) SDATA (SYMBOL_NAME (val));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
311 for (i = 0; i < len; i++)
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
312 for (j = 1; j < ASIZE (AREF (table, i)); j++)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
313 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
314 elt = AREF (AREF (table, i), j);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
315 if (strcasecmp (s, (char *) SDATA (SYMBOL_NAME (elt))) == 0)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
316 return ((XINT (AREF (AREF (table, i), 0)) << 8)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
317 | (i << 4) | (j - 1));
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
318 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
319 if (! noerror)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
320 return -1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
321 if (len == 255)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
322 abort ();
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
323 elt = Fmake_vector (make_number (2), make_number (255));
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
324 ASET (elt, 1, val);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
325 args[0] = table;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
326 args[1] = Fmake_vector (make_number (1), elt);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
327 ASET (font_style_table, prop - FONT_WEIGHT_INDEX, Fvconcat (2, args));
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
328 return (255 << 8) | (i << 4);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
329 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
330 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
331 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
332 int i, last_n;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
333 int numeric = XINT (val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
334
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
335 for (i = 0, last_n = -1; i < len; i++)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
336 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
337 int n = XINT (AREF (AREF (table, i), 0));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
338
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
339 if (numeric == n)
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
340 return (n << 8) | (i << 4);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
341 if (numeric < n)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
342 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
343 if (! noerror)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
344 return -1;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
345 return ((i == 0 || n - numeric < numeric - last_n)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
346 ? (n << 8) | (i << 4): (last_n << 8 | ((i - 1) << 4)));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
347 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
348 last_n = n;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
349 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
350 if (! noerror)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
351 return -1;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
352 return ((last_n << 8) | ((i - 1) << 4));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
353 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
354 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
355
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
356 Lisp_Object
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
357 font_style_symbolic (font, prop, for_face)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
358 Lisp_Object font;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
359 enum font_property_index prop;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
360 int for_face;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
361 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
362 Lisp_Object val = AREF (font, prop);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
363 Lisp_Object table, elt;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
364 int i;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
365
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
366 if (NILP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
367 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
368 table = AREF (font_style_table, prop - FONT_WEIGHT_INDEX);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
369 i = XINT (val) & 0xFF;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
370 font_assert (((i >> 4) & 0xF) < ASIZE (table));
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
371 elt = AREF (table, ((i >> 4) & 0xF));
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
372 font_assert ((i & 0xF) + 1 < ASIZE (elt));
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
373 return (for_face ? AREF (elt, 1) : AREF (elt, (i & 0xF) + 1));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
374 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
375
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
376 extern Lisp_Object Vface_alternative_font_family_alist;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
377
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
378 extern Lisp_Object find_font_encoding P_ ((Lisp_Object));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
379
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
380
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
381 /* Return ENCODING or a cons of ENCODING and REPERTORY of the font
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
382 FONTNAME. ENCODING is a charset symbol that specifies the encoding
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
383 of the font. REPERTORY is a charset symbol or nil. */
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
384
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
385 Lisp_Object
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
386 find_font_encoding (fontname)
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
387 Lisp_Object fontname;
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
388 {
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
389 Lisp_Object tail, elt;
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
390
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
391 for (tail = Vfont_encoding_alist; CONSP (tail); tail = XCDR (tail))
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
392 {
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
393 elt = XCAR (tail);
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
394 if (CONSP (elt)
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
395 && STRINGP (XCAR (elt))
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
396 && fast_string_match_ignore_case (XCAR (elt), fontname) >= 0
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
397 && (SYMBOLP (XCDR (elt))
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
398 ? CHARSETP (XCDR (elt))
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
399 : CONSP (XCDR (elt)) && CHARSETP (XCAR (XCDR (elt)))))
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
400 return (XCDR (elt));
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
401 }
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
402 /* We don't know the encoding of this font. Let's assume `ascii'. */
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
403 return Qascii;
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
404 }
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
405
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
406 /* Return encoding charset and repertory charset for REGISTRY in
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
407 ENCODING and REPERTORY correspondingly. If correct information for
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
408 REGISTRY is available, return 0. Otherwise return -1. */
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
409
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
410 int
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
411 font_registry_charsets (registry, encoding, repertory)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
412 Lisp_Object registry;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
413 struct charset **encoding, **repertory;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
414 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
415 Lisp_Object val;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
416 int encoding_id, repertory_id;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
417
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
418 val = Fassoc_string (registry, font_charset_alist, Qt);
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
419 if (! NILP (val))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
420 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
421 val = XCDR (val);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
422 if (NILP (val))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
423 return -1;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
424 encoding_id = XINT (XCAR (val));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
425 repertory_id = XINT (XCDR (val));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
426 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
427 else
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
428 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
429 val = find_font_encoding (SYMBOL_NAME (registry));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
430 if (SYMBOLP (val) && CHARSETP (val))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
431 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
432 encoding_id = repertory_id = XINT (CHARSET_SYMBOL_ID (val));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
433 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
434 else if (CONSP (val))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
435 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
436 if (! CHARSETP (XCAR (val)))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
437 goto invalid_entry;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
438 encoding_id = XINT (CHARSET_SYMBOL_ID (XCAR (val)));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
439 if (NILP (XCDR (val)))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
440 repertory_id = -1;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
441 else
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
442 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
443 if (! CHARSETP (XCDR (val)))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
444 goto invalid_entry;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
445 repertory_id = XINT (CHARSET_SYMBOL_ID (XCDR (val)));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
446 }
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
447 }
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
448 else
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
449 goto invalid_entry;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
450 val = Fcons (make_number (encoding_id), make_number (repertory_id));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
451 font_charset_alist
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
452 = nconc2 (font_charset_alist, Fcons (Fcons (registry, val), Qnil));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
453 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
454
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
455 if (encoding)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
456 *encoding = CHARSET_FROM_ID (encoding_id);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
457 if (repertory)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
458 *repertory = repertory_id >= 0 ? CHARSET_FROM_ID (repertory_id) : NULL;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
459 return 0;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
460
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
461 invalid_entry:
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
462 font_charset_alist
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
463 = nconc2 (font_charset_alist, Fcons (Fcons (registry, Qnil), Qnil));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
464 return -1;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
465 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
466
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
467
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
468 /* Font property value validaters. See the comment of
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
469 font_property_table for the meaning of the arguments. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
470
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
471 static Lisp_Object font_prop_validate P_ ((int, Lisp_Object, Lisp_Object));
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
472 static Lisp_Object font_prop_validate_symbol P_ ((Lisp_Object, Lisp_Object));
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
473 static Lisp_Object font_prop_validate_style P_ ((Lisp_Object, Lisp_Object));
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
474 static Lisp_Object font_prop_validate_non_neg P_ ((Lisp_Object, Lisp_Object));
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
475 static Lisp_Object font_prop_validate_spacing P_ ((Lisp_Object, Lisp_Object));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
476 static int get_font_prop_index P_ ((Lisp_Object));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
477
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
478 static Lisp_Object
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
479 font_prop_validate_symbol (prop, val)
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
480 Lisp_Object prop, val;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
481 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
482 if (STRINGP (val))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
483 val = Fintern (val, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
484 if (! SYMBOLP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
485 val = Qerror;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
486 else if (EQ (prop, QCregistry))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
487 val = Fintern (Fdowncase (SYMBOL_NAME (val)), Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
488 return val;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
489 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
490
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
491
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
492 static Lisp_Object
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
493 font_prop_validate_style (style, val)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
494 Lisp_Object style, val;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
495 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
496 enum font_property_index prop = (EQ (style, QCweight) ? FONT_WEIGHT_INDEX
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
497 : EQ (style, QCslant) ? FONT_SLANT_INDEX
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
498 : FONT_WIDTH_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
499 int n;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
500 if (INTEGERP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
501 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
502 n = XINT (val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
503 if ((n & 0xFF)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
504 >= ASIZE (AREF (font_style_table, prop - FONT_WEIGHT_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
505 val = Qerror;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
506 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
507 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
508 Lisp_Object elt = AREF (AREF (font_style_table, prop - FONT_WEIGHT_INDEX), n & 0xFF);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
509 if (XINT (XCDR (elt)) != (n >> 8))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
510 val = Qerror;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
511 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
512 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
513 else if (SYMBOLP (val))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
514 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
515 int n = font_style_to_value (prop, val, 0);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
516
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
517 val = n >= 0 ? make_number (n) : Qerror;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
518 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
519 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
520 val = Qerror;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
521 return val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
522 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
523
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
524 static Lisp_Object
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
525 font_prop_validate_non_neg (prop, val)
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
526 Lisp_Object prop, val;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
527 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
528 return (NATNUMP (val) || (FLOATP (val) && XFLOAT_DATA (val) >= 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
529 ? val : Qerror);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
530 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
531
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
532 static Lisp_Object
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
533 font_prop_validate_spacing (prop, val)
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
534 Lisp_Object prop, val;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
535 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
536 if (NILP (val) || (NATNUMP (val) && XINT (val) <= FONT_SPACING_CHARCELL))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
537 return val;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
538 if (EQ (val, Qc))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
539 return make_number (FONT_SPACING_CHARCELL);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
540 if (EQ (val, Qm))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
541 return make_number (FONT_SPACING_MONO);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
542 if (EQ (val, Qp))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
543 return make_number (FONT_SPACING_PROPORTIONAL);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
544 if (EQ (val, Qd))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
545 return make_number (FONT_SPACING_DUAL);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
546 return Qerror;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
547 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
548
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
549 static Lisp_Object
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
550 font_prop_validate_otf (prop, val)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
551 Lisp_Object prop, val;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
552 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
553 Lisp_Object tail, tmp;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
554 int i;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
555
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
556 /* VAL = (SCRIPT [ LANGSYS [ GSUB-FEATURES [ GPOS-FEATURES ]]])
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
557 GSUB-FEATURES = (FEATURE ... [ nil FEATURE ... ]) | nil
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
558 GPOS-FEATURES = (FEATURE ... [ nil FEATURE ... ]) | nil */
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
559 if (! CONSP (val))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
560 return Qerror;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
561 if (! SYMBOLP (XCAR (val)))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
562 return Qerror;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
563 tail = XCDR (val);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
564 if (NILP (tail))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
565 return val;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
566 if (! CONSP (tail) || ! SYMBOLP (XCAR (val)))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
567 return Qerror;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
568 for (i = 0; i < 2; i++)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
569 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
570 tail = XCDR (tail);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
571 if (NILP (tail))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
572 return val;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
573 if (! CONSP (tail))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
574 return Qerror;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
575 for (tmp = XCAR (tail); CONSP (tmp); tmp = XCDR (tmp))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
576 if (! SYMBOLP (XCAR (tmp)))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
577 return Qerror;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
578 if (! NILP (tmp))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
579 return Qerror;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
580 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
581 return val;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
582 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
583
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
584 /* Structure of known font property keys and validater of the
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
585 values. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
586 struct
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
587 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
588 /* Pointer to the key symbol. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
589 Lisp_Object *key;
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
590 /* Function to validate PROP's value VAL, or NULL if any value is
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
591 ok. The value is VAL or its regularized value if VAL is valid,
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
592 and Qerror if not. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
593 Lisp_Object (*validater) P_ ((Lisp_Object prop, Lisp_Object val));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
594 } font_property_table[] =
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
595 { { &QCtype, font_prop_validate_symbol },
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
596 { &QCfoundry, font_prop_validate_symbol },
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
597 { &QCfamily, font_prop_validate_symbol },
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
598 { &QCadstyle, font_prop_validate_symbol },
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
599 { &QCregistry, font_prop_validate_symbol },
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
600 { &QCweight, font_prop_validate_style },
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
601 { &QCslant, font_prop_validate_style },
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
602 { &QCwidth, font_prop_validate_style },
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
603 { &QCsize, font_prop_validate_non_neg },
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
604 { &QCdpi, font_prop_validate_non_neg },
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
605 { &QCspacing, font_prop_validate_spacing },
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
606 { &QCavgwidth, font_prop_validate_non_neg },
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
607 /* The order of the above entries must match with enum
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
608 font_property_index. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
609 { &QClang, font_prop_validate_symbol },
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
610 { &QCscript, font_prop_validate_symbol },
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
611 { &QCotf, font_prop_validate_otf }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
612 };
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
613
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
614 /* Size (number of elements) of the above table. */
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
615 #define FONT_PROPERTY_TABLE_SIZE \
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
616 ((sizeof font_property_table) / (sizeof *font_property_table))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
617
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
618 /* Return an index number of font property KEY or -1 if KEY is not an
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
619 already known property. */
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
620
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
621 static int
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
622 get_font_prop_index (key)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
623 Lisp_Object key;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
624 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
625 int i;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
626
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
627 for (i = 0; i < FONT_PROPERTY_TABLE_SIZE; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
628 if (EQ (key, *font_property_table[i].key))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
629 return i;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
630 return -1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
631 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
632
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
633 /* Validate the font property. The property key is specified by the
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
634 symbol PROP, or the index IDX (if PROP is nil). If VAL is invalid,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
635 signal an error. The value is VAL or the regularized one. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
636
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
637 static Lisp_Object
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
638 font_prop_validate (idx, prop, val)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
639 int idx;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
640 Lisp_Object prop, val;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
641 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
642 Lisp_Object validated;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
643
94964
5ffc88767cc1 (font_prop_validate): Make nil a valid value.
Kenichi Handa <handa@m17n.org>
parents: 94963
diff changeset
644 if (NILP (val))
5ffc88767cc1 (font_prop_validate): Make nil a valid value.
Kenichi Handa <handa@m17n.org>
parents: 94963
diff changeset
645 return val;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
646 if (NILP (prop))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
647 prop = *font_property_table[idx].key;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
648 else
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
649 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
650 idx = get_font_prop_index (prop);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
651 if (idx < 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
652 return val;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
653 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
654 validated = (font_property_table[idx].validater) (prop, val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
655 if (EQ (validated, Qerror))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
656 signal_error ("invalid font property", Fcons (prop, val));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
657 return validated;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
658 }
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
659
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
660
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
661 /* Store VAL as a value of extra font property PROP in FONT while
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
662 keeping the sorting order. Don't check the validity of VAL. */
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
663
90888
5f03b3602143 (font_put_extra): Expose externally.
Jason Rumney <jasonr@gnu.org>
parents: 90883
diff changeset
664 Lisp_Object
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
665 font_put_extra (font, prop, val)
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
666 Lisp_Object font, prop, val;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
667 {
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
668 Lisp_Object extra = AREF (font, FONT_EXTRA_INDEX);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
669 Lisp_Object slot = (NILP (extra) ? Qnil : assq_no_quit (prop, extra));
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
670
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
671 if (NILP (slot))
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
672 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
673 Lisp_Object prev = Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
674
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
675 while (CONSP (extra)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
676 && NILP (Fstring_lessp (prop, XCAR (XCAR (extra)))))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
677 prev = extra, extra = XCDR (extra);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
678 if (NILP (prev))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
679 ASET (font, FONT_EXTRA_INDEX, Fcons (Fcons (prop, val), extra));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
680 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
681 XSETCDR (prev, Fcons (Fcons (prop, val), extra));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
682 return val;
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
683 }
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
684 XSETCDR (slot, val);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
685 return val;
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
686 }
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
687
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
688
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
689 /* Font name parser and unparser */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
690
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
691 static int parse_matrix P_ ((char *));
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
692 static int font_expand_wildcards P_ ((Lisp_Object *, int));
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
693 static int font_parse_name P_ ((char *, Lisp_Object));
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
694
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
695 /* An enumerator for each field of an XLFD font name. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
696 enum xlfd_field_index
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
697 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
698 XLFD_FOUNDRY_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
699 XLFD_FAMILY_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
700 XLFD_WEIGHT_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
701 XLFD_SLANT_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
702 XLFD_SWIDTH_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
703 XLFD_ADSTYLE_INDEX,
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
704 XLFD_PIXEL_INDEX,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
705 XLFD_POINT_INDEX,
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
706 XLFD_RESX_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
707 XLFD_RESY_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
708 XLFD_SPACING_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
709 XLFD_AVGWIDTH_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
710 XLFD_REGISTRY_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
711 XLFD_ENCODING_INDEX,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
712 XLFD_LAST_INDEX
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
713 };
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
714
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
715 /* An enumerator for mask bit corresponding to each XLFD field. */
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
716 enum xlfd_field_mask
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
717 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
718 XLFD_FOUNDRY_MASK = 0x0001,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
719 XLFD_FAMILY_MASK = 0x0002,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
720 XLFD_WEIGHT_MASK = 0x0004,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
721 XLFD_SLANT_MASK = 0x0008,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
722 XLFD_SWIDTH_MASK = 0x0010,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
723 XLFD_ADSTYLE_MASK = 0x0020,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
724 XLFD_PIXEL_MASK = 0x0040,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
725 XLFD_POINT_MASK = 0x0080,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
726 XLFD_RESX_MASK = 0x0100,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
727 XLFD_RESY_MASK = 0x0200,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
728 XLFD_SPACING_MASK = 0x0400,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
729 XLFD_AVGWIDTH_MASK = 0x0800,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
730 XLFD_REGISTRY_MASK = 0x1000,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
731 XLFD_ENCODING_MASK = 0x2000
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
732 };
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
733
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
734
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
735 /* Parse P pointing the pixel/point size field of the form
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
736 `[A B C D]' which specifies a transformation matrix:
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
737
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
738 A B 0
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
739 C D 0
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
740 0 0 1
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
741
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
742 by which all glyphs of the font are transformed. The spec says
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
743 that scalar value N for the pixel/point size is equivalent to:
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
744 A = N * resx/resy, B = C = 0, D = N.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
745
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
746 Return the scalar value N if the form is valid. Otherwise return
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
747 -1. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
748
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
749 static int
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
750 parse_matrix (p)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
751 char *p;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
752 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
753 double matrix[4];
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
754 char *end;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
755 int i;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
756
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
757 for (i = 0, p++; i < 4 && *p && *p != ']'; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
758 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
759 if (*p == '~')
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
760 matrix[i] = - strtod (p + 1, &end);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
761 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
762 matrix[i] = strtod (p, &end);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
763 p = end;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
764 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
765 return (i == 4 ? (int) matrix[3] : -1);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
766 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
767
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
768 /* Expand a wildcard field in FIELD (the first N fields are filled) to
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
769 multiple fields to fill in all 14 XLFD fields while restring a
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
770 field position by its contents. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
771
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
772 static int
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
773 font_expand_wildcards (field, n)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
774 Lisp_Object field[XLFD_LAST_INDEX];
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
775 int n;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
776 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
777 /* Copy of FIELD. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
778 Lisp_Object tmp[XLFD_LAST_INDEX];
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
779 /* Array of information about where this element can go. Nth
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
780 element is for Nth element of FIELD. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
781 struct {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
782 /* Minimum possible field. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
783 int from;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
784 /* Maxinum possible field. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
785 int to;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
786 /* Bit mask of possible field. Nth bit corresponds to Nth field. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
787 int mask;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
788 } range[XLFD_LAST_INDEX];
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
789 int i, j;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
790 int range_from, range_to;
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
791 unsigned range_mask;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
792
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
793 #define XLFD_SYMBOL_MASK (XLFD_FOUNDRY_MASK | XLFD_FAMILY_MASK \
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
794 | XLFD_ADSTYLE_MASK | XLFD_REGISTRY_MASK)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
795 #define XLFD_NULL_MASK (XLFD_FOUNDRY_MASK | XLFD_ADSTYLE_MASK)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
796 #define XLFD_LARGENUM_MASK (XLFD_POINT_MASK | XLFD_RESX_MASK | XLFD_RESY_MASK \
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
797 | XLFD_AVGWIDTH_MASK)
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
798 #define XLFD_REGENC_MASK (XLFD_REGISTRY_MASK | XLFD_ENCODING_MASK)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
799
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
800 /* Initialize RANGE_MASK for FIELD[0] which can be 0th to (14 - N)th
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
801 field. The value is shifted to left one bit by one in the
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
802 following loop. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
803 for (i = 0, range_mask = 0; i <= 14 - n; i++)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
804 range_mask = (range_mask << 1) | 1;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
805
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
806 /* The triplet RANGE_FROM, RANGE_TO, and RANGE_MASK is a
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
807 position-based retriction for FIELD[I]. */
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
808 for (i = 0, range_from = 0, range_to = 14 - n; i < n;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
809 i++, range_from++, range_to++, range_mask <<= 1)
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
810 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
811 Lisp_Object val = field[i];
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
812
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
813 tmp[i] = val;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
814 if (NILP (val))
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
815 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
816 /* Wildcard. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
817 range[i].from = range_from;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
818 range[i].to = range_to;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
819 range[i].mask = range_mask;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
820 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
821 else
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
822 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
823 /* The triplet FROM, TO, and MASK is a value-based
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
824 retriction for FIELD[I]. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
825 int from, to;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
826 unsigned mask;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
827
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
828 if (INTEGERP (val))
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
829 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
830 int numeric = XINT (val);
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
831
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
832 if (i + 1 == n)
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
833 from = to = XLFD_ENCODING_INDEX,
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
834 mask = XLFD_ENCODING_MASK;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
835 else if (numeric == 0)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
836 from = XLFD_PIXEL_INDEX, to = XLFD_AVGWIDTH_INDEX,
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
837 mask = XLFD_PIXEL_MASK | XLFD_LARGENUM_MASK;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
838 else if (numeric <= 48)
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
839 from = to = XLFD_PIXEL_INDEX,
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
840 mask = XLFD_PIXEL_MASK;
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
841 else
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
842 from = XLFD_POINT_INDEX, to = XLFD_AVGWIDTH_INDEX,
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
843 mask = XLFD_LARGENUM_MASK;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
844 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
845 else if (SBYTES (SYMBOL_NAME (val)) == 0)
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
846 from = XLFD_FOUNDRY_INDEX, to = XLFD_ADSTYLE_INDEX,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
847 mask = XLFD_NULL_MASK;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
848 else if (i == 0)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
849 from = to = XLFD_FOUNDRY_INDEX, mask = XLFD_FOUNDRY_MASK;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
850 else if (i + 1 == n)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
851 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
852 Lisp_Object name = SYMBOL_NAME (val);
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
853
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
854 if (SDATA (name)[SBYTES (name) - 1] == '*')
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
855 from = XLFD_REGISTRY_INDEX, to = XLFD_ENCODING_INDEX,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
856 mask = XLFD_REGENC_MASK;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
857 else
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
858 from = to = XLFD_ENCODING_INDEX,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
859 mask = XLFD_ENCODING_MASK;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
860 }
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
861 else if (range_from <= XLFD_WEIGHT_INDEX
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
862 && range_to >= XLFD_WEIGHT_INDEX
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
863 && FONT_WEIGHT_NAME_NUMERIC (val) >= 0)
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
864 from = to = XLFD_WEIGHT_INDEX, mask = XLFD_WEIGHT_MASK;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
865 else if (range_from <= XLFD_SLANT_INDEX
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
866 && range_to >= XLFD_SLANT_INDEX
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
867 && FONT_SLANT_NAME_NUMERIC (val) >= 0)
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
868 from = to = XLFD_SLANT_INDEX, mask = XLFD_SLANT_MASK;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
869 else if (range_from <= XLFD_SWIDTH_INDEX
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
870 && range_to >= XLFD_SWIDTH_INDEX
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
871 && FONT_WIDTH_NAME_NUMERIC (val) >= 0)
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
872 from = to = XLFD_SWIDTH_INDEX, mask = XLFD_SWIDTH_MASK;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
873 else
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
874 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
875 if (EQ (val, Qc) || EQ (val, Qm) || EQ (val, Qp) || EQ (val, Qd))
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
876 from = to = XLFD_SPACING_INDEX, mask = XLFD_SPACING_MASK;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
877 else
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
878 from = XLFD_FOUNDRY_INDEX, to = XLFD_ENCODING_INDEX,
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
879 mask = XLFD_SYMBOL_MASK;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
880 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
881
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
882 /* Merge position-based and value-based restrictions. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
883 mask &= range_mask;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
884 while (from < range_from)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
885 mask &= ~(1 << from++);
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
886 while (from < 14 && ! (mask & (1 << from)))
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
887 from++;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
888 while (to > range_to)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
889 mask &= ~(1 << to--);
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
890 while (to >= 0 && ! (mask & (1 << to)))
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
891 to--;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
892 if (from > to)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
893 return -1;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
894 range[i].from = from;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
895 range[i].to = to;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
896 range[i].mask = mask;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
897
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
898 if (from > range_from || to < range_to)
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
899 {
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
900 /* The range is narrowed by value-based restrictions.
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
901 Reflect it to the other fields. */
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
902
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
903 /* Following fields should be after FROM. */
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
904 range_from = from;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
905 /* Preceding fields should be before TO. */
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
906 for (j = i - 1, from--, to--; j >= 0; j--, from--, to--)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
907 {
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
908 /* Check FROM for non-wildcard field. */
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
909 if (! NILP (tmp[j]) && range[j].from < from)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
910 {
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
911 while (range[j].from < from)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
912 range[j].mask &= ~(1 << range[j].from++);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
913 while (from < 14 && ! (range[j].mask & (1 << from)))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
914 from++;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
915 range[j].from = from;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
916 }
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
917 else
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
918 from = range[j].from;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
919 if (range[j].to > to)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
920 {
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
921 while (range[j].to > to)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
922 range[j].mask &= ~(1 << range[j].to--);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
923 while (to >= 0 && ! (range[j].mask & (1 << to)))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
924 to--;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
925 range[j].to = to;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
926 }
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
927 else
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
928 to = range[j].to;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
929 if (from > to)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
930 return -1;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
931 }
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
932 }
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
933 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
934 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
935
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
936 /* Decide all fileds from restrictions in RANGE. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
937 for (i = j = 0; i < n ; i++)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
938 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
939 if (j < range[i].from)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
940 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
941 if (i == 0 || ! NILP (tmp[i - 1]))
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
942 /* None of TMP[X] corresponds to Jth field. */
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
943 return -1;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
944 for (; j < range[i].from; j++)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
945 field[j] = Qnil;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
946 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
947 field[j++] = tmp[i];
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
948 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
949 if (! NILP (tmp[n - 1]) && j < XLFD_REGISTRY_INDEX)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
950 return -1;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
951 for (; j < XLFD_LAST_INDEX; j++)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
952 field[j] = Qnil;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
953 if (INTEGERP (field[XLFD_ENCODING_INDEX]))
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
954 field[XLFD_ENCODING_INDEX]
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
955 = Fintern (Fnumber_to_string (field[XLFD_ENCODING_INDEX]), Qnil);
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
956 return 0;
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
957 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
958
92113
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
959
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
960 #ifdef ENABLE_CHECKING
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
961 /* Match a 14-field XLFD pattern against a full XLFD font name. */
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
962 static int
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
963 font_match_xlfd (char *pattern, char *name)
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
964 {
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
965 while (*pattern && *name)
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
966 {
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
967 if (*pattern == *name)
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
968 pattern++;
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
969 else if (*pattern == '*')
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
970 if (*name == pattern[1])
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
971 pattern += 2;
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
972 else
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
973 ;
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
974 else
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
975 return 0;
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
976 name++;
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
977 }
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
978 return 1;
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
979 }
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
980
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
981 /* Make sure the font object matches the XLFD font name. */
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
982 static int
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
983 font_check_xlfd_parse (Lisp_Object font, char *name)
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
984 {
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
985 char name_check[256];
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
986 font_unparse_xlfd (font, 0, name_check, 255);
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
987 return font_match_xlfd (name_check, name);
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
988 }
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
989
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
990 #endif
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
991
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
992
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
993 /* Parse NAME (null terminated) as XLFD and store information in FONT
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
994 (font-spec or font-entity). Size property of FONT is set as
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
995 follows:
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
996 specified XLFD fields FONT property
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
997 --------------------- -------------
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
998 PIXEL_SIZE PIXEL_SIZE (Lisp integer)
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
999 POINT_SIZE and RESY calculated pixel size (Lisp integer)
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1000 POINT_SIZE POINT_SIZE/10 (Lisp float)
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1001
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1002 If NAME is successfully parsed, return 0. Otherwise return -1.
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1003
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1004 FONT is usually a font-spec, but when this function is called from
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1005 X font backend driver, it is a font-entity. In that case, NAME is
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1006 a fully specified XLFD. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1007
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1008 int
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1009 font_parse_xlfd (name, font)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1010 char *name;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1011 Lisp_Object font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1012 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1013 int len = strlen (name);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1014 int i, j, n;
90695
a1cd7344d6a2 (font_parse_xlfd): Fix the array size of `f'.
Kenichi Handa <handa@m17n.org>
parents: 90677
diff changeset
1015 char *f[XLFD_LAST_INDEX + 1];
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1016 Lisp_Object val;
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1017 char *p;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1018
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1019 if (len > 255)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1020 /* Maximum XLFD name length is 255. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1021 return -1;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1022 /* Accept "*-.." as a fully specified XLFD. */
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1023 if (name[0] == '*' && name[1] == '-')
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1024 i = 1, f[XLFD_FOUNDRY_INDEX] = name;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1025 else
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1026 i = 0;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1027 for (p = name + i; *p; p++)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1028 if (*p == '-')
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1029 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1030 f[i++] = p + 1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1031 if (i == XLFD_LAST_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1032 break;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1033 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1034 f[i] = name + len;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1035
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1036 #define INTERN_FIELD(N) font_intern_prop (f[N], f[(N) + 1] - 1 - f[N])
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1037
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1038 if (i == XLFD_LAST_INDEX)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1039 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1040 /* Fully specified XLFD. */
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1041 int pixel_size;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1042
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1043 ASET (font, FONT_FOUNDRY_INDEX, INTERN_FIELD (XLFD_FOUNDRY_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1044 ASET (font, FONT_FAMILY_INDEX, INTERN_FIELD (XLFD_FAMILY_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1045 for (i = XLFD_WEIGHT_INDEX, j = FONT_WEIGHT_INDEX;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1046 i <= XLFD_SWIDTH_INDEX; i++, j++)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1047 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1048 val = INTERN_FIELD (i);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1049 if (! NILP (val))
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1050 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1051 if ((n = font_style_to_value (j, INTERN_FIELD (i), 0)) < 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1052 return -1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1053 ASET (font, j, make_number (n));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1054 }
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1055 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1056 ASET (font, FONT_ADSTYLE_INDEX, INTERN_FIELD (XLFD_ADSTYLE_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1057 if (strcmp (f[XLFD_REGISTRY_INDEX], "*-*") == 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1058 ASET (font, FONT_REGISTRY_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1059 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1060 ASET (font, FONT_REGISTRY_INDEX,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1061 font_intern_prop (f[XLFD_REGISTRY_INDEX],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1062 f[XLFD_LAST_INDEX] - f[XLFD_REGISTRY_INDEX]));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1063 p = f[XLFD_PIXEL_INDEX];
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1064 if (*p == '[' && (pixel_size = parse_matrix (p)) >= 0)
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
1065 ASET (font, FONT_SIZE_INDEX, make_number (pixel_size));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1066 else
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1067 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1068 val = INTERN_FIELD (XLFD_PIXEL_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1069 if (INTEGERP (val))
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1070 ASET (font, FONT_SIZE_INDEX, val);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1071 else
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1072 {
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1073 double point_size = -1;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1074
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1075 font_assert (FONT_SPEC_P (font));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1076 p = f[XLFD_POINT_INDEX];
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1077 if (*p == '[')
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1078 point_size = parse_matrix (p);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1079 else if (isdigit (*p))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1080 point_size = atoi (p), point_size /= 10;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1081 if (point_size >= 0)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1082 ASET (font, FONT_SIZE_INDEX, make_float (point_size));
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1083 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1084 }
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1085
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1086 ASET (font, FONT_DPI_INDEX, INTERN_FIELD (XLFD_RESY_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1087 val = INTERN_FIELD (XLFD_SPACING_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1088 if (! NILP (val))
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1089 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1090 val = font_prop_validate_spacing (QCspacing, val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1091 if (! INTEGERP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1092 return -1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1093 ASET (font, FONT_SPACING_INDEX, val);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1094 }
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1095 p = f[XLFD_AVGWIDTH_INDEX];
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1096 if (*p == '~')
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1097 p++;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1098 ASET (font, FONT_AVGWIDTH_INDEX,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1099 font_intern_prop (p, f[XLFD_REGISTRY_INDEX] - 1 - p));
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1100 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1101 else
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1102 {
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1103 int wild_card_found = 0;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1104 Lisp_Object prop[XLFD_LAST_INDEX];
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1105
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1106 if (FONT_ENTITY_P (font))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1107 return -1;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1108 for (j = 0; j < i; j++)
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1109 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1110 if (*f[j] == '*')
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1111 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1112 if (f[j][1] && f[j][1] != '-')
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1113 return -1;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1114 prop[j] = Qnil;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1115 wild_card_found = 1;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1116 }
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1117 else if (j + 1 < i)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1118 prop[j] = INTERN_FIELD (j);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1119 else
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1120 prop[j] = font_intern_prop (f[j], f[i] - f[j]);
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1121 }
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1122 if (! wild_card_found)
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1123 return -1;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1124 if (font_expand_wildcards (prop, i) < 0)
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1125 return -1;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1126
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1127 ASET (font, FONT_FOUNDRY_INDEX, prop[XLFD_FOUNDRY_INDEX]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1128 ASET (font, FONT_FAMILY_INDEX, prop[XLFD_FAMILY_INDEX]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1129 for (i = XLFD_WEIGHT_INDEX, j = FONT_WEIGHT_INDEX;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1130 i <= XLFD_SWIDTH_INDEX; i++, j++)
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1131 if (! NILP (prop[i]))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1132 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1133 if ((n = font_style_to_value (j, prop[i], 1)) < 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1134 return -1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1135 ASET (font, j, make_number (n));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1136 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1137 ASET (font, FONT_ADSTYLE_INDEX, prop[XLFD_ADSTYLE_INDEX]);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1138 val = prop[XLFD_REGISTRY_INDEX];
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1139 if (NILP (val))
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1140 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1141 val = prop[XLFD_ENCODING_INDEX];
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1142 if (! NILP (val))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1143 val = concat2 (build_string ("*-"), SYMBOL_NAME (val));
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1144 }
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1145 else if (NILP (prop[XLFD_ENCODING_INDEX]))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1146 val = concat2 (SYMBOL_NAME (val), build_string ("-*"));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1147 else
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1148 val = concat3 (SYMBOL_NAME (val), build_string ("-"),
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1149 SYMBOL_NAME (prop[XLFD_ENCODING_INDEX]));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1150 if (! NILP (val))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1151 ASET (font, FONT_REGISTRY_INDEX, Fintern (val, Qnil));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1152
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1153 if (INTEGERP (prop[XLFD_PIXEL_INDEX]))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1154 ASET (font, FONT_SIZE_INDEX, prop[XLFD_PIXEL_INDEX]);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1155 else if (INTEGERP (prop[XLFD_POINT_INDEX]))
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1156 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1157 double point_size = XINT (prop[XLFD_POINT_INDEX]);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1158
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1159 ASET (font, FONT_SIZE_INDEX, make_float (point_size / 10));
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1160 }
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1161
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1162 if (INTEGERP (prop[XLFD_RESX_INDEX]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1163 ASET (font, FONT_DPI_INDEX, prop[XLFD_RESY_INDEX]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1164 if (! NILP (prop[XLFD_SPACING_INDEX]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1165 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1166 val = font_prop_validate_spacing (QCspacing,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1167 prop[XLFD_SPACING_INDEX]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1168 if (! INTEGERP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1169 return -1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1170 ASET (font, FONT_SPACING_INDEX, val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1171 }
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1172 if (INTEGERP (prop[XLFD_AVGWIDTH_INDEX]))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1173 ASET (font, FONT_AVGWIDTH_INDEX, prop[XLFD_AVGWIDTH_INDEX]);
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
1174 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1175
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1176 return 0;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1177 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1178
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1179 /* Store XLFD name of FONT (font-spec or font-entity) in NAME (NBYTES
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1180 length), and return the name length. If FONT_SIZE_INDEX of FONT is
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1181 0, use PIXEL_SIZE instead. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1182
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1183 int
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1184 font_unparse_xlfd (font, pixel_size, name, nbytes)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1185 Lisp_Object font;
90439
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1186 int pixel_size;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1187 char *name;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1188 int nbytes;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1189 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1190 char *f[XLFD_REGISTRY_INDEX + 1];
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1191 Lisp_Object val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1192 int i, j, len = 0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1193
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1194 font_assert (FONTP (font));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1195
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1196 for (i = FONT_FOUNDRY_INDEX, j = XLFD_FOUNDRY_INDEX; i <= FONT_REGISTRY_INDEX;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1197 i++, j++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1198 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1199 if (i == FONT_ADSTYLE_INDEX)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1200 j = XLFD_ADSTYLE_INDEX;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1201 else if (i == FONT_REGISTRY_INDEX)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1202 j = XLFD_REGISTRY_INDEX;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1203 val = AREF (font, i);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1204 if (NILP (val))
90439
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1205 {
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1206 if (j == XLFD_REGISTRY_INDEX)
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1207 f[j] = "*-*", len += 4;
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1208 else
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1209 f[j] = "*", len += 2;
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1210 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1211 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1212 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1213 if (SYMBOLP (val))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1214 val = SYMBOL_NAME (val);
90439
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1215 if (j == XLFD_REGISTRY_INDEX
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1216 && ! strchr ((char *) SDATA (val), '-'))
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1217 {
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1218 /* Change "jisx0208*" and "jisx0208" to "jisx0208*-*". */
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1219 if (SDATA (val)[SBYTES (val) - 1] == '*')
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1220 {
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1221 f[j] = alloca (SBYTES (val) + 3);
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1222 sprintf (f[j], "%s-*", SDATA (val));
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1223 len += SBYTES (val) + 3;
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1224 }
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1225 else
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1226 {
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1227 f[j] = alloca (SBYTES (val) + 4);
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1228 sprintf (f[j], "%s*-*", SDATA (val));
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1229 len += SBYTES (val) + 4;
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1230 }
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1231 }
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1232 else
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
1233 f[j] = (char *) SDATA (val), len += SBYTES (val) + 1;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1234 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1235 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1236
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1237 for (i = FONT_WEIGHT_INDEX, j = XLFD_WEIGHT_INDEX; i <= FONT_WIDTH_INDEX;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1238 i++, j++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1239 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1240 val = font_style_symbolic (font, i, 0);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1241 if (NILP (val))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1242 f[j] = "*", len += 2;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1243 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1244 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1245 val = SYMBOL_NAME (val);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1246 f[j] = (char *) SDATA (val), len += SBYTES (val) + 1;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1247 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1248 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1249
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1250 val = AREF (font, FONT_SIZE_INDEX);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1251 font_assert (NUMBERP (val) || NILP (val));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1252 if (INTEGERP (val))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1253 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1254 i = XINT (val);
91943
c5e5ad126614 (font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91909
diff changeset
1255 if (i <= 0)
c5e5ad126614 (font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91909
diff changeset
1256 i = pixel_size;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1257 if (i > 0)
91943
c5e5ad126614 (font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91909
diff changeset
1258 {
c5e5ad126614 (font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91909
diff changeset
1259 f[XLFD_PIXEL_INDEX] = alloca (22);
c5e5ad126614 (font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91909
diff changeset
1260 len += sprintf (f[XLFD_PIXEL_INDEX], "%d-*", i) + 1;
c5e5ad126614 (font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91909
diff changeset
1261 }
c5e5ad126614 (font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91909
diff changeset
1262 else
c5e5ad126614 (font_unparse_xlfd): Don't ignore integer pixel size specs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91909
diff changeset
1263 f[XLFD_PIXEL_INDEX] = "*-*", len += 4;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1264 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1265 else if (FLOATP (val))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1266 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1267 i = XFLOAT_DATA (val) * 10;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1268 f[XLFD_PIXEL_INDEX] = alloca (12);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1269 len += sprintf (f[XLFD_PIXEL_INDEX], "*-%d", i) + 1;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1270 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1271 else
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1272 f[XLFD_PIXEL_INDEX] = "*-*", len += 4;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1273
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1274 if (INTEGERP (AREF (font, FONT_DPI_INDEX)))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1275 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1276 i = XINT (AREF (font, FONT_DPI_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1277 f[XLFD_RESX_INDEX] = alloca (22);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1278 len += sprintf (f[XLFD_RESX_INDEX],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1279 "%d-%d", i, i) + 1;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1280 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1281 else
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1282 f[XLFD_RESX_INDEX] = "*-*", len += 4;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1283 if (INTEGERP (AREF (font, FONT_SPACING_INDEX)))
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1284 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1285 int spacing = XINT (AREF (font, FONT_SPACING_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1286
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1287 f[XLFD_SPACING_INDEX] = (spacing <= FONT_SPACING_PROPORTIONAL ? "p"
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1288 : spacing <= FONT_SPACING_DUAL ? "d"
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1289 : spacing <= FONT_SPACING_MONO ? "m"
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1290 : "c");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1291 len += 2;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1292 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1293 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1294 f[XLFD_SPACING_INDEX] = "*", len += 2;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1295 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1296 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1297 f[XLFD_AVGWIDTH_INDEX] = alloca (11);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1298 len += sprintf (f[XLFD_AVGWIDTH_INDEX],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1299 "%d", XINT (AREF (font, FONT_AVGWIDTH_INDEX))) + 1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1300 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1301 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1302 f[XLFD_AVGWIDTH_INDEX] = "*", len += 2;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1303 len++; /* for terminating '\0'. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1304 if (len >= nbytes)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1305 return -1;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1306 return sprintf (name, "-%s-%s-%s-%s-%s-%s-%s-%s-%s-%s-%s",
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1307 f[XLFD_FOUNDRY_INDEX], f[XLFD_FAMILY_INDEX],
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1308 f[XLFD_WEIGHT_INDEX], f[XLFD_SLANT_INDEX],
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1309 f[XLFD_SWIDTH_INDEX], f[XLFD_ADSTYLE_INDEX],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1310 f[XLFD_PIXEL_INDEX], f[XLFD_RESX_INDEX],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1311 f[XLFD_SPACING_INDEX], f[XLFD_AVGWIDTH_INDEX],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1312 f[XLFD_REGISTRY_INDEX]);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1313 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1314
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1315 /* Parse NAME (null terminated) as Fonconfig's name format and store
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1316 information in FONT (font-spec or font-entity). If NAME is
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1317 successfully parsed, return 0. Otherwise return -1. */
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1318
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1319 int
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1320 font_parse_fcname (name, font)
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1321 char *name;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1322 Lisp_Object font;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1323 {
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1324 char *p0, *p1;
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1325 int len = strlen (name);
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1326 char *copy;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1327
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1328 if (len == 0)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1329 return -1;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1330 /* It is assured that (name[0] && name[0] != '-'). */
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1331 if (name[0] == ':')
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1332 p0 = name;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1333 else
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1334 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1335 Lisp_Object family;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1336 double point_size;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1337
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1338 for (p0 = name + 1; *p0 && (*p0 != '-' && *p0 != ':'); p0++)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1339 if (*p0 == '\\' && p0[1])
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1340 p0++;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1341 family = font_intern_prop (name, p0 - name);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1342 if (*p0 == '-')
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1343 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1344 if (! isdigit (p0[1]))
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1345 return -1;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1346 point_size = strtod (p0 + 1, &p1);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1347 if (*p1 && *p1 != ':')
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1348 return -1;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1349 ASET (font, FONT_SIZE_INDEX, make_float (point_size));
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1350 p0 = p1;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1351 }
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1352 ASET (font, FONT_FAMILY_INDEX, family);
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1353 }
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1354
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1355 len -= p0 - name;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1356 copy = alloca (len + 1);
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1357 if (! copy)
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1358 return -1;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1359 name = copy;
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
1360
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1361 /* Now parse ":KEY=VAL" patterns. Store known keys and values in
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1362 extra, copy unknown ones to COPY. It is stored in extra slot by
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1363 the key QCfc_unknown_spec. */
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1364 while (*p0)
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1365 {
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1366 Lisp_Object key, val;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1367 int prop;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1368
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1369 for (p1 = p0 + 1; *p1 && *p1 != '=' && *p1 != ':'; p1++);
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1370 if (*p1 != '=')
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1371 {
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1372 /* Must be an enumerated value. */
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1373 val = font_intern_prop (p0 + 1, p1 - p0 - 1);
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1374 if (memcmp (p0 + 1, "light", 5) == 0
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1375 || memcmp (p0 + 1, "medium", 6) == 0
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1376 || memcmp (p0 + 1, "demibold", 8) == 0
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1377 || memcmp (p0 + 1, "bold", 4) == 0
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1378 || memcmp (p0 + 1, "black", 5) == 0)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1379 FONT_SET_STYLE (font, FONT_WEIGHT_INDEX, val);
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1380 else if (memcmp (p0 + 1, "roman", 5) == 0
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1381 || memcmp (p0 + 1, "italic", 6) == 0
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1382 || memcmp (p0 + 1, "oblique", 7) == 0)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1383 FONT_SET_STYLE (font, FONT_SLANT_INDEX, val);
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1384 else if (memcmp (p0 + 1, "charcell", 8) == 0
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1385 || memcmp (p0 + 1, "mono", 4) == 0
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1386 || memcmp (p0 + 1, "proportional", 12) == 0)
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1387 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1388 int spacing = (p0[1] == 'c' ? FONT_SPACING_CHARCELL
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1389 : p0[1] == 'm' ? FONT_SPACING_MONO
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1390 : FONT_SPACING_PROPORTIONAL);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1391 ASET (font, FONT_SPACING_INDEX, make_number (spacing));
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
1392 }
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1393 else
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1394 {
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1395 /* unknown key */
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1396 bcopy (p0, copy, p1 - p0);
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1397 copy += p1 - p0;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1398 }
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1399 }
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1400 else
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1401 {
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1402 if (memcmp (p0 + 1, "pixelsize=", 10) == 0)
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1403 prop = FONT_SIZE_INDEX;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1404 else
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1405 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1406 key = font_intern_prop (p0, p1 - p0);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1407 prop = get_font_prop_index (key);
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1408 }
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1409 p0 = p1 + 1;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1410 for (p1 = p0; *p1 && *p1 != ':'; p1++);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1411 val = font_intern_prop (p0, p1 - p0);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1412 if (! NILP (val))
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1413 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1414 if (prop >= FONT_FOUNDRY_INDEX && prop < FONT_EXTRA_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1415 ASET (font, prop, font_prop_validate (prop, Qnil, val));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1416 else if (prop >= 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1417 Ffont_put (font, key, val);
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1418 else
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1419 bcopy (p0 - 1, copy, p1 - p0 + 1);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1420 copy += p1 - p0 + 1;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1421 }
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1422 }
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1423 p0 = p1;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1424 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1425 if (name != copy)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1426 font_put_extra (font, QCfc_unknown_spec,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1427 make_unibyte_string (name, copy - name));
91261
2e5bb6a0a787 (font_parse_fcname): Default weight and slant to normal.
Jason Rumney <jasonr@gnu.org>
parents: 91247
diff changeset
1428
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1429 return 0;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1430 }
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1431
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1432 /* Store fontconfig's font name of FONT (font-spec or font-entity) in
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1433 NAME (NBYTES length), and return the name length. If
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1434 FONT_SIZE_INDEX of FONT is 0, use PIXEL_SIZE instead. */
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1435
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1436 int
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1437 font_unparse_fcname (font, pixel_size, name, nbytes)
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1438 Lisp_Object font;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1439 int pixel_size;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1440 char *name;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1441 int nbytes;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1442 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1443 Lisp_Object tail, val;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1444 int point_size;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1445 int dpi;
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1446 int i, len = 1;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1447 char *p;
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
1448 Lisp_Object styles[3];
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
1449 char *style_names[3] = { "weight", "slant", "width" };
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1450 char work[256];
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1451
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1452 val = AREF (font, FONT_FAMILY_INDEX);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1453 if (STRINGP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1454 len += SBYTES (val);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1455
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1456 val = AREF (font, FONT_SIZE_INDEX);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1457 if (INTEGERP (val))
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1458 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1459 if (XINT (val) != 0)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1460 pixel_size = XINT (val);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1461 point_size = -1;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1462 len += 21; /* for ":pixelsize=NUM" */
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1463 }
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1464 else if (FLOATP (val))
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1465 {
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1466 pixel_size = -1;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1467 point_size = (int) XFLOAT_DATA (val);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1468 len += 11; /* for "-NUM" */
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1469 }
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1470
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1471 val = AREF (font, FONT_FOUNDRY_INDEX);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1472 if (STRINGP (val))
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1473 /* ":foundry=NAME" */
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1474 len += 9 + SBYTES (val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1475
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1476 for (i = 0; i < 3; i++)
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1477 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1478 styles[i] = font_style_symbolic (font, FONT_WEIGHT_INDEX + i, 0);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1479 if (! NILP (styles[i]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1480 len += sprintf (work, ":%s=%s", style_names[i],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1481 SDATA (SYMBOL_NAME (styles[i])));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1482 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1483
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1484 if (INTEGERP (AREF (font, FONT_DPI_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1485 len += sprintf (work, ":dpi=%d", dpi);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1486 if (INTEGERP (AREF (font, FONT_SPACING_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1487 len += strlen (":spacing=100");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1488 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1489 len += strlen (":scalable=false"); /* or ":scalable=true" */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1490 for (tail = AREF (font, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail))
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1491 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1492 Lisp_Object key = XCAR (XCAR (tail)), val = XCDR (XCAR (tail));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1493
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1494 len += SBYTES (SYMBOL_NAME (key)) + 1; /* for :KEY= */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1495 if (STRINGP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1496 len += SBYTES (val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1497 else if (INTEGERP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1498 len += sprintf (work, "%d", XINT (val));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1499 else if (SYMBOLP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1500 len += (NILP (val) ? 5 : 4); /* for "false" or "true" */
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1501 }
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1502
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1503 if (len > nbytes)
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1504 return -1;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1505 p = name;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1506 if (! NILP (AREF (font, FONT_FAMILY_INDEX)))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1507 p += sprintf(p, "%s", SDATA (SYMBOL_NAME (AREF (font, FONT_FAMILY_INDEX))));
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1508 if (point_size > 0)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1509 {
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1510 if (p == name)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1511 p += sprintf (p, "%d", point_size);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1512 else
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1513 p += sprintf (p, "-%d", point_size);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1514 }
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1515 else if (pixel_size > 0)
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1516 p += sprintf (p, ":pixelsize=%d", pixel_size);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1517 if (! NILP (AREF (font, FONT_FOUNDRY_INDEX)))
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
1518 p += sprintf (p, ":foundry=%s",
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
1519 SDATA (SYMBOL_NAME (AREF (font, FONT_FOUNDRY_INDEX))));
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
1520 for (i = 0; i < 3; i++)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1521 if (! NILP (styles[i]))
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
1522 p += sprintf (p, ":%s=%s", style_names[i],
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1523 SDATA (SYMBOL_NAME (styles[i])));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1524 if (INTEGERP (AREF (font, FONT_DPI_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1525 p += sprintf (p, ":dpi=%d", XINT (AREF (font, FONT_DPI_INDEX)));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1526 if (INTEGERP (AREF (font, FONT_SPACING_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1527 p += sprintf (p, ":spacing=%d", XINT (AREF (font, FONT_SPACING_INDEX)));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1528 if (INTEGERP (AREF (font, FONT_AVGWIDTH_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1529 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1530 if (XINT (AREF (font, FONT_AVGWIDTH_INDEX)) == 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1531 p += sprintf (p, ":scalable=true");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1532 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1533 p += sprintf (p, ":scalable=false");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1534 }
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1535 return (p - name);
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1536 }
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1537
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1538 /* Parse NAME (null terminated) and store information in FONT
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1539 (font-spec or font-entity). If NAME is successfully parsed, return
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1540 0. Otherwise return -1. */
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1541
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1542 static int
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1543 font_parse_name (name, font)
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1544 char *name;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1545 Lisp_Object font;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1546 {
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1547 if (name[0] == '-' || index (name, '*'))
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1548 return font_parse_xlfd (name, font);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
1549 return font_parse_fcname (name, font);
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1550 }
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
1551
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1552
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1553 /* Merge FAMILY and REGISTRY into FONT_SPEC. FAMILY may have the form
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1554 "FAMILY-FOUNDRY". REGISTRY may not contain charset-encoding
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1555 part. */
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
1556
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1557 void
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1558 font_parse_family_registry (family, registry, font_spec)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1559 Lisp_Object family, registry, font_spec;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1560 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1561 int len;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1562 char *p0, *p1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1563
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1564 if (! NILP (family)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1565 && NILP (AREF (font_spec, FONT_FAMILY_INDEX)))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1566 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1567 CHECK_STRING (family);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1568 len = SBYTES (family);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1569 p0 = (char *) SDATA (family);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1570 p1 = index (p0, '-');
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1571 if (p1)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1572 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1573 if ((*p0 != '*' || p1 - p0 > 1)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1574 && NILP (AREF (font_spec, FONT_FOUNDRY_INDEX)))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1575 ASET (font_spec, FONT_FOUNDRY_INDEX,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1576 font_intern_prop (p0, p1 - p0));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1577 p1++;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1578 len -= p1 - p0;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1579 ASET (font_spec, FONT_FAMILY_INDEX, font_intern_prop (p1, len));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1580 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1581 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1582 ASET (font_spec, FONT_FAMILY_INDEX, Fintern (family, Qnil));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1583 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1584 if (! NILP (registry))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1585 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1586 /* Convert "XXX" and "XXX*" to "XXX*-*". */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1587 CHECK_STRING (registry);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1588 len = SBYTES (registry);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1589 p0 = (char *) SDATA (registry);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1590 p1 = index (p0, '-');
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1591 if (! p1)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1592 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1593 if (SDATA (registry)[len - 1] == '*')
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1594 registry = concat2 (registry, build_string ("-*"));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1595 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1596 registry = concat2 (registry, build_string ("*-*"));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1597 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1598 registry = Fdowncase (registry);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1599 ASET (font_spec, FONT_REGISTRY_INDEX, Fintern (registry, Qnil));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1600 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1601 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1602
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
1603
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1604 /* This part (through the next ^L) is still experimental and not
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1605 tested much. We may drastically change codes. */
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
1606
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
1607 /* OTF handler */
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
1608
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1609 #define LGSTRING_HEADER_SIZE 6
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1610 #define LGSTRING_GLYPH_SIZE 8
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1611
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1612 static int
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1613 check_gstring (gstring)
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1614 Lisp_Object gstring;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1615 {
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1616 Lisp_Object val;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1617 int i, j;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1618
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1619 CHECK_VECTOR (gstring);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1620 val = AREF (gstring, 0);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1621 CHECK_VECTOR (val);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1622 if (ASIZE (val) < LGSTRING_HEADER_SIZE)
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1623 goto err;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1624 CHECK_FONT_OBJECT (LGSTRING_FONT (gstring));
91550
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1625 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_LBEARING)))
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1626 CHECK_NUMBER (LGSTRING_SLOT (gstring, LGSTRING_IX_LBEARING));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1627 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_RBEARING)))
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1628 CHECK_NUMBER (LGSTRING_SLOT (gstring, LGSTRING_IX_RBEARING));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1629 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_WIDTH)))
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1630 CHECK_NATNUM (LGSTRING_SLOT (gstring, LGSTRING_IX_WIDTH));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1631 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_ASCENT)))
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1632 CHECK_NUMBER (LGSTRING_SLOT (gstring, LGSTRING_IX_ASCENT));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1633 if (!NILP (LGSTRING_SLOT (gstring, LGSTRING_IX_ASCENT)))
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1634 CHECK_NUMBER (LGSTRING_SLOT (gstring, LGSTRING_IX_ASCENT));
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1635
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1636 for (i = 0; i < LGSTRING_LENGTH (gstring); i++)
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1637 {
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1638 val = LGSTRING_GLYPH (gstring, i);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1639 CHECK_VECTOR (val);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1640 if (ASIZE (val) < LGSTRING_GLYPH_SIZE)
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1641 goto err;
91550
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1642 if (NILP (AREF (val, LGLYPH_IX_CHAR)))
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1643 break;
91550
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1644 CHECK_NATNUM (AREF (val, LGLYPH_IX_FROM));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1645 CHECK_NATNUM (AREF (val, LGLYPH_IX_TO));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1646 CHECK_CHARACTER (AREF (val, LGLYPH_IX_CHAR));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1647 if (!NILP (AREF (val, LGLYPH_IX_CODE)))
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1648 CHECK_NATNUM (AREF (val, LGLYPH_IX_CODE));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1649 if (!NILP (AREF (val, LGLYPH_IX_WIDTH)))
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1650 CHECK_NATNUM (AREF (val, LGLYPH_IX_WIDTH));
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1651 if (!NILP (AREF (val, LGLYPH_IX_ADJUSTMENT)))
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1652 {
91550
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
1653 val = AREF (val, LGLYPH_IX_ADJUSTMENT);
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1654 CHECK_VECTOR (val);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1655 if (ASIZE (val) < 3)
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1656 goto err;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1657 for (j = 0; j < 3; j++)
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1658 CHECK_NUMBER (AREF (val, j));
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1659 }
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1660 }
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1661 return i;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1662 err:
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1663 error ("Invalid glyph-string format");
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1664 return -1;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1665 }
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
1666
90823
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1667 static void
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1668 check_otf_features (otf_features)
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1669 Lisp_Object otf_features;
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1670 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1671 Lisp_Object val;
90823
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1672
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1673 CHECK_CONS (otf_features);
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1674 CHECK_SYMBOL (XCAR (otf_features));
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1675 otf_features = XCDR (otf_features);
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1676 CHECK_CONS (otf_features);
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1677 CHECK_SYMBOL (XCAR (otf_features));
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1678 otf_features = XCDR (otf_features);
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1679 for (val = Fcar (otf_features); ! NILP (val); val = Fcdr (val))
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1680 {
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1681 CHECK_SYMBOL (Fcar (val));
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1682 if (SBYTES (SYMBOL_NAME (XCAR (val))) > 4)
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1683 error ("Invalid OTF GSUB feature: %s", SYMBOL_NAME (XCAR (val)));
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1684 }
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1685 otf_features = XCDR (otf_features);
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1686 for (val = Fcar (otf_features); ! NILP (val); val = Fcdr (val))
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1687 {
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1688 CHECK_SYMBOL (Fcar (val));
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1689 if (SBYTES (SYMBOL_NAME (XCAR (val))) > 4)
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1690 error ("Invalid OTF GPOS feature: %s", SYMBOL_NAME (XCAR (val)));
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1691 }
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1692 }
b08ad368c328 (check_otf_features): Define it regardless of
Kenichi Handa <handa@m17n.org>
parents: 90817
diff changeset
1693
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1694 #ifdef HAVE_LIBOTF
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1695 #include <otf.h>
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1696
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1697 Lisp_Object otf_list;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1698
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1699 static Lisp_Object
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1700 otf_tag_symbol (tag)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1701 OTF_Tag tag;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1702 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1703 char name[5];
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1704
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1705 OTF_tag_name (tag, name);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1706 return Fintern (make_unibyte_string (name, 4), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1707 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1708
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1709 static OTF *
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1710 otf_open (file)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1711 Lisp_Object file;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1712 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1713 Lisp_Object val = Fassoc (file, otf_list);
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1714 OTF *otf;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1715
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1716 if (! NILP (val))
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1717 otf = XSAVE_VALUE (XCDR (val))->pointer;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1718 else
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1719 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1720 otf = STRINGP (file) ? OTF_open ((char *) SDATA (file)) : NULL;
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1721 val = make_save_value (otf, 0);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1722 otf_list = Fcons (Fcons (file, val), otf_list);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1723 }
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1724 return otf;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1725 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1726
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1727
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1728 /* Return a list describing which scripts/languages FONT supports by
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1729 which GSUB/GPOS features of OpenType tables. See the comment of
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
1730 (struct font_driver).otf_capability. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1731
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1732 Lisp_Object
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1733 font_otf_capability (font)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1734 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1735 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1736 OTF *otf;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1737 Lisp_Object capability = Fcons (Qnil, Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1738 int i;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1739
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1740 otf = otf_open (font->props[FONT_FILE_INDEX]);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1741 if (! otf)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1742 return Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1743 for (i = 0; i < 2; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1744 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1745 OTF_GSUB_GPOS *gsub_gpos;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1746 Lisp_Object script_list = Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1747 int j;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1748
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1749 if (OTF_get_features (otf, i == 0) < 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1750 continue;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1751 gsub_gpos = i == 0 ? otf->gsub : otf->gpos;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1752 for (j = gsub_gpos->ScriptList.ScriptCount - 1; j >= 0; j--)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1753 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1754 OTF_Script *script = gsub_gpos->ScriptList.Script + j;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1755 Lisp_Object langsys_list = Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1756 Lisp_Object script_tag = otf_tag_symbol (script->ScriptTag);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1757 int k;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1758
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1759 for (k = script->LangSysCount; k >= 0; k--)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1760 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1761 OTF_LangSys *langsys;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1762 Lisp_Object feature_list = Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1763 Lisp_Object langsys_tag;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1764 int l;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1765
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1766 if (k == script->LangSysCount)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1767 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1768 langsys = &script->DefaultLangSys;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1769 langsys_tag = Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1770 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1771 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1772 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1773 langsys = script->LangSys + k;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1774 langsys_tag
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1775 = otf_tag_symbol (script->LangSysRecord[k].LangSysTag);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1776 }
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1777 for (l = langsys->FeatureCount - 1; l >= 0; l--)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1778 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1779 OTF_Feature *feature
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1780 = gsub_gpos->FeatureList.Feature + langsys->FeatureIndex[l];
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1781 Lisp_Object feature_tag
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1782 = otf_tag_symbol (feature->FeatureTag);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1783
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1784 feature_list = Fcons (feature_tag, feature_list);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1785 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1786 langsys_list = Fcons (Fcons (langsys_tag, feature_list),
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1787 langsys_list);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1788 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1789 script_list = Fcons (Fcons (script_tag, langsys_list),
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1790 script_list);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1791 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1792
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1793 if (i == 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1794 XSETCAR (capability, script_list);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1795 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1796 XSETCDR (capability, script_list);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1797 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1798
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1799 return capability;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1800 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1801
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1802 /* Parse OTF features in SPEC and write a proper features spec string
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1803 in FEATURES for the call of OTF_drive_gsub/gpos (of libotf). It is
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1804 assured that the sufficient memory has already allocated for
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1805 FEATURES. */
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1806
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1807 static void
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1808 generate_otf_features (spec, features)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1809 Lisp_Object spec;
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1810 char *features;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1811 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1812 Lisp_Object val;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1813 char *p;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1814 int asterisk;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1815
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1816 p = features;
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1817 *p = '\0';
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1818 for (asterisk = 0; CONSP (spec); spec = XCDR (spec))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1819 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1820 val = XCAR (spec);
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1821 CHECK_SYMBOL (val);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1822 if (p > features)
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1823 *p++ = ',';
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1824 if (SREF (SYMBOL_NAME (val), 0) == '*')
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1825 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1826 asterisk = 1;
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1827 *p++ = '*';
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1828 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1829 else if (! asterisk)
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1830 {
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1831 val = SYMBOL_NAME (val);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1832 p += sprintf (p, "%s", SDATA (val));
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1833 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1834 else
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1835 {
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1836 val = SYMBOL_NAME (val);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1837 p += sprintf (p, "~%s", SDATA (val));
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1838 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1839 }
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1840 if (CONSP (spec))
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1841 error ("OTF spec too long");
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1842 }
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1843
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1844
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1845 Lisp_Object
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1846 font_otf_DeviceTable (device_table)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1847 OTF_DeviceTable *device_table;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1848 {
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1849 int len = device_table->StartSize - device_table->EndSize + 1;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1850
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1851 return Fcons (make_number (len),
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1852 make_unibyte_string (device_table->DeltaValue, len));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1853 }
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1854
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1855 Lisp_Object
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1856 font_otf_ValueRecord (value_format, value_record)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1857 int value_format;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1858 OTF_ValueRecord *value_record;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1859 {
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1860 Lisp_Object val = Fmake_vector (make_number (8), Qnil);
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1861
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1862 if (value_format & OTF_XPlacement)
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
1863 ASET (val, 0, make_number (value_record->XPlacement));
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1864 if (value_format & OTF_YPlacement)
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
1865 ASET (val, 1, make_number (value_record->YPlacement));
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1866 if (value_format & OTF_XAdvance)
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
1867 ASET (val, 2, make_number (value_record->XAdvance));
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1868 if (value_format & OTF_YAdvance)
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
1869 ASET (val, 3, make_number (value_record->YAdvance));
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1870 if (value_format & OTF_XPlaDevice)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1871 ASET (val, 4, font_otf_DeviceTable (&value_record->XPlaDevice));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1872 if (value_format & OTF_YPlaDevice)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1873 ASET (val, 4, font_otf_DeviceTable (&value_record->YPlaDevice));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1874 if (value_format & OTF_XAdvDevice)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1875 ASET (val, 4, font_otf_DeviceTable (&value_record->XAdvDevice));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1876 if (value_format & OTF_YAdvDevice)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1877 ASET (val, 4, font_otf_DeviceTable (&value_record->YAdvDevice));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1878 return val;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1879 }
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1880
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1881 Lisp_Object
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1882 font_otf_Anchor (anchor)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1883 OTF_Anchor *anchor;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1884 {
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1885 Lisp_Object val;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1886
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1887 val = Fmake_vector (make_number (anchor->AnchorFormat + 1), Qnil);
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1888 ASET (val, 0, make_number (anchor->XCoordinate));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1889 ASET (val, 1, make_number (anchor->YCoordinate));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1890 if (anchor->AnchorFormat == 2)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1891 ASET (val, 2, make_number (anchor->f.f1.AnchorPoint));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1892 else
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1893 {
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1894 ASET (val, 3, font_otf_DeviceTable (&anchor->f.f2.XDeviceTable));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1895 ASET (val, 4, font_otf_DeviceTable (&anchor->f.f2.YDeviceTable));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1896 }
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1897 return val;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1898 }
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
1899
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1900 #endif /* HAVE_LIBOTF */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1901
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1902 /* G-string (glyph string) handler */
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1903
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1904 /* G-string is a vector of the form [HEADER GLYPH ...].
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
1905 See the docstring of `font-make-gstring' for more detail. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1906
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1907 struct font *
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1908 font_prepare_composition (cmp, f)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1909 struct composition *cmp;
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1910 FRAME_PTR f;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1911 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1912 Lisp_Object gstring
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1913 = AREF (XHASH_TABLE (composition_hash_table)->key_and_value,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1914 cmp->hash_index * 2);
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1915
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1916 cmp->font = XFONT_OBJECT (LGSTRING_FONT (gstring));
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1917 cmp->glyph_len = LGSTRING_LENGTH (gstring);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1918 cmp->pixel_width = LGSTRING_WIDTH (gstring);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1919 cmp->lbearing = LGSTRING_LBEARING (gstring);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1920 cmp->rbearing = LGSTRING_RBEARING (gstring);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1921 cmp->ascent = LGSTRING_ASCENT (gstring);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1922 cmp->descent = LGSTRING_DESCENT (gstring);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1923 cmp->width = cmp->pixel_width / FRAME_COLUMN_WIDTH (f);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1924 if (cmp->width == 0)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1925 cmp->width = 1;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1926
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
1927 return cmp->font;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1928 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1929
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1930
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1931 /* Font sorting */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1932
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1933 static unsigned font_score P_ ((Lisp_Object, Lisp_Object *, Lisp_Object));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1934 static int font_compare P_ ((const void *, const void *));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1935 static Lisp_Object font_sort_entites P_ ((Lisp_Object, Lisp_Object,
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1936 Lisp_Object, Lisp_Object,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1937 int));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1938
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1939 /* We sort fonts by scoring each of them against a specified
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1940 font-spec. The score value is 32 bit (`unsigned'), and the smaller
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1941 the value is, the closer the font is to the font-spec.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1942
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1943 The highest 2 bits of the score is used for FAMILY. The exact
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1944 match is 0, match with one of face-font-family-alternatives is
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1945 nonzero.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1946
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1947 The next 2 bits of the score is used for the atomic properties
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1948 FOUNDRY and ADSTYLE respectively.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1949
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1950 Each 7-bit in the lower 28 bits are used for numeric properties
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1951 WEIGHT, SLANT, WIDTH, and SIZE. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1952
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1953 /* How many bits to shift to store the difference value of each font
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1954 property in a score. Note that flots for FONT_TYPE_INDEX and
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1955 FONT_REGISTRY_INDEX are not used. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1956 static int sort_shift_bits[FONT_SIZE_INDEX + 1];
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1957
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1958 /* Score font-entity ENTITY against properties of font-spec SPEC_PROP.
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1959 The return value indicates how different ENTITY is compared with
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1960 SPEC_PROP.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1961
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1962 ALTERNATE_FAMILIES, if non-nil, is a pre-calculated list of
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1963 alternate family names for AREF (SPEC_PROP, FONT_FAMILY_INDEX). */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1964
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1965 static unsigned
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1966 font_score (entity, spec_prop, alternate_families)
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
1967 Lisp_Object entity, *spec_prop;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1968 Lisp_Object alternate_families;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1969 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1970 unsigned score = 0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
1971 int i;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1972
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1973 /* Score three atomic fields. Maximum difference is 1 (family is 3). */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1974 for (i = FONT_FOUNDRY_INDEX; i <= FONT_ADSTYLE_INDEX; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1975 if (i != FONT_REGISTRY_INDEX
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1976 && ! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1977 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1978 Lisp_Object entity_str = SYMBOL_NAME (AREF (entity, i));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1979 Lisp_Object spec_str = SYMBOL_NAME (spec_prop[i]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1980
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1981 if (strcasecmp ((char *) SDATA (spec_str), (char *) SDATA (entity_str)))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1982 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1983 if (i == FONT_FAMILY_INDEX && CONSP (alternate_families))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1984 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1985 int j;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1986
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1987 for (j = 1; CONSP (alternate_families);
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
1988 j++, alternate_families = XCDR (alternate_families))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1989 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1990 spec_str = XCAR (alternate_families);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1991 if (strcasecmp ((char *) SDATA (spec_str),
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
1992 (char *) SDATA (entity_str)) == 0)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1993 break;
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
1994
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1995 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1996 if (j > 3)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1997 j = 3;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1998 score |= j << sort_shift_bits[i];
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
1999 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2000 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2001 score |= 1 << sort_shift_bits[i];
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2002 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2003 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2004
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2005 /* Score three style numeric fields. Maximum difference is 127. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2006 for (i = FONT_WEIGHT_INDEX; i <= FONT_WIDTH_INDEX; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2007 if (! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2008 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2009 int diff = (XINT (AREF (entity, i)) >> 8) - (XINT (spec_prop[i]) >> 8);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2010
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2011 if (diff < 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2012 diff = - diff;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2013 /* This is to prefer the exact symbol style. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2014 diff++;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2015 score |= min (diff, 127) << sort_shift_bits[i];
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2016 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2017
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2018 /* Score the size. Maximum difference is 127. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2019 i = FONT_SIZE_INDEX;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2020 if (! NILP (spec_prop[i]) && ! EQ (AREF (entity, i), spec_prop[i])
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2021 && XINT (AREF (entity, i)) > 0)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2022 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2023 /* We use the higher 6-bit for the actual size difference. The
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2024 lowest bit is set if the DPI is different. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2025 int diff = XINT (spec_prop[i]) - XINT (AREF (entity, i));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2026
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2027 if (diff < 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2028 diff = - diff;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2029 diff <<= 1;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2030 if (! NILP (spec_prop[FONT_DPI_INDEX])
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2031 && ! EQ (spec_prop[FONT_DPI_INDEX], AREF (entity, FONT_DPI_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2032 diff |= 1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2033 score |= min (diff, 127) << sort_shift_bits[FONT_SIZE_INDEX];
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2034 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2035
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2036 return score;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2037 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2038
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2039
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2040 /* The comparison function for qsort. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2041
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2042 static int
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2043 font_compare (d1, d2)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2044 const void *d1, *d2;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2045 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2046 return (*(unsigned *) d1 - *(unsigned *) d2);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2047 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2048
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2049
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2050 /* The structure for elements being sorted by qsort. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2051 struct font_sort_data
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2052 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2053 unsigned score;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2054 Lisp_Object entity;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2055 };
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2056
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2057
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2058 /* Sort font-entities in vector VEC by closeness to font-spec PREFER.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2059 If PREFER specifies a point-size, calculate the corresponding
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2060 pixel-size from QCdpi property of PREFER or from the Y-resolution
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2061 of FRAME before sorting. If SPEC is not nil, it is a font-spec to
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2062 get the font-entities in VEC.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2063
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2064 If BEST-ONLY is nonzero, return the best matching entity. Otherwise,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2065 return the sorted VEC. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2066
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2067 static Lisp_Object
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2068 font_sort_entites (vec, prefer, frame, spec, best_only)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2069 Lisp_Object vec, prefer, frame, spec;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2070 int best_only;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2071 {
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2072 Lisp_Object prefer_prop[FONT_SPEC_MAX];
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2073 int len, i;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2074 struct font_sort_data *data;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2075 Lisp_Object alternate_families = Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2076 unsigned best_score;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2077 Lisp_Object best_entity;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2078 USE_SAFE_ALLOCA;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2079
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2080 len = ASIZE (vec);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2081 if (len <= 1)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2082 return best_only ? AREF (vec, 0) : vec;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2083
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2084 for (i = FONT_FOUNDRY_INDEX; i <= FONT_DPI_INDEX; i++)
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2085 prefer_prop[i] = AREF (prefer, i);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2086
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2087 if (! NILP (spec))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2088 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2089 /* A font driver may return a font that has a property value
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2090 different from the value specified in SPEC if the driver
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2091 thinks they are the same. That happens, for instance, such a
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2092 generic family name as "serif" is specified. So, to ignore
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2093 such a difference, for all properties specified in SPEC, set
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2094 the corresponding properties in PREFER_PROP to nil. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2095 for (i = FONT_FOUNDRY_INDEX; i <= FONT_REGISTRY_INDEX; i++)
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2096 if (! NILP (AREF (spec, i)))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2097 prefer_prop[i] = Qnil;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2098 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2099
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2100 if (FLOATP (prefer_prop[FONT_SIZE_INDEX]))
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2101 prefer_prop[FONT_SIZE_INDEX]
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2102 = make_number (font_pixel_size (XFRAME (frame), prefer));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2103 if (! NILP (prefer_prop[FONT_FAMILY_INDEX]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2104 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2105 alternate_families
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2106 = Fassoc_string (prefer_prop[FONT_FAMILY_INDEX],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2107 Vface_alternative_font_family_alist, Qt);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2108 if (CONSP (alternate_families))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2109 alternate_families = XCDR (alternate_families);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2110 }
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2111
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2112 /* Scoring and sorting. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2113 SAFE_ALLOCA (data, struct font_sort_data *, (sizeof *data) * len);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2114 best_score = 0xFFFFFFFF;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2115 best_entity = Qnil;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2116 for (i = 0; i < len; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2117 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2118 data[i].entity = AREF (vec, i);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2119 data[i].score = font_score (data[i].entity, prefer_prop,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2120 alternate_families);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2121 if (best_only && best_score > data[i].score)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2122 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2123 best_score = data[i].score;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2124 best_entity = data[i].entity;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2125 if (best_score == 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2126 break;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2127 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2128 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2129 if (NILP (best_entity))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2130 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2131 qsort (data, len, sizeof *data, font_compare);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2132 for (i = 0; i < len; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2133 ASET (vec, i, data[i].entity);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2134 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2135 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2136 vec = best_entity;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2137 SAFE_FREE ();
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2138
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2139 font_add_log ("sort-by", prefer, vec);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2140 return vec;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2141 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2142
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2143
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2144 /* API of Font Service Layer. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2145
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2146 /* Reflect ORDER (see the variable font_sort_order in xfaces.c) to
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2147 sort_shift_bits. Finternal_set_font_selection_order calls this
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2148 function with font_sort_order after setting up it. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2149
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2150 void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2151 font_update_sort_order (order)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2152 int *order;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2153 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2154 int i, shift_bits;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2155
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2156 for (i = 0, shift_bits = 21; i < 4; i++, shift_bits -= 7)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2157 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2158 int xlfd_idx = order[i];
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2159
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2160 if (xlfd_idx == XLFD_WEIGHT_INDEX)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2161 sort_shift_bits[FONT_WEIGHT_INDEX] = shift_bits;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2162 else if (xlfd_idx == XLFD_SLANT_INDEX)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2163 sort_shift_bits[FONT_SLANT_INDEX] = shift_bits;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2164 else if (xlfd_idx == XLFD_SWIDTH_INDEX)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2165 sort_shift_bits[FONT_WIDTH_INDEX] = shift_bits;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2166 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2167 sort_shift_bits[FONT_SIZE_INDEX] = shift_bits;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2168 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2169 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2170
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2171
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2172 /* Check if ENTITY matches with the font specification SPEC. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2173
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2174 int
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2175 font_match_p (spec, entity)
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2176 Lisp_Object spec, entity;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2177 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2178 Lisp_Object prefer_prop[FONT_SPEC_MAX];
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2179 Lisp_Object alternate_families = Qnil;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2180 int i;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2181
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2182 for (i = FONT_FOUNDRY_INDEX; i <= FONT_SIZE_INDEX; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2183 prefer_prop[i] = AREF (spec, i);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2184 if (FLOATP (prefer_prop[FONT_SIZE_INDEX]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2185 prefer_prop[FONT_SIZE_INDEX]
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2186 = make_number (font_pixel_size (XFRAME (selected_frame), spec));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2187 if (! NILP (prefer_prop[FONT_FAMILY_INDEX]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2188 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2189 alternate_families
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2190 = Fassoc_string (prefer_prop[FONT_FAMILY_INDEX],
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2191 Vface_alternative_font_family_alist, Qt);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2192 if (CONSP (alternate_families))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2193 alternate_families = XCDR (alternate_families);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2194 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2195
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2196 return (font_score (entity, prefer_prop, alternate_families) == 0);
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2197 }
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2198
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2199
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2200 /* CHeck a lispy font object corresponding to FONT. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2201
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2202 int
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2203 font_check_object (font)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2204 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2205 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2206 Lisp_Object tail, elt;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2207
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2208 for (tail = font->props[FONT_OBJLIST_INDEX]; CONSP (tail);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2209 tail = XCDR (tail))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2210 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2211 elt = XCAR (tail);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2212 if (font == XFONT_OBJECT (elt))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2213 return 1;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2214 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2215 return 0;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2216 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2217
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2218
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
2219
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2220 /* Font cache
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2221
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2222 Each font backend has the callback function get_cache, and it
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2223 returns a cons cell of which cdr part can be freely used for
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2224 caching fonts. The cons cell may be shared by multiple frames
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2225 and/or multiple font drivers. So, we arrange the cdr part as this:
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2226
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2227 ((DRIVER-TYPE NUM-FRAMES FONT-CACHE-DATA ...) ...)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2228
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2229 where DRIVER-TYPE is a symbol such as `x', `xft', etc., NUM-FRAMES
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2230 is a number frames sharing this cache, and FONT-CACHE-DATA is a
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2231 cons (FONT-SPEC FONT-ENTITY ...). */
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2232
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2233 static void font_prepare_cache P_ ((FRAME_PTR, struct font_driver *));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2234 static void font_finish_cache P_ ((FRAME_PTR, struct font_driver *));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2235 static Lisp_Object font_get_cache P_ ((FRAME_PTR, struct font_driver *));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2236 static void font_clear_cache P_ ((FRAME_PTR, Lisp_Object,
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2237 struct font_driver *));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2238
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2239 static void
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2240 font_prepare_cache (f, driver)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2241 FRAME_PTR f;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2242 struct font_driver *driver;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2243 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2244 Lisp_Object cache, val;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2245
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2246 cache = driver->get_cache (f);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2247 val = XCDR (cache);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2248 while (CONSP (val) && ! EQ (XCAR (XCAR (val)), driver->type))
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2249 val = XCDR (val);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2250 if (NILP (val))
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2251 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2252 val = Fcons (driver->type, Fcons (make_number (1), Qnil));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2253 XSETCDR (cache, Fcons (val, XCDR (cache)));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2254 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2255 else
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2256 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2257 val = XCDR (XCAR (val));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2258 XSETCAR (val, make_number (XINT (XCAR (val)) + 1));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2259 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2260 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2261
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2262
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2263 static void
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2264 font_finish_cache (f, driver)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2265 FRAME_PTR f;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2266 struct font_driver *driver;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2267 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2268 Lisp_Object cache, val, tmp;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2269
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2270
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2271 cache = driver->get_cache (f);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2272 val = XCDR (cache);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2273 while (CONSP (val) && ! EQ (XCAR (XCAR (val)), driver->type))
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2274 cache = val, val = XCDR (val);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2275 font_assert (! NILP (val));
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2276 tmp = XCDR (XCAR (val));
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2277 XSETCAR (tmp, make_number (XINT (XCAR (tmp)) - 1));
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2278 if (XINT (XCAR (tmp)) == 0)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2279 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2280 font_clear_cache (f, XCAR (val), driver);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2281 XSETCDR (cache, XCDR (val));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2282 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2283 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2284
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2285
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2286 static Lisp_Object
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2287 font_get_cache (f, driver)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2288 FRAME_PTR f;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2289 struct font_driver *driver;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2290 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2291 Lisp_Object val = driver->get_cache (f);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2292 Lisp_Object type = driver->type;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2293
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2294 font_assert (CONSP (val));
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2295 for (val = XCDR (val); ! EQ (XCAR (XCAR (val)), type); val = XCDR (val));
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2296 font_assert (CONSP (val));
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2297 /* VAL = ((DRIVER-TYPE NUM-FRAMES FONT-CACHE-DATA ...) ...) */
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2298 val = XCDR (XCAR (val));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2299 return val;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2300 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2301
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2302 static int num_fonts;
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2303
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2304 static void
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2305 font_clear_cache (f, cache, driver)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2306 FRAME_PTR f;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2307 Lisp_Object cache;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2308 struct font_driver *driver;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2309 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2310 Lisp_Object tail, elt;
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
2311
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2312 /* CACHE = (DRIVER-TYPE NUM-FRAMES FONT-CACHE-DATA ...) */
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2313 for (tail = XCDR (XCDR (cache)); CONSP (tail); tail = XCDR (tail))
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2314 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2315 elt = XCAR (tail);
94968
e87ef440216b (font_clear_cache): Check if the cached vector of entities is nil
Kenichi Handa <handa@m17n.org>
parents: 94964
diff changeset
2316 if (CONSP (elt) && FONT_SPEC_P (XCAR (elt)) && VECTORP (XCDR (elt)))
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2317 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2318 Lisp_Object vec = XCDR (elt);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2319 int i;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2320
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2321 for (i = 0; i < ASIZE (vec); i++)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2322 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2323 Lisp_Object entity = AREF (vec, i);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2324
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2325 if (EQ (driver->type, AREF (entity, FONT_TYPE_INDEX)))
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2326 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2327 Lisp_Object objlist = AREF (entity, FONT_OBJLIST_INDEX);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2328
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2329 for (; CONSP (objlist); objlist = XCDR (objlist))
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2330 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2331 Lisp_Object val = XCAR (objlist);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2332 struct font *font = XFONT_OBJECT (val);
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2333
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2334 font_assert (font && driver == font->driver);
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2335 driver->close (f, font);
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2336 num_fonts--;
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2337 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2338 if (driver->free_entity)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2339 driver->free_entity (entity);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2340 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2341 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2342 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2343 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2344 XSETCDR (cache, Qnil);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2345 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2346
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2347
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2348 static Lisp_Object scratch_font_spec, scratch_font_prefer;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2349
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2350 Lisp_Object
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2351 font_delete_unmatched (list, spec, size)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2352 Lisp_Object list, spec;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2353 int size;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2354 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2355 Lisp_Object entity, val;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2356 enum font_property_index prop;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2357
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2358 for (val = Qnil; CONSP (list); list = XCDR (list))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2359 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2360 entity = XCAR (list);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2361 for (prop = FONT_WEIGHT_INDEX; prop < FONT_SIZE_INDEX; prop++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2362 if (INTEGERP (AREF (spec, prop))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2363 && ((XINT (AREF (spec, prop)) >> 8)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2364 != (XINT (AREF (entity, prop)) >> 8)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2365 prop = FONT_SPEC_MAX;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2366 if (prop++ <= FONT_SIZE_INDEX
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2367 && size
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2368 && XINT (AREF (entity, FONT_SIZE_INDEX)) > 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2369 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2370 int diff = XINT (AREF (entity, FONT_SIZE_INDEX)) - size;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2371
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2372 if (diff != 0
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2373 && (diff < 0 ? -diff > FONT_PIXEL_SIZE_QUANTUM
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2374 : diff > FONT_PIXEL_SIZE_QUANTUM))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2375 prop = FONT_SPEC_MAX;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2376 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2377 if (prop < FONT_SPEC_MAX
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2378 && INTEGERP (AREF (spec, FONT_SPACING_INDEX))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2379 && ! EQ (AREF (spec, FONT_SPACING_INDEX),
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2380 AREF (entity, FONT_SPACING_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2381 prop = FONT_SPEC_MAX;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2382 if (prop < FONT_SPEC_MAX)
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2383 val = Fcons (entity, val);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2384 }
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2385 return val;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2386 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2387
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2388
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2389 /* Return a vector of font-entities matching with SPEC on FRAME. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2390
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2391 Lisp_Object
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2392 font_list_entities (frame, spec)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2393 Lisp_Object frame, spec;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2394 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2395 FRAME_PTR f = XFRAME (frame);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2396 struct font_driver_list *driver_list = f->font_driver_list;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2397 Lisp_Object ftype, family, alternate_familes, val;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2398 Lisp_Object *vec;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2399 int size;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2400 int need_filtering = 0;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2401 int n_family = 1;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2402 int i;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2403
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2404 font_assert (FONT_SPEC_P (spec));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2405
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2406 family = AREF (spec, FONT_FAMILY_INDEX);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2407 if (NILP (family))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2408 alternate_familes = Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2409 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2410 {
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
2411 alternate_familes = Fassoc_string (family,
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2412 Vface_alternative_font_family_alist,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2413 Qt);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2414 if (! NILP (alternate_familes))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2415 alternate_familes = XCDR (alternate_familes);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2416 n_family += XINT (Flength (alternate_familes));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2417 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2418
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2419 if (INTEGERP (AREF (spec, FONT_SIZE_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2420 size = XINT (AREF (spec, FONT_SIZE_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2421 else if (FLOATP (AREF (spec, FONT_SIZE_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2422 size = font_pixel_size (f, spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2423 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2424 size = 0;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2425
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2426 ftype = AREF (spec, FONT_TYPE_INDEX);
95104
ae4280e6a166 (font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents: 95013
diff changeset
2427 for (i = 1; i <= FONT_REGISTRY_INDEX; i++)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2428 ASET (scratch_font_spec, i, AREF (spec, i));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2429 for (; i < FONT_EXTRA_INDEX; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2430 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2431 ASET (scratch_font_spec, i, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2432 if (! NILP (AREF (spec, i)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2433 need_filtering = 1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2434 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2435 ASET (scratch_font_spec, FONT_EXTRA_INDEX, AREF (spec, FONT_EXTRA_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2436
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2437 vec = alloca (sizeof (Lisp_Object) * num_font_drivers * n_family);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2438 if (! vec)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2439 return null_vector;
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
2440
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2441 for (i = 0; driver_list; driver_list = driver_list->next)
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
2442 if (driver_list->on
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
2443 && (NILP (ftype) || EQ (driver_list->driver->type, ftype)))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2444 {
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2445 Lisp_Object cache = font_get_cache (f, driver_list->driver);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2446 Lisp_Object tail = alternate_familes;
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2447
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2448 while (1)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2449 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2450 val = assoc_no_quit (scratch_font_spec, XCDR (cache));
95104
ae4280e6a166 (font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents: 95013
diff changeset
2451 if (CONSP (val))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2452 val = XCDR (val);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2453 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2454 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2455 Lisp_Object copy;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2456
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2457 val = driver_list->driver->list (frame, scratch_font_spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2458 copy = Fcopy_font_spec (scratch_font_spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2459 XSETCDR (cache, Fcons (Fcons (copy, val), XCDR (cache)));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2460 }
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2461 if (! NILP (val) && need_filtering)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2462 val = font_delete_unmatched (val, spec, size);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2463 if (! NILP (val))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2464 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2465 vec[i++] = val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2466 break;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2467 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2468 if (NILP (tail))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2469 break;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2470 ASET (scratch_font_spec, FONT_FAMILY_INDEX,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2471 Fintern (XCAR (tail), Qnil));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2472 tail = XCDR (tail);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2473 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2474 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2475
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2476 val = (i > 0 ? Fvconcat (i, vec) : null_vector);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2477 font_add_log ("list", spec, val);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2478 return (val);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2479 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2480
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2481
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2482 /* Return a font entity matching with SPEC on FRAME. ATTRS, if non
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2483 nil, is an array of face's attributes, which specifies preferred
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2484 font-related attributes. */
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2485
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2486 static Lisp_Object
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2487 font_matching_entity (f, attrs, spec)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2488 FRAME_PTR f;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2489 Lisp_Object *attrs, spec;
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2490 {
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2491 struct font_driver_list *driver_list = f->font_driver_list;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2492 Lisp_Object ftype, size, entity;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2493 Lisp_Object frame;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2494
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2495 XSETFRAME (frame, f);
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2496 ftype = AREF (spec, FONT_TYPE_INDEX);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2497 size = AREF (spec, FONT_SIZE_INDEX);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2498 if (FLOATP (size))
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2499 ASET (spec, FONT_SIZE_INDEX, make_number (font_pixel_size (f, spec)));
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2500 entity = Qnil;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2501 for (; driver_list; driver_list = driver_list->next)
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2502 if (driver_list->on
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2503 && (NILP (ftype) || EQ (driver_list->driver->type, ftype)))
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2504 {
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
2505 Lisp_Object cache = font_get_cache (f, driver_list->driver);
95104
ae4280e6a166 (font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents: 95013
diff changeset
2506 Lisp_Object copy;
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2507
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2508 ASET (spec, FONT_TYPE_INDEX, driver_list->driver->type);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2509 entity = assoc_no_quit (spec, XCDR (cache));
95104
ae4280e6a166 (font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents: 95013
diff changeset
2510 if (CONSP (entity))
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2511 entity = XCDR (entity);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2512 else
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2513 {
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2514 entity = driver_list->driver->match (frame, spec);
95104
ae4280e6a166 (font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents: 95013
diff changeset
2515 copy = Fcopy_font_spec (spec);
ae4280e6a166 (font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents: 95013
diff changeset
2516 ASET (copy, FONT_TYPE_INDEX, driver_list->driver->type);
ae4280e6a166 (font_list_entities): Fix handling of cache.
Kenichi Handa <handa@m17n.org>
parents: 95013
diff changeset
2517 XSETCDR (cache, Fcons (Fcons (copy, entity), XCDR (cache)));
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2518 }
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2519 if (! NILP (entity))
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2520 break;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2521 }
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2522 ASET (spec, FONT_TYPE_INDEX, ftype);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2523 ASET (spec, FONT_SIZE_INDEX, size);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2524 font_add_log ("match", spec, entity);
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2525 return entity;
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2526 }
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
2527
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2528
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2529 /* Open a font of ENTITY and PIXEL_SIZE on frame F, and return the
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2530 opened font object. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2531
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2532 static Lisp_Object
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2533 font_open_entity (f, entity, pixel_size)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2534 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2535 Lisp_Object entity;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2536 int pixel_size;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2537 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2538 struct font_driver_list *driver_list;
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2539 Lisp_Object objlist, size, val, font_object;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2540 struct font *font;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2541 int min_width;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2542
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2543 font_assert (FONT_ENTITY_P (entity));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2544 size = AREF (entity, FONT_SIZE_INDEX);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2545 if (XINT (size) != 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2546 pixel_size = XINT (size);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2547
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2548 for (objlist = AREF (entity, FONT_OBJLIST_INDEX); CONSP (objlist);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2549 objlist = XCDR (objlist))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2550 if (XFONT_OBJECT (XCAR (objlist))->pixel_size == pixel_size)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2551 return XCAR (objlist);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2552
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2553 val = AREF (entity, FONT_TYPE_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2554 for (driver_list = f->font_driver_list;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2555 driver_list && ! EQ (driver_list->driver->type, val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2556 driver_list = driver_list->next);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2557 if (! driver_list)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2558 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2559
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2560 font_object = driver_list->driver->open (f, entity, pixel_size);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2561 font_add_log ("open", entity, font_object);
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2562 if (NILP (font_object))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2563 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2564 ASET (entity, FONT_OBJLIST_INDEX,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2565 Fcons (font_object, AREF (entity, FONT_OBJLIST_INDEX)));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2566 ASET (font_object, FONT_OBJLIST_INDEX, AREF (entity, FONT_OBJLIST_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2567 num_fonts++;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2568
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2569 font = XFONT_OBJECT (font_object);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2570 min_width = (font->min_width ? font->min_width
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2571 : font->average_width ? font->average_width
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2572 : font->space_width ? font->space_width
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2573 : 1);
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
2574 #ifdef HAVE_WINDOW_SYSTEM
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2575 FRAME_X_DISPLAY_INFO (f)->n_fonts++;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2576 if (FRAME_X_DISPLAY_INFO (f)->n_fonts == 1)
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2577 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2578 FRAME_SMALLEST_CHAR_WIDTH (f) = min_width;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2579 FRAME_SMALLEST_FONT_HEIGHT (f) = font->height;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2580 fonts_changed_p = 1;
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2581 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2582 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2583 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2584 if (FRAME_SMALLEST_CHAR_WIDTH (f) > min_width)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2585 FRAME_SMALLEST_CHAR_WIDTH (f) = min_width, fonts_changed_p = 1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2586 if (FRAME_SMALLEST_FONT_HEIGHT (f) > font->height)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2587 FRAME_SMALLEST_FONT_HEIGHT (f) = font->height, fonts_changed_p = 1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2588 }
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
2589 #endif
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2590
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2591 return font_object;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2592 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2593
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2594
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2595 /* Close FONT_OBJECT that is opened on frame F. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2596
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2597 void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2598 font_close_object (f, font_object)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2599 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2600 Lisp_Object font_object;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2601 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2602 struct font *font = XFONT_OBJECT (font_object);
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
2603 Lisp_Object objlist;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2604 Lisp_Object tail, prev = Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2605
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2606 objlist = AREF (font_object, FONT_OBJLIST_INDEX);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2607 for (prev = Qnil, tail = objlist; CONSP (tail);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2608 prev = tail, tail = XCDR (tail))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2609 if (EQ (font_object, XCAR (tail)))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2610 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2611 font_add_log ("close", font_object, Qnil);
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
2612 font->driver->close (f, font);
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
2613 #ifdef HAVE_WINDOW_SYSTEM
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2614 font_assert (FRAME_X_DISPLAY_INFO (f)->n_fonts);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2615 FRAME_X_DISPLAY_INFO (f)->n_fonts--;
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
2616 #endif
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
2617 if (NILP (prev))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2618 ASET (font_object, FONT_OBJLIST_INDEX, XCDR (objlist));
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
2619 else
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
2620 XSETCDR (prev, XCDR (objlist));
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
2621 num_fonts--;
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
2622 return;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2623 }
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
2624 abort ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2625 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2626
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2627
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
2628 /* Return 1 if FONT on F has a glyph for character C, 0 if not, -1 if
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
2629 FONT is a font-entity and it must be opened to check. */
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2630
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2631 int
90490
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2632 font_has_char (f, font, c)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2633 FRAME_PTR f;
90490
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2634 Lisp_Object font;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2635 int c;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2636 {
90490
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2637 struct font *fontp;
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2638
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2639 if (FONT_ENTITY_P (font))
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2640 {
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2641 Lisp_Object type = AREF (font, FONT_TYPE_INDEX);
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2642 struct font_driver_list *driver_list;
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2643
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2644 for (driver_list = f->font_driver_list;
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2645 driver_list && ! EQ (driver_list->driver->type, type);
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2646 driver_list = driver_list->next);
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2647 if (! driver_list)
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2648 return 0;
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2649 if (! driver_list->driver->has_char)
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2650 return -1;
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2651 return driver_list->driver->has_char (font, c);
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2652 }
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2653
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2654 font_assert (FONT_OBJECT_P (font));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2655 fontp = XFONT_OBJECT (font);
90490
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2656 if (fontp->driver->has_char)
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2657 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2658 int result = fontp->driver->has_char (font, c);
90490
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2659
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2660 if (result >= 0)
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2661 return result;
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2662 }
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2663 return (fontp->driver->encode_char (fontp, c) != FONT_INVALID_CODE);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2664 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2665
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2666
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2667 /* Return the glyph ID of FONT_OBJECT for character C. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2668
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2669 unsigned
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2670 font_encode_char (font_object, c)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2671 Lisp_Object font_object;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2672 int c;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2673 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2674 struct font *font;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2675
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2676 font_assert (FONT_OBJECT_P (font_object));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2677 font = XFONT_OBJECT (font_object);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2678 return font->driver->encode_char (font, c);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2679 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2680
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2681
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2682 /* Return the name of FONT_OBJECT. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2683
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2684 Lisp_Object
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2685 font_get_name (font_object)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2686 Lisp_Object font_object;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2687 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2688 font_assert (FONT_OBJECT_P (font_object));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2689 return AREF (font_object, FONT_NAME_INDEX);
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2690 }
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2691
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2692
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2693 /* Return the specification of FONT_OBJECT. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2694
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2695 Lisp_Object
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2696 font_get_spec (font_object)
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2697 Lisp_Object font_object;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2698 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2699 Lisp_Object spec = font_make_spec ();
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2700 int i;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2701
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2702 for (i = 0; i < FONT_SIZE_INDEX; i++)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2703 ASET (spec, i, AREF (font_object, i));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2704 ASET (spec, FONT_SIZE_INDEX,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2705 make_number (XFONT_OBJECT (font_object)->pixel_size));
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2706 return spec;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2707 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2708
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2709 Lisp_Object
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2710 font_spec_from_name (font_name)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2711 Lisp_Object font_name;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2712 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2713 Lisp_Object args[2];
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2714
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2715 args[0] = QCname;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2716 args[1] = font_name;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2717 return Ffont_spec (2, args);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2718 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2719
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2720
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2721 void
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2722 font_clear_prop (attrs, prop)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2723 Lisp_Object *attrs;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2724 enum font_property_index prop;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2725 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2726 Lisp_Object font = attrs[LFACE_FONT_INDEX];
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2727
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2728 if (! FONTP (font))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2729 return;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2730 if (NILP (AREF (font, prop))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2731 && prop != FONT_FAMILY_INDEX && prop != FONT_FAMILY_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2732 return;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2733 font = Fcopy_font_spec (font);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2734 ASET (font, prop, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2735 if (prop == FONT_FAMILY_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2736 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2737 ASET (font, FONT_FOUNDRY_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2738 ASET (font, FONT_ADSTYLE_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2739 ASET (font, FONT_SIZE_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2740 ASET (font, FONT_DPI_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2741 ASET (font, FONT_SPACING_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2742 ASET (font, FONT_AVGWIDTH_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2743 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2744 else if (prop == FONT_SIZE_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2745 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2746 ASET (font, FONT_DPI_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2747 ASET (font, FONT_SPACING_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2748 ASET (font, FONT_AVGWIDTH_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2749 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2750 attrs[LFACE_FONT_INDEX] = font;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2751 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2752
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2753 void
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2754 font_update_lface (f, attrs)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2755 FRAME_PTR f;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2756 Lisp_Object *attrs;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2757 {
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2758 Lisp_Object spec;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2759
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2760 spec = attrs[LFACE_FONT_INDEX];
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2761 if (! FONT_SPEC_P (spec))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2762 return;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2763
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2764 if (! NILP (AREF (spec, FONT_FOUNDRY_INDEX))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2765 || ! NILP (AREF (spec, FONT_FAMILY_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2766 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2767 Lisp_Object family;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2768
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2769 if (NILP (AREF (spec, FONT_FOUNDRY_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2770 family = AREF (spec, FONT_FAMILY_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2771 else if (NILP (AREF (spec, FONT_FAMILY_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2772 family = concat2 (SYMBOL_NAME (AREF (spec, FONT_FOUNDRY_INDEX)),
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2773 build_string ("-*"));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2774 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2775 family = concat3 (SYMBOL_NAME (AREF (spec, FONT_FOUNDRY_INDEX)),
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2776 build_string ("-"),
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2777 SYMBOL_NAME (AREF (spec, FONT_FAMILY_INDEX)));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2778 attrs[LFACE_FAMILY_INDEX] = family;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2779 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2780 if (! NILP (AREF (spec, FONT_WEIGHT_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2781 attrs[LFACE_WEIGHT_INDEX] = FONT_WEIGHT_FOR_FACE (spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2782 if (! NILP (AREF (spec, FONT_SLANT_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2783 attrs[LFACE_SLANT_INDEX] = FONT_SLANT_FOR_FACE (spec);;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2784 if (! NILP (AREF (spec, FONT_WIDTH_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2785 attrs[LFACE_SWIDTH_INDEX] = FONT_WIDTH_FOR_FACE (spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2786 if (! NILP (AREF (spec, FONT_SIZE_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2787 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2788 int point;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2789
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2790 if (INTEGERP (AREF (spec, FONT_SIZE_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2791 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2792 Lisp_Object val;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2793 int dpi = f->resy;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2794
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2795 val = Ffont_get (spec, QCdpi);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2796 if (! NILP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2797 dpi = XINT (val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2798 point = PIXEL_TO_POINT (XINT (AREF (spec, FONT_SIZE_INDEX)) * 10,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2799 dpi);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2800 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2801 else if (FLOATP (AREF (spec, FONT_SIZE_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2802 point = XFLOAT_DATA (AREF (spec, FONT_SIZE_INDEX)) * 10;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2803 attrs[LFACE_HEIGHT_INDEX] = make_number (point);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2804 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2805 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2806
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2807
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2808 /* Return a font-entity satisfying SPEC and best matching with face's
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2809 font related attributes in ATTRS. C, if not negative, is a
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
2810 character that the entity must support. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2811
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2812 Lisp_Object
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2813 font_find_for_lface (f, attrs, spec, c)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2814 FRAME_PTR f;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2815 Lisp_Object *attrs;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2816 Lisp_Object spec;
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
2817 int c;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2818 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2819 Lisp_Object frame, entities, val, props[FONT_REGISTRY_INDEX + 1] ;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2820 Lisp_Object size;
91353
b93ade1a3602 (font_find_for_lface): Check if the character C is
Kenichi Handa <handa@m17n.org>
parents: 91350
diff changeset
2821 int i, result;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
2822
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2823 if (c >= 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2824 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2825 Lisp_Object registry = AREF (spec, FONT_REGISTRY_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2826 struct charset *encoding, *repertory;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2827
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2828 if (font_registry_charsets (registry, &encoding, &repertory) < 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2829 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2830 if (repertory)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2831 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2832 if (ENCODE_CHAR (repertory, c) == CHARSET_INVALID_CODE (repertory))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2833 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2834 /* Any font of this registry support C. So, let's
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2835 suppress the further checking. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2836 c = -1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2837 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2838 else if (c > encoding->max_char)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2839 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2840 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2841
90507
4a6034a7c870 (font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents: 90503
diff changeset
2842 XSETFRAME (frame, f);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2843 size = AREF (spec, FONT_SIZE_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2844 ASET (spec, FONT_SIZE_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2845 entities = font_list_entities (frame, spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2846 ASET (spec, FONT_SIZE_INDEX, size);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2847 if (ASIZE (entities) == 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2848 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2849 if (ASIZE (entities) == 1)
90490
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2850 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2851 if (c < 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2852 return AREF (entities, 0);
90490
8ef2cbaf626a (font_parse_xlfd): Fix generating of CHARSET_REGISTRY field.
Kenichi Handa <handa@m17n.org>
parents: 90483
diff changeset
2853 }
90507
4a6034a7c870 (font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents: 90503
diff changeset
2854 else
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2855 {
90507
4a6034a7c870 (font_find_for_lface): Code optimized.
Kenichi Handa <handa@m17n.org>
parents: 90503
diff changeset
2856 /* Sort fonts by properties specified in LFACE. */
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
2857 Lisp_Object prefer = scratch_font_prefer;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
2858
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2859 for (i = 0; i < FONT_EXTRA_INDEX; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2860 ASET (prefer, i, AREF (spec, i));
95013
125a7ecf00db (font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents: 94968
diff changeset
2861 if (FONTP (attrs[LFACE_FONT_INDEX]))
125a7ecf00db (font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents: 94968
diff changeset
2862 {
125a7ecf00db (font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents: 94968
diff changeset
2863 Lisp_Object face_font = attrs[LFACE_FONT_INDEX];
125a7ecf00db (font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents: 94968
diff changeset
2864
125a7ecf00db (font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents: 94968
diff changeset
2865 for (i = 0; i < FONT_EXTRA_INDEX; i++)
125a7ecf00db (font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents: 94968
diff changeset
2866 if (NILP (AREF (prefer, i)))
125a7ecf00db (font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents: 94968
diff changeset
2867 ASET (prefer, i, AREF (face_font, i));
125a7ecf00db (font_find_for_lface): Reflect LFACE_FONT in the font
Kenichi Handa <handa@m17n.org>
parents: 94968
diff changeset
2868 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2869 if (NILP (AREF (prefer, FONT_FAMILY_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2870 font_parse_family_registry (attrs[LFACE_FAMILY_INDEX], Qnil, prefer);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2871 if (NILP (AREF (prefer, FONT_WEIGHT_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2872 FONT_SET_STYLE (prefer, FONT_WEIGHT_INDEX, attrs[LFACE_WEIGHT_INDEX]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2873 if (NILP (AREF (prefer, FONT_SLANT_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2874 FONT_SET_STYLE (prefer, FONT_SLANT_INDEX, attrs[LFACE_SLANT_INDEX]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2875 if (NILP (AREF (prefer, FONT_WIDTH_INDEX)))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2876 FONT_SET_STYLE (prefer, FONT_WIDTH_INDEX, attrs[LFACE_SWIDTH_INDEX]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2877 if (INTEGERP (size))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2878 ASET (prefer, FONT_SIZE_INDEX, size);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2879 else if (FLOATP (size))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2880 ASET (prefer, FONT_SIZE_INDEX, make_number (font_pixel_size (f, spec)));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2881 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2882 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2883 double pt = XINT (attrs[LFACE_HEIGHT_INDEX]);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2884 int pixel_size = POINT_TO_PIXEL (pt / 10, f->resy);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2885 ASET (prefer, FONT_SIZE_INDEX, make_number (pixel_size));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2886 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2887 ASET (spec, FONT_SIZE_INDEX, Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2888 entities = font_sort_entites (entities, prefer, frame, spec, c < 0);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2889 ASET (spec, FONT_SIZE_INDEX, size);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2890 }
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
2891 if (c < 0)
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2892 return entities;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2893
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2894 for (i = 0; i < ASIZE (entities); i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2895 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2896 int j;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2897
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2898 val = AREF (entities, i);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2899 if (i > 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2900 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2901 for (j = FONT_FOUNDRY_INDEX; j <= FONT_REGISTRY_INDEX; j++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2902 if (! EQ (AREF (val, j), props[j]))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2903 break;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2904 if (j > FONT_REGISTRY_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2905 continue;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2906 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2907 for (j = FONT_FOUNDRY_INDEX; j <= FONT_REGISTRY_INDEX; j++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2908 props[j] = AREF (val, j);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2909 result = font_has_char (f, val, c);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2910 if (result > 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2911 return val;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2912 if (result == 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2913 return Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2914 val = font_open_for_lface (f, val, attrs, spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2915 if (NILP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2916 continue;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2917 result = font_has_char (f, val, c);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2918 font_close_object (f, val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2919 if (result > 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2920 return AREF (entities, i);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2921 }
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
2922 return Qnil;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2923 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2924
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2925
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2926 Lisp_Object
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2927 font_open_for_lface (f, entity, attrs, spec)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2928 FRAME_PTR f;
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2929 Lisp_Object entity;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2930 Lisp_Object *attrs;
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2931 Lisp_Object spec;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2932 {
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2933 int size;
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
2934
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2935 if (FONT_SPEC_P (spec) && INTEGERP (AREF (spec, FONT_SIZE_INDEX)))
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2936 size = XINT (AREF (spec, FONT_SIZE_INDEX));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2937 else
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2938 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2939 double pt = XINT (attrs[LFACE_HEIGHT_INDEX]);
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2940
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2941 pt /= 10;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2942 size = POINT_TO_PIXEL (pt, f->resy);
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
2943 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2944 return font_open_entity (f, entity, size);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2945 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2946
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2947
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2948 /* Find a font satisfying SPEC and best matching with face's
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2949 attributes in ATTRS on FRAME, and return the opened
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2950 font-object. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2951
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2952 Lisp_Object
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2953 font_load_for_lface (f, attrs, spec)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2954 FRAME_PTR f;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2955 Lisp_Object *attrs, spec;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2956 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2957 Lisp_Object entity;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2958
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2959 entity = font_find_for_lface (f, attrs, spec, -1);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2960 if (NILP (entity))
91350
9673276f310c (font_load_for_face): Handle the case that the font in
Kenichi Handa <handa@m17n.org>
parents: 91337
diff changeset
2961 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2962 /* No font is listed for SPEC, but each font-backend may have
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2963 the different criteria about "font matching". So, try
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2964 it. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2965 entity = font_matching_entity (f, attrs, spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2966 if (NILP (entity))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2967 return Qnil;
91350
9673276f310c (font_load_for_face): Handle the case that the font in
Kenichi Handa <handa@m17n.org>
parents: 91337
diff changeset
2968 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2969 return font_open_for_lface (f, entity, attrs, spec);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2970 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2971
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2972
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2973 /* Make FACE on frame F ready to use the font opened for FACE. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2974
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2975 void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2976 font_prepare_for_face (f, face)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2977 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2978 struct face *face;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2979 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2980 if (face->font->driver->prepare_face)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2981 face->font->driver->prepare_face (f, face);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2982 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2983
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2984
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2985 /* Make FACE on frame F stop using the font opened for FACE. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2986
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2987 void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2988 font_done_for_face (f, face)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2989 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2990 struct face *face;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2991 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2992 if (face->font->driver->done_face)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
2993 face->font->driver->done_face (f, face);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2994 face->extra = NULL;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2995 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
2996
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2997
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2998 /* Open a font best matching with NAME on frame F. If no proper font
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
2999 is found, return Qnil. */
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3000
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3001 Lisp_Object
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3002 font_open_by_name (f, name)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3003 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3004 char *name;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3005 {
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3006 Lisp_Object args[2];
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3007 Lisp_Object spec, prefer, size, entity, entity_list;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3008 Lisp_Object frame;
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3009 int i;
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3010 int pixel_size;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3011
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3012 XSETFRAME (frame, f);
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3013
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3014 args[0] = QCname;
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3015 args[1] = make_unibyte_string (name, strlen (name));
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3016 spec = Ffont_spec (2, args);
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3017 prefer = scratch_font_prefer;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3018 for (i = 0; i < FONT_SPEC_MAX; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3019 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3020 ASET (prefer, i, AREF (spec, i));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3021 if (NILP (AREF (prefer, i))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3022 && i >= FONT_WEIGHT_INDEX && i <= FONT_WIDTH_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3023 FONT_SET_STYLE (prefer, i, make_number (100));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3024 }
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3025 size = AREF (spec, FONT_SIZE_INDEX);
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3026 if (NILP (size))
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3027 pixel_size = 0;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3028 else
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3029 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3030 if (INTEGERP (size))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3031 pixel_size = XINT (size);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3032 else /* FLOATP (size) */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3033 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3034 double pt = XFLOAT_DATA (size);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3035
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3036 pixel_size = POINT_TO_PIXEL (pt, f->resy);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3037 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3038 if (pixel_size == 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3039 ASET (spec, FONT_SIZE_INDEX, Qnil);
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3040 }
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3041 if (pixel_size == 0)
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3042 {
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
3043 pixel_size = POINT_TO_PIXEL (12.0, f->resy);
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3044 size = make_number (pixel_size);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3045 ASET (prefer, FONT_SIZE_INDEX, size);
90468
5424215feef6 (XLFD_SMALLNUM_MASK): Delete this macro.
Kenichi Handa <handa@m17n.org>
parents: 90451
diff changeset
3046 }
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
3047 if (NILP (AREF (spec, FONT_REGISTRY_INDEX)))
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
3048 ASET (spec, FONT_REGISTRY_INDEX, Qiso8859_1);
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3049
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3050 entity_list = Flist_fonts (spec, frame, make_number (1), prefer);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3051 if (NILP (entity_list))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3052 entity = font_matching_entity (f, NULL, spec);
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3053 else
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3054 entity = XCAR (entity_list);
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3055 return (NILP (entity)
90476
017a6aec5d77 (font_parse_fcname): Fix parsing of point-size.
Kenichi Handa <handa@m17n.org>
parents: 90468
diff changeset
3056 ? Qnil
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3057 : font_open_entity (f, entity, pixel_size));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3058 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3059
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3060
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3061 /* Register font-driver DRIVER. This function is used in two ways.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3062
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3063 The first is with frame F non-NULL. In this case, make DRIVER
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3064 available (but not yet activated) on F. All frame creaters
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3065 (e.g. Fx_create_frame) must call this function at least once with
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3066 an available font-driver.
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3067
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3068 The second is with frame F NULL. In this case, DRIVER is globally
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3069 registered in the variable `font_driver_list'. All font-driver
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3070 implementations must call this function in its syms_of_XXXX
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3071 (e.g. syms_of_xfont). */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3072
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3073 void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3074 register_font_driver (driver, f)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3075 struct font_driver *driver;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3076 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3077 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3078 struct font_driver_list *root = f ? f->font_driver_list : font_driver_list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3079 struct font_driver_list *prev, *list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3080
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3081 if (f && ! driver->draw)
92113
2a9ed1c080b4 (font_match_xlfd, font_check_xlfd_parse): New funs.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91943
diff changeset
3082 error ("Unusable font driver for a frame: %s",
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3083 SDATA (SYMBOL_NAME (driver->type)));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3084
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3085 for (prev = NULL, list = root; list; prev = list, list = list->next)
90695
a1cd7344d6a2 (font_parse_xlfd): Fix the array size of `f'.
Kenichi Handa <handa@m17n.org>
parents: 90677
diff changeset
3086 if (EQ (list->driver->type, driver->type))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3087 error ("Duplicated font driver: %s", SDATA (SYMBOL_NAME (driver->type)));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3088
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3089 list = malloc (sizeof (struct font_driver_list));
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3090 list->on = 0;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3091 list->driver = driver;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3092 list->next = NULL;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3093 if (prev)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3094 prev->next = list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3095 else if (f)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3096 f->font_driver_list = list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3097 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3098 font_driver_list = list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3099 num_font_drivers++;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3100 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3101
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3102
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3103 /* Free font-driver list on frame F. It doesn't free font-drivers
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3104 themselves. */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3105
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3106 void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3107 free_font_driver_list (f)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3108 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3109 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3110 while (f->font_driver_list)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3111 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3112 struct font_driver_list *next = f->font_driver_list->next;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3113
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3114 free (f->font_driver_list);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3115 f->font_driver_list = next;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3116 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3117 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3118
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3119
91112
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3120 /* Make the frame F use font backends listed in NEW_DRIVERS (list of
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3121 symbols, e.g. xft, x). If NEW_DRIVERS is t, make F use all
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3122 available font drivers. If NEW_DRIVERS is nil, finalize all drivers.
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3123
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3124 A caller must free all realized faces if any in advance. The
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3125 return value is a list of font backends actually made used on
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3126 F. */
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3127
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3128 Lisp_Object
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3129 font_update_drivers (f, new_drivers)
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3130 FRAME_PTR f;
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3131 Lisp_Object new_drivers;
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3132 {
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3133 Lisp_Object active_drivers = Qnil;
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3134 struct font_driver_list *list;
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3135
91112
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3136 for (list = f->font_driver_list; list; list = list->next)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3137 if (list->on)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3138 {
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3139 if (! EQ (new_drivers, Qt)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3140 && NILP (Fmemq (list->driver->type, new_drivers)))
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3141 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3142 if (list->driver->end_for_frame)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3143 list->driver->end_for_frame (f);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3144 font_finish_cache (f, list->driver);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3145 list->on = 0;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3146 }
91112
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3147 }
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3148 else
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3149 {
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3150 if (EQ (new_drivers, Qt)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3151 || ! NILP (Fmemq (list->driver->type, new_drivers)))
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3152 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3153 if (! list->driver->start_for_frame
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3154 || list->driver->start_for_frame (f) == 0)
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3155 {
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3156 font_prepare_cache (f, list->driver);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3157 list->on = 1;
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3158 active_drivers = nconc2 (active_drivers,
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3159 Fcons (list->driver->type, Qnil));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3160 }
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3161 }
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3162 }
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3163
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3164 return active_drivers;
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3165 }
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3166
91112
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3167 int
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3168 font_put_frame_data (f, driver, data)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3169 FRAME_PTR f;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3170 struct font_driver *driver;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3171 void *data;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3172 {
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3173 struct font_data_list *list, *prev;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3174
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3175 for (prev = NULL, list = f->font_data_list; list;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3176 prev = list, list = list->next)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3177 if (list->driver == driver)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3178 break;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3179 if (! data)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3180 {
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3181 if (list)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3182 {
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3183 if (prev)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3184 prev->next = list->next;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3185 else
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3186 f->font_data_list = list->next;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3187 free (list);
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3188 }
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3189 return 0;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3190 }
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3191
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3192 if (! list)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3193 {
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3194 list = malloc (sizeof (struct font_data_list));
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3195 if (! list)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3196 return -1;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3197 list->driver = driver;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3198 list->next = f->font_data_list;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3199 f->font_data_list = list;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3200 }
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3201 list->data = data;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3202 return 0;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3203 }
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3204
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3205
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3206 void *
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3207 font_get_frame_data (f, driver)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3208 FRAME_PTR f;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3209 struct font_driver *driver;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3210 {
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3211 struct font_data_list *list;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3212
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3213 for (list = f->font_data_list; list; list = list->next)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3214 if (list->driver == driver)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3215 break;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3216 if (! list)
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3217 return NULL;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3218 return list->data;
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3219 }
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3220
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3221
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3222 /* Return the font used to draw character C by FACE at buffer position
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3223 POS in window W. If STRING is non-nil, it is a string containing C
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3224 at index POS. If C is negative, get C from the current buffer or
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3225 STRING. */
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3226
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3227 Lisp_Object
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3228 font_at (c, pos, face, w, string)
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3229 int c;
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3230 EMACS_INT pos;
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3231 struct face *face;
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3232 struct window *w;
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3233 Lisp_Object string;
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3234 {
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3235 FRAME_PTR f;
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3236 int multibyte;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3237 Lisp_Object font_object;
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3238
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3239 if (c < 0)
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3240 {
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3241 if (NILP (string))
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3242 {
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3243 multibyte = ! NILP (current_buffer->enable_multibyte_characters);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3244 if (multibyte)
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3245 {
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3246 EMACS_INT pos_byte = CHAR_TO_BYTE (pos);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3247
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3248 c = FETCH_CHAR (pos_byte);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3249 }
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3250 else
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3251 c = FETCH_BYTE (pos);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3252 }
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3253 else
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3254 {
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3255 unsigned char *str;
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3256
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3257 multibyte = STRING_MULTIBYTE (string);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3258 if (multibyte)
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3259 {
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3260 EMACS_INT pos_byte = string_char_to_byte (string, pos);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3261
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3262 str = SDATA (string) + pos_byte;
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3263 c = STRING_CHAR (str, 0);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3264 }
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3265 else
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3266 c = SDATA (string)[pos];
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3267 }
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3268 }
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3269
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3270 f = XFRAME (w->frame);
90811
c1ed0fd37416 (font_at): If the window W is not on a window system,
Kenichi Handa <handa@m17n.org>
parents: 90695
diff changeset
3271 if (! FRAME_WINDOW_P (f))
c1ed0fd37416 (font_at): If the window W is not on a window system,
Kenichi Handa <handa@m17n.org>
parents: 90695
diff changeset
3272 return Qnil;
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3273 if (! face)
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3274 {
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3275 int face_id;
92237
ce06567a933d * dispextern.h (face_at_buffer_position, face_for_overlay_string)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 92233
diff changeset
3276 EMACS_INT endptr;
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3277
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3278 if (STRINGP (string))
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3279 face_id = face_at_string_position (w, string, pos, 0, -1, -1, &endptr,
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3280 DEFAULT_FACE_ID, 0);
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3281 else
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3282 face_id = face_at_buffer_position (w, pos, -1, -1, &endptr,
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3283 pos + 100, 0);
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3284 face = FACE_FROM_ID (f, face_id);
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3285 }
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3286 if (multibyte)
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3287 {
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3288 int face_id = FACE_FOR_CHAR (f, face, c, pos, string);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3289 face = FACE_FROM_ID (f, face_id);
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
3290 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3291 if (! face->font)
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3292 return Qnil;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3293
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3294 font_assert (font_check_object ((struct font *) face->font));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3295 XSETFONT (font_object, face->font);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3296 return font_object;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3297 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3298
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3299
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3300 /* Check how many characters after POS (at most to LIMIT) can be
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3301 displayed by the same font. FACE is the face selected for the
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3302 character as POS on frame F. STRING, if not nil, is the string to
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3303 check instead of the current buffer.
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
3304
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3305 The return value is the position of the character that is displayed
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3306 by the differnt font than that of the character as POS. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3307
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3308 EMACS_INT
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3309 font_range (pos, limit, face, f, string)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3310 EMACS_INT pos, limit;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3311 struct face *face;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3312 FRAME_PTR f;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3313 Lisp_Object string;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3314 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3315 int multibyte;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3316 EMACS_INT pos_byte;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3317 int c;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3318 struct font *font;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3319 int first = 1;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3320
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3321 if (NILP (string))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3322 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3323 multibyte = ! NILP (current_buffer->enable_multibyte_characters);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3324 pos_byte = CHAR_TO_BYTE (pos);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3325 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3326 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3327 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3328 multibyte = STRING_MULTIBYTE (string);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3329 pos_byte = string_char_to_byte (string, pos);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3330 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3331
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3332 if (! multibyte)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3333 /* All unibyte character are displayed by the same font. */
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3334 return limit;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3335
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3336 while (pos < limit)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3337 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3338 int face_id;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3339
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3340 if (NILP (string))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3341 FETCH_CHAR_ADVANCE_NO_CHECK (c, pos, pos_byte);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3342 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3343 FETCH_STRING_CHAR_ADVANCE_NO_CHECK (c, string, pos, pos_byte);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3344 face_id = FACE_FOR_CHAR (f, face, c, pos, string);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3345 face = FACE_FROM_ID (f, face_id);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3346 if (first)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3347 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3348 font = face->font;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3349 first = 0;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3350 continue;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3351 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3352 else if (font != face->font)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3353 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3354 pos--;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3355 break;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3356 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3357 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3358 return pos;
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3359 }
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3360
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3361
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3362 /* Lisp API */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3363
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3364 DEFUN ("fontp", Ffontp, Sfontp, 1, 2, 0,
91353
b93ade1a3602 (font_find_for_lface): Check if the character C is
Kenichi Handa <handa@m17n.org>
parents: 91350
diff changeset
3365 doc: /* Return t if OBJECT is a font-spec, font-entity, or font-object.
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3366 Return nil otherwise.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3367 Optional 2nd argument EXTRA-TYPE, if non-nil, specifies to check
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
3368 which kind of font it is. It must be one of `font-spec', `font-entity',
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3369 `font-object'. */)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3370 (object, extra_type)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3371 Lisp_Object object, extra_type;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3372 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3373 if (NILP (extra_type))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3374 return (FONTP (object) ? Qt : Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3375 if (EQ (extra_type, Qfont_spec))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3376 return (FONT_SPEC_P (object) ? Qt : Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3377 if (EQ (extra_type, Qfont_entity))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3378 return (FONT_ENTITY_P (object) ? Qt : Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3379 if (EQ (extra_type, Qfont_object))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3380 return (FONT_OBJECT_P (object) ? Qt : Qnil);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3381 wrong_type_argument (intern ("font-extra-type"), extra_type);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3382 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3383
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3384 DEFUN ("font-spec", Ffont_spec, Sfont_spec, 0, MANY, 0,
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3385 doc: /* Return a newly created font-spec with arguments as properties.
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3386
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3387 ARGS must come in pairs KEY VALUE of font properties. KEY must be a
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3388 valid font property name listed below:
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3389
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3390 `:family', `:weight', `:slant', `:width'
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3391
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3392 They are the same as face attributes of the same name. See
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3393 `set-face-attribute'.
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3394
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3395 `:foundry'
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3396
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3397 VALUE must be a string or a symbol specifying the font foundry, e.g. ``misc''.
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3398
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3399 `:adstyle'
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3400
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3401 VALUE must be a string or a symbol specifying the additional
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3402 typographic style information of a font, e.g. ``sans''.
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3403
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3404 `:registry'
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3405
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3406 VALUE must be a string or a symbol specifying the charset registry and
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3407 encoding of a font, e.g. ``iso8859-1''.
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3408
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3409 `:size'
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3410
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3411 VALUE must be a non-negative integer or a floating point number
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3412 specifying the font size. It specifies the font size in pixels
91112
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3413 (if VALUE is an integer), or in points (if VALUE is a float).
8042dbbb0419 (font_update_drivers): Call driver->start_for_frame and
Kenichi Handa <handa@m17n.org>
parents: 91081
diff changeset
3414 usage: (font-spec ARGS ...) */)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3415 (nargs, args)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3416 int nargs;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3417 Lisp_Object *args;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3418 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3419 Lisp_Object spec = font_make_spec ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3420 int i;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3421
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3422 for (i = 0; i < nargs; i += 2)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3423 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3424 Lisp_Object key = args[i], val = args[i + 1];
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3425
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3426 if (EQ (key, QCname))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3427 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3428 CHECK_STRING (val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3429 font_parse_name ((char *) SDATA (val), spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3430 font_put_extra (spec, key, val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3431 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3432 else if (EQ (key, QCfamily))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3433 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3434 CHECK_STRING (val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3435 font_parse_family_registry (val, Qnil, spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3436 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3437 else
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
3438 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3439 int idx = get_font_prop_index (key);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3440
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3441 if (idx >= 0)
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
3442 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3443 val = font_prop_validate (idx, Qnil, val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3444 if (idx < FONT_EXTRA_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3445 ASET (spec, idx, val);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3446 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3447 font_put_extra (spec, key, val);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
3448 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3449 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3450 font_put_extra (spec, key, font_prop_validate (0, key, val));
90451
6ffc9b378367 (enum xlfd_field_index): Rename XLFD_XXX_SIZE_INDEX to
Kenichi Handa <handa@m17n.org>
parents: 90448
diff changeset
3451 }
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3452 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3453 return spec;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3454 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3455
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3456 DEFUN ("copy-font-spec", Fcopy_font_spec, Scopy_font_spec, 1, 1, 0,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3457 doc: /* Return a copy of FONT as a font-spec. */)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3458 (font)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3459 Lisp_Object font;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3460 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3461 Lisp_Object new_spec, tail, extra;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3462 int i;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3463
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3464 CHECK_FONT (font);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3465 new_spec = font_make_spec ();
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3466 for (i = 1; i < FONT_EXTRA_INDEX; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3467 ASET (new_spec, i, AREF (font, i));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3468 extra = Qnil;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3469 for (tail = AREF (font, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3470 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3471 if (! EQ (XCAR (XCAR (tail)), QCfont_entity))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3472 extra = Fcons (Fcons (XCAR (XCAR (tail)), XCDR (XCAR (tail))), extra);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3473 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3474 ASET (new_spec, FONT_EXTRA_INDEX, extra);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3475 return new_spec;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3476 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3477
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3478 DEFUN ("merge-font-spec", Fmerge_font_spec, Smerge_font_spec, 2, 2, 0,
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3479 doc: /* Merge font-specs FROM and TO, and return a new font-spec.
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3480 Every specified properties in FROM override the corresponding
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3481 properties in TO. */)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3482 (from, to)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3483 Lisp_Object from, to;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3484 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3485 Lisp_Object extra, tail;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3486 int i;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3487
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3488 CHECK_FONT (from);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3489 CHECK_FONT (to);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3490 to = Fcopy_font_spec (to);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3491 for (i = 0; i < FONT_EXTRA_INDEX; i++)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3492 ASET (to, i, AREF (from, i));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3493 extra = AREF (to, FONT_EXTRA_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3494 for (tail = AREF (from, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3495 if (! EQ (XCAR (XCAR (tail)), Qfont_entity))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3496 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3497 Lisp_Object slot = assq_no_quit (XCAR (XCAR (tail)), extra);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3498
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3499 if (! NILP (slot))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3500 XSETCDR (slot, XCDR (XCAR (tail)));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3501 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3502 extra = Fcons (Fcons (XCAR (XCAR (tail)), XCDR (XCAR (tail))), extra);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3503 }
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3504 ASET (to, FONT_EXTRA_INDEX, extra);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3505 return to;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3506 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3507
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3508 DEFUN ("font-get", Ffont_get, Sfont_get, 2, 2, 0,
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3509 doc: /* Return the value of FONT's property KEY.
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
3510 FONT is a font-spec, a font-entity, or a font-object. */)
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3511 (font, key)
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3512 Lisp_Object font, key;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3513 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3514 int idx;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3515
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3516 CHECK_FONT (font);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3517 CHECK_SYMBOL (key);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3518
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3519 idx = get_font_prop_index (key);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3520 if (idx >= 0 && idx < FONT_EXTRA_INDEX)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3521 return AREF (font, idx);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3522 return Fcdr (Fassq (key, AREF (font, FONT_EXTRA_INDEX)));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3523 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3524
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3525
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3526 DEFUN ("font-put", Ffont_put, Sfont_put, 3, 3, 0,
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3527 doc: /* Set one property of FONT-SPEC: give property PROP value VAL. */)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3528 (font_spec, prop, val)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3529 Lisp_Object font_spec, prop, val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3530 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3531 int idx;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3532
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3533 CHECK_FONT_SPEC (font_spec);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3534 idx = get_font_prop_index (prop);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3535 if (idx >= 0 && idx < FONT_EXTRA_INDEX)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3536 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3537 if (idx == FONT_FAMILY_INDEX
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3538 && STRINGP (val))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3539 font_parse_family_registry (val, Qnil, font_spec);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3540 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3541 ASET (font_spec, idx, font_prop_validate (idx, Qnil, val));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3542 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3543 else
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3544 font_put_extra (font_spec, prop, font_prop_validate (0, prop, val));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3545 return val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3546 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3547
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3548 DEFUN ("list-fonts", Flist_fonts, Slist_fonts, 1, 4, 0,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3549 doc: /* List available fonts matching FONT-SPEC on the current frame.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3550 Optional 2nd argument FRAME specifies the target frame.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3551 Optional 3rd argument NUM, if non-nil, limits the number of returned fonts.
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3552 Optional 4th argument PREFER, if non-nil, is a font-spec to
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3553 control the order of the returned list. Fonts are sorted by
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
3554 how close they are to PREFER. */)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3555 (font_spec, frame, num, prefer)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3556 Lisp_Object font_spec, frame, num, prefer;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3557 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3558 Lisp_Object vec, list, tail;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3559 int n = 0, i, len;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3560
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3561 if (NILP (frame))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3562 frame = selected_frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3563 CHECK_LIVE_FRAME (frame);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3564 CHECK_FONT_SPEC (font_spec);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3565 if (! NILP (num))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3566 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3567 CHECK_NUMBER (num);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3568 n = XINT (num);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3569 if (n <= 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3570 return Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3571 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3572 if (! NILP (prefer))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3573 CHECK_FONT_SPEC (prefer);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3574
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3575 vec = font_list_entities (frame, font_spec);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3576 len = ASIZE (vec);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3577 if (len == 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3578 return Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3579 if (len == 1)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3580 return Fcons (AREF (vec, 0), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3581
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3582 if (! NILP (prefer))
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3583 vec = font_sort_entites (vec, prefer, frame, font_spec, 0);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3584
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3585 list = tail = Fcons (AREF (vec, 0), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3586 if (n == 0 || n > len)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3587 n = len;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3588 for (i = 1; i < n; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3589 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3590 Lisp_Object val = Fcons (AREF (vec, i), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3591
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3592 XSETCDR (tail, val);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3593 tail = val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3594 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3595 return list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3596 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3597
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3598 DEFUN ("font-family-list", Ffont_family_list, Sfont_family_list, 0, 1, 0,
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3599 doc: /* List available font families on the current frame.
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
3600 Optional argument FRAME, if non-nil, specifies the target frame. */)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3601 (frame)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3602 Lisp_Object frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3603 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3604 FRAME_PTR f;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3605 struct font_driver_list *driver_list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3606 Lisp_Object list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3607
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3608 if (NILP (frame))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3609 frame = selected_frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3610 CHECK_LIVE_FRAME (frame);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3611 f = XFRAME (frame);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3612 list = Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3613 for (driver_list = f->font_driver_list; driver_list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3614 driver_list = driver_list->next)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3615 if (driver_list->driver->list_family)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3616 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3617 Lisp_Object val = driver_list->driver->list_family (frame);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3618
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3619 if (NILP (list))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3620 list = val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3621 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3622 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3623 Lisp_Object tail = list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3624
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3625 for (; CONSP (val); val = XCDR (val))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3626 if (NILP (Fmemq (XCAR (val), tail)))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3627 list = Fcons (XCAR (val), list);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3628 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3629 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3630 return list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3631 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3632
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3633 DEFUN ("find-font", Ffind_font, Sfind_font, 1, 2, 0,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3634 doc: /* Return a font-entity matching with FONT-SPEC on the current frame.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3635 Optional 2nd argument FRAME, if non-nil, specifies the target frame. */)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3636 (font_spec, frame)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3637 Lisp_Object font_spec, frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3638 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3639 Lisp_Object val = Flist_fonts (font_spec, frame, make_number (1), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3640
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3641 if (CONSP (val))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3642 val = XCAR (val);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3643 return val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3644 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3645
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3646 DEFUN ("font-xlfd-name", Ffont_xlfd_name, Sfont_xlfd_name, 1, 2, 0,
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3647 doc: /* Return XLFD name of FONT.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3648 FONT is a font-spec, font-entity, or font-object.
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3649 If the name is too long for XLFD (maximum 255 chars), return nil.
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3650 If the 2nd optional arg FOLD-WILDCARDS is non-nil,
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3651 the consecutive wildcards are folded to one. */)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3652 (font, fold_wildcards)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3653 Lisp_Object font, fold_wildcards;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3654 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3655 char name[256];
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3656 int pixel_size = 0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3657
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3658 CHECK_FONT (font);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3659
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3660 if (FONT_OBJECT_P (font))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3661 {
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3662 Lisp_Object font_name = AREF (font, FONT_NAME_INDEX);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3663
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3664 if (STRINGP (font_name)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3665 && SDATA (font_name)[0] == '-')
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3666 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3667 if (NILP (fold_wildcards))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3668 return font_name;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3669 strcpy (name, (char *) SDATA (font_name));
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3670 goto done;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3671 }
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3672 pixel_size = XFONT_OBJECT (font)->pixel_size;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3673 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3674 if (font_unparse_xlfd (font, pixel_size, name, 256) < 0)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3675 return Qnil;
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3676 done:
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3677 if (! NILP (fold_wildcards))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3678 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3679 char *p0 = name, *p1;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3680
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3681 while ((p1 = strstr (p0, "-*-*")))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3682 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3683 strcpy (p1, p1 + 2);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3684 p0 = p1;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3685 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3686 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3687
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3688 return build_string (name);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3689 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3690
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3691 DEFUN ("clear-font-cache", Fclear_font_cache, Sclear_font_cache, 0, 0, 0,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3692 doc: /* Clear font cache. */)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3693 ()
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3694 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3695 Lisp_Object list, frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3696
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3697 FOR_EACH_FRAME (list, frame)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3698 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3699 FRAME_PTR f = XFRAME (frame);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3700 struct font_driver_list *driver_list = f->font_driver_list;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3701
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3702 for (; driver_list; driver_list = driver_list->next)
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3703 if (driver_list->on)
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3704 {
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3705 Lisp_Object cache = driver_list->driver->get_cache (f);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3706 Lisp_Object val;
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3707
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3708 val = XCDR (cache);
91909
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
3709 while (! NILP (val)
a549624ad4bc Include xterm.h.
Kenichi Handa <handa@m17n.org>
parents: 91871
diff changeset
3710 && ! EQ (XCAR (XCAR (val)), driver_list->driver->type))
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3711 val = XCDR (val);
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3712 font_assert (! NILP (val));
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3713 val = XCDR (XCAR (val));
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3714 if (XINT (XCAR (val)) == 0)
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3715 {
91247
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3716 font_clear_cache (f, XCAR (val), driver_list->driver);
217eabc2db11 (font_prepare_cache, font_finish_cache, font_get_cache): New
Kenichi Handa <handa@m17n.org>
parents: 91240
diff changeset
3717 XSETCDR (cache, XCDR (val));
90549
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3718 }
5dab62a4573c (font_unparse_fcname): Fix typo (swidth->width).
Kenichi Handa <handa@m17n.org>
parents: 90541
diff changeset
3719 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3720 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3721
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3722 return Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3723 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3724
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
3725 /* The following three functions are still expremental. */
91081
2c767d9f0bb1 (font_prop_validate_symbol): The argument prop_index is
Kenichi Handa <handa@m17n.org>
parents: 90993
diff changeset
3726
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3727 DEFUN ("font-make-gstring", Ffont_make_gstring, Sfont_make_gstring, 2, 2, 0,
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3728 doc: /* Return a newly created g-string for FONT-OBJECT with NUM glyphs.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3729 FONT-OBJECT may be nil if it is not yet known.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3730
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3731 G-string is sequence of glyphs of a specific font,
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3732 and is a vector of this form:
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3733 [ HEADER GLYPH ... ]
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3734 HEADER is a vector of this form:
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3735 [FONT-OBJECT WIDTH LBEARING RBEARING ASCENT DESCENT]
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3736 where
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
3737 FONT-OBJECT is a font-object for all glyphs in the g-string,
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
3738 WIDTH thru DESCENT are the metrics (in pixels) of the whole G-string.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3739 GLYPH is a vector of this form:
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3740 [ FROM-IDX TO-IDX C CODE WIDTH LBEARING RBEARING ASCENT DESCENT
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3741 [ [X-OFF Y-OFF WADJUST] | nil] ]
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3742 where
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3743 FROM-IDX and TO-IDX are used internally and should not be touched.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3744 C is the character of the glyph.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3745 CODE is the glyph-code of C in FONT-OBJECT.
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
3746 WIDTH thru DESCENT are the metrics (in pixels) of the glyph.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3747 X-OFF and Y-OFF are offests to the base position for the glyph.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3748 WADJUST is the adjustment to the normal width of the glyph. */)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3749 (font_object, num)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3750 Lisp_Object font_object, num;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3751 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3752 Lisp_Object gstring, g;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3753 int len;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3754 int i;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3755
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3756 if (! NILP (font_object))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3757 CHECK_FONT_OBJECT (font_object);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3758 CHECK_NATNUM (num);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3759
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3760 len = XINT (num) + 1;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3761 gstring = Fmake_vector (make_number (len), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3762 g = Fmake_vector (make_number (6), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3763 ASET (g, 0, font_object);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3764 ASET (gstring, 0, g);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3765 for (i = 1; i < len; i++)
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3766 ASET (gstring, i, Fmake_vector (make_number (10), Qnil));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3767 return gstring;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3768 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3769
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3770 DEFUN ("font-fill-gstring", Ffont_fill_gstring, Sfont_fill_gstring, 4, 5, 0,
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3771 doc: /* Fill in glyph-string GSTRING by characters for FONT-OBJECT.
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3772 START and END specify the region to extract characters.
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3773 If optional 5rd argument OBJECT is non-nil, it is a buffer or a string from
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3774 where to extract characters.
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
3775 FONT-OBJECT may be nil if GSTRING already contains one. */)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3776 (gstring, font_object, start, end, object)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3777 Lisp_Object gstring, font_object, start, end, object;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3778 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3779 int len, i, c;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3780 unsigned code;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3781 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3782
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3783 CHECK_VECTOR (gstring);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3784 if (NILP (font_object))
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3785 font_object = LGSTRING_FONT (gstring);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3786 font = XFONT_OBJECT (font_object);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3787
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3788 if (STRINGP (object))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3789 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3790 const unsigned char *p;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3791
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3792 CHECK_NATNUM (start);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3793 CHECK_NATNUM (end);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3794 if (XINT (start) > XINT (end)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3795 || XINT (end) > ASIZE (object)
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3796 || XINT (end) - XINT (start) > LGSTRING_LENGTH (gstring))
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3797 args_out_of_range_3 (object, start, end);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3798
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3799 len = XINT (end) - XINT (start);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3800 p = SDATA (object) + string_char_to_byte (object, XINT (start));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3801 for (i = 0; i < len; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3802 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3803 Lisp_Object g = LGSTRING_GLYPH (gstring, i);
91871
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3804 /* Shut up GCC warning in comparison with
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3805 MOST_POSITIVE_FIXNUM below. */
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3806 EMACS_INT cod;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3807
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3808 c = STRING_CHAR_ADVANCE (p);
91871
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3809 cod = code = font->driver->encode_char (font, c);
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3810 if (cod > MOST_POSITIVE_FIXNUM || code == FONT_INVALID_CODE)
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3811 break;
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3812 LGLYPH_SET_FROM (g, i);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3813 LGLYPH_SET_TO (g, i);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3814 LGLYPH_SET_CHAR (g, c);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3815 LGLYPH_SET_CODE (g, code);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3816 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3817 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3818 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3819 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3820 int pos, pos_byte;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3821
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3822 if (! NILP (object))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3823 Fset_buffer (object);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3824 validate_region (&start, &end);
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3825 if (XINT (end) - XINT (start) > LGSTRING_LENGTH (gstring))
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3826 args_out_of_range (start, end);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3827 len = XINT (end) - XINT (start);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3828 pos = XINT (start);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3829 pos_byte = CHAR_TO_BYTE (pos);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3830 for (i = 0; i < len; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3831 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3832 Lisp_Object g = LGSTRING_GLYPH (gstring, i);
91871
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3833 /* Shut up GCC warning in comparison with
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3834 MOST_POSITIVE_FIXNUM below. */
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3835 EMACS_INT cod;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3836
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3837 FETCH_CHAR_ADVANCE (c, pos, pos_byte);
91871
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3838 cod = code = font->driver->encode_char (font, c);
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
3839 if (cod > MOST_POSITIVE_FIXNUM || code == FONT_INVALID_CODE)
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3840 break;
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3841 LGLYPH_SET_FROM (g, i);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3842 LGLYPH_SET_TO (g, i);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3843 LGLYPH_SET_CHAR (g, c);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3844 LGLYPH_SET_CODE (g, code);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3845 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3846 }
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3847 for (; i < LGSTRING_LENGTH (gstring); i++)
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3848 LGSTRING_SET_GLYPH (gstring, i, Qnil);
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3849 return Qnil;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3850 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3851
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3852 DEFUN ("font-shape-text", Ffont_shape_text, Sfont_shape_text, 3, 4, 0,
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3853 doc: /* Shape text between FROM and TO by FONT-OBJECT.
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3854 If optional 4th argument STRING is non-nil, it is a string to shape,
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3855 and FROM and TO are indices to the string.
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3856 The value is the end position of the text that can be shaped by
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3857 FONT-OBJECT. */)
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3858 (from, to, font_object, string)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3859 Lisp_Object from, to, font_object, string;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3860 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3861 struct font *font;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3862 struct font_metrics metrics;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3863 EMACS_INT start, end;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3864 Lisp_Object gstring, n;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3865 int len, i;
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3866
92183
275e5e980fc4 If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents: 92113
diff changeset
3867 if (! FONT_OBJECT_P (font_object))
275e5e980fc4 If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents: 92113
diff changeset
3868 return Qnil;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
3869 font = XFONT_OBJECT (font_object);
92183
275e5e980fc4 If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents: 92113
diff changeset
3870 if (! font->driver->shape)
275e5e980fc4 If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents: 92113
diff changeset
3871 return Qnil;
275e5e980fc4 If the font driver doesn't have `shape' function, return Qnil.
Kenichi Handa <handa@m17n.org>
parents: 92113
diff changeset
3872
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3873 if (NILP (string))
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3874 {
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3875 validate_region (&from, &to);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3876 start = XFASTINT (from);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3877 end = XFASTINT (to);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3878 modify_region (current_buffer, start, end, 0);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3879 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3880 else
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3881 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3882 CHECK_STRING (string);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3883 start = XINT (from);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3884 end = XINT (to);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3885 if (start < 0 || start > end || end > SCHARS (string))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3886 args_out_of_range_3 (string, from, to);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3887 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3888
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3889 len = end - start;
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3890 gstring = Ffont_make_gstring (font_object, make_number (len));
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3891 Ffont_fill_gstring (gstring, font_object, from, to, string);
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3892
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3893 /* Try at most three times with larger gstring each time. */
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3894 for (i = 0; i < 3; i++)
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3895 {
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3896 Lisp_Object args[2];
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3897
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3898 n = font->driver->shape (gstring);
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3899 if (INTEGERP (n))
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3900 break;
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3901 args[0] = gstring;
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3902 args[1] = Fmake_vector (make_number (len), Qnil);
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3903 gstring = Fvconcat (2, args);
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3904 }
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3905 if (! INTEGERP (n) || XINT (n) == 0)
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3906 return Qnil;
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3907 len = XINT (n);
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3908
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3909 for (i = 0; i < len;)
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3910 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3911 Lisp_Object gstr;
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3912 Lisp_Object g = LGSTRING_GLYPH (gstring, i);
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3913 EMACS_INT this_from = LGLYPH_FROM (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3914 EMACS_INT this_to = LGLYPH_TO (g) + 1;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3915 int j, k;
91267
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3916 int need_composition = 0;
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3917
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3918 metrics.lbearing = LGLYPH_LBEARING (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3919 metrics.rbearing = LGLYPH_RBEARING (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3920 metrics.ascent = LGLYPH_ASCENT (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3921 metrics.descent = LGLYPH_DESCENT (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3922 if (NILP (LGLYPH_ADJUSTMENT (g)))
91267
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3923 {
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3924 metrics.width = LGLYPH_WIDTH (g);
91550
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
3925 if (LGLYPH_CHAR (g) == 0 || metrics.width == 0)
91267
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3926 need_composition = 1;
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3927 }
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3928 else
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3929 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3930 metrics.width = LGLYPH_WADJUST (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3931 metrics.lbearing += LGLYPH_XOFF (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3932 metrics.rbearing += LGLYPH_XOFF (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3933 metrics.ascent -= LGLYPH_YOFF (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3934 metrics.descent += LGLYPH_YOFF (g);
91267
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3935 need_composition = 1;
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3936 }
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
3937 for (j = i + 1; j < len; j++)
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3938 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3939 int x;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3940
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3941 g = LGSTRING_GLYPH (gstring, j);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3942 if (this_from != LGLYPH_FROM (g))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3943 break;
91267
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3944 need_composition = 1;
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3945 x = metrics.width + LGLYPH_LBEARING (g) + LGLYPH_XOFF (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3946 if (metrics.lbearing > x)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3947 metrics.lbearing = x;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3948 x = metrics.width + LGLYPH_RBEARING (g) + LGLYPH_XOFF (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3949 if (metrics.rbearing < x)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3950 metrics.rbearing = x;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3951 x = LGLYPH_ASCENT (g) - LGLYPH_YOFF (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3952 if (metrics.ascent < x)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3953 metrics.ascent = x;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3954 x = LGLYPH_DESCENT (g) - LGLYPH_YOFF (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3955 if (metrics.descent < x)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3956 metrics.descent = x;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3957 if (NILP (LGLYPH_ADJUSTMENT (g)))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3958 metrics.width += LGLYPH_WIDTH (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3959 else
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3960 metrics.width += LGLYPH_WADJUST (g);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3961 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3962
91267
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3963 if (need_composition)
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3964 {
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3965 gstr = Ffont_make_gstring (font_object, make_number (j - i));
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3966 LGSTRING_SET_WIDTH (gstr, metrics.width);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3967 LGSTRING_SET_LBEARING (gstr, metrics.lbearing);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3968 LGSTRING_SET_RBEARING (gstr, metrics.rbearing);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3969 LGSTRING_SET_ASCENT (gstr, metrics.ascent);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3970 LGSTRING_SET_DESCENT (gstr, metrics.descent);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3971 for (k = i; i < j; i++)
91307
0afaa00ae397 (Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents: 91273
diff changeset
3972 {
0afaa00ae397 (Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents: 91273
diff changeset
3973 Lisp_Object g = LGSTRING_GLYPH (gstring, i);
0afaa00ae397 (Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents: 91273
diff changeset
3974
0afaa00ae397 (Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents: 91273
diff changeset
3975 LGLYPH_SET_FROM (g, LGLYPH_FROM (g) - this_from);
91309
3f56aab091ed (Ffont_shape_text): Fix setting of `to' field of glyphs.
Kenichi Handa <handa@m17n.org>
parents: 91307
diff changeset
3976 LGLYPH_SET_TO (g, LGLYPH_TO (g) - this_from);
91307
0afaa00ae397 (Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents: 91273
diff changeset
3977 LGSTRING_SET_GLYPH (gstr, i - k, LGSTRING_GLYPH (gstring, i));
0afaa00ae397 (Ffont_shape_text): If the font driver doesn't have a
Kenichi Handa <handa@m17n.org>
parents: 91273
diff changeset
3978 }
91267
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3979 from = make_number (start + this_from);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3980 to = make_number (start + this_to);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3981 if (NILP (string))
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3982 Fcompose_region_internal (from, to, gstr, Qnil);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3983 else
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3984 Fcompose_string_internal (string, from, to, gstr, Qnil);
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3985 }
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3986 else
91267
0fa5916e5871 (Ffont_shape_text): Avoid unnecessary composition.
Kenichi Handa <handa@m17n.org>
parents: 91261
diff changeset
3987 i = j;
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
3988 }
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
3989
91192
bcad98389aeb (Ffont_shape_text): Fix the return value.
Kenichi Handa <handa@m17n.org>
parents: 91174
diff changeset
3990 return to;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3991 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
3992
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
3993 DEFUN ("font-drive-otf", Ffont_drive_otf, Sfont_drive_otf, 6, 6, 0,
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
3994 doc: /* Apply OpenType features on glyph-string GSTRING-IN.
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
3995 OTF-FEATURES specifies which features to apply in this format:
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
3996 (SCRIPT LANGSYS GSUB GPOS)
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3997 where
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3998 SCRIPT is a symbol specifying a script tag of OpenType,
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
3999 LANGSYS is a symbol specifying a langsys tag of OpenType,
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4000 GSUB and GPOS, if non-nil, are lists of symbols specifying feature tags.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4001
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4002 If LANGYS is nil, the default langsys is selected.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4003
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4004 The features are applied in the order they appear in the list. The
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4005 symbol `*' means to apply all available features not present in this
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4006 list, and the remaining features are ignored. For instance, (vatu
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4007 pstf * haln) is to apply vatu and pstf in this order, then to apply
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4008 all available features other than vatu, pstf, and haln.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4009
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4010 The features are applied to the glyphs in the range FROM and TO of
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4011 the glyph-string GSTRING-IN.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4012
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4013 If some feature is actually applicable, the resulting glyphs are
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4014 produced in the glyph-string GSTRING-OUT from the index INDEX. In
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4015 this case, the value is the number of produced glyphs.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4016
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4017 If no feature is applicable, no glyph is produced in GSTRING-OUT, and
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4018 the value is 0.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4019
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4020 If GSTRING-OUT is too short to hold produced glyphs, no glyphs are
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4021 produced in GSTRING-OUT, and the value is nil.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4022
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4023 See the documentation of `font-make-gstring' for the format of
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4024 glyph-string. */)
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4025 (otf_features, gstring_in, from, to, gstring_out, index)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4026 Lisp_Object otf_features, gstring_in, from, to, gstring_out, index;
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4027 {
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4028 Lisp_Object font_object = LGSTRING_FONT (gstring_in);
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4029 Lisp_Object val;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4030 struct font *font;
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4031 int len, num;
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4032
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4033 check_otf_features (otf_features);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4034 CHECK_FONT_OBJECT (font_object);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4035 font = XFONT_OBJECT (font_object);
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4036 if (! font->driver->otf_drive)
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4037 error ("Font backend %s can't drive OpenType GSUB table",
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4038 SDATA (SYMBOL_NAME (font->driver->type)));
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4039 CHECK_CONS (otf_features);
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4040 CHECK_SYMBOL (XCAR (otf_features));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4041 val = XCDR (otf_features);
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4042 CHECK_SYMBOL (XCAR (val));
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4043 val = XCDR (otf_features);
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4044 if (! NILP (val))
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4045 CHECK_CONS (val);
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4046 len = check_gstring (gstring_in);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4047 CHECK_VECTOR (gstring_out);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4048 CHECK_NATNUM (from);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4049 CHECK_NATNUM (to);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4050 CHECK_NATNUM (index);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4051
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4052 if (XINT (from) >= XINT (to) || XINT (to) > len)
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4053 args_out_of_range_3 (from, to, make_number (len));
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4054 if (XINT (index) >= ASIZE (gstring_out))
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4055 args_out_of_range (index, make_number (ASIZE (gstring_out)));
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4056 num = font->driver->otf_drive (font, otf_features,
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4057 gstring_in, XINT (from), XINT (to),
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4058 gstring_out, XINT (index), 0);
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4059 if (num < 0)
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4060 return Qnil;
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4061 return make_number (num);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4062 }
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4063
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4064 DEFUN ("font-otf-alternates", Ffont_otf_alternates, Sfont_otf_alternates,
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4065 3, 3, 0,
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4066 doc: /* Return a list of alternate glyphs of CHARACTER in FONT-OBJECT.
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4067 OTF-FEATURES specifies which features of the font FONT-OBJECT to apply
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4068 in this format:
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4069 (SCRIPT LANGSYS FEATURE ...)
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
4070 See the documentation of `font-drive-otf' for more detail.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4071
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4072 The value is a list of cons cells of the format (GLYPH-ID . CHARACTER),
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4073 where GLYPH-ID is a glyph index of the font, and CHARACTER is a
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4074 character code corresponding to the glyph or nil if there's no
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4075 corresponding character. */)
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4076 (font_object, character, otf_features)
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4077 Lisp_Object font_object, character, otf_features;
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4078 {
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4079 struct font *font;
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4080 Lisp_Object gstring_in, gstring_out, g;
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4081 Lisp_Object alternates;
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4082 int i, num;
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4083
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4084 CHECK_FONT_GET_OBJECT (font_object, font);
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4085 if (! font->driver->otf_drive)
90563
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
4086 error ("Font backend %s can't drive OpenType GSUB table",
7c29515f7c2a (font_parse_fcname): Don't change :name property of FONT.
Kenichi Handa <handa@m17n.org>
parents: 90556
diff changeset
4087 SDATA (SYMBOL_NAME (font->driver->type)));
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4088 CHECK_CHARACTER (character);
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4089 CHECK_CONS (otf_features);
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4090
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4091 gstring_in = Ffont_make_gstring (font_object, make_number (1));
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4092 g = LGSTRING_GLYPH (gstring_in, 0);
91550
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
4093 LGLYPH_SET_CHAR (g, XINT (character));
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4094 gstring_out = Ffont_make_gstring (font_object, make_number (10));
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4095 while ((num = font->driver->otf_drive (font, otf_features, gstring_in, 0, 1,
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4096 gstring_out, 0, 1)) < 0)
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4097 gstring_out = Ffont_make_gstring (font_object,
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4098 make_number (ASIZE (gstring_out) * 2));
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4099 alternates = Qnil;
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4100 for (i = 0; i < num; i++)
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4101 {
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4102 Lisp_Object g = LGSTRING_GLYPH (gstring_out, i);
91550
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
4103 int c = LGLYPH_CHAR (g);
83267bc0360a (check_gstring): Use them and AREF to access the vector before
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 91360
diff changeset
4104 unsigned code = LGLYPH_CODE (g);
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4105
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4106 alternates = Fcons (Fcons (make_number (code),
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4107 c > 0 ? make_number (c) : Qnil),
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4108 alternates);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4109 }
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4110 return Fnreverse (alternates);
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4111 }
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4112
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4113
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4114 #ifdef FONT_DEBUG
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4115
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4116 DEFUN ("open-font", Fopen_font, Sopen_font, 1, 3, 0,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4117 doc: /* Open FONT-ENTITY. */)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4118 (font_entity, size, frame)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4119 Lisp_Object font_entity;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4120 Lisp_Object size;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4121 Lisp_Object frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4122 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4123 int isize;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4124
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4125 CHECK_FONT_ENTITY (font_entity);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4126 if (NILP (frame))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4127 frame = selected_frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4128 CHECK_LIVE_FRAME (frame);
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4129
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4130 if (NILP (size))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4131 isize = XINT (AREF (font_entity, FONT_SIZE_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4132 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4133 {
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4134 CHECK_NUMBER_OR_FLOAT (size);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4135 if (FLOATP (size))
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4136 isize = POINT_TO_PIXEL (- isize, XFRAME (frame)->resy);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4137 else
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4138 isize = XINT (size);
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4139 if (isize == 0)
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4140 isize = 120;
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4141 }
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4142 return font_open_entity (XFRAME (frame), font_entity, isize);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4143 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4144
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4145 DEFUN ("close-font", Fclose_font, Sclose_font, 1, 2, 0,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4146 doc: /* Close FONT-OBJECT. */)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4147 (font_object, frame)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4148 Lisp_Object font_object, frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4149 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4150 CHECK_FONT_OBJECT (font_object);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4151 if (NILP (frame))
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4152 frame = selected_frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4153 CHECK_LIVE_FRAME (frame);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4154 font_close_object (XFRAME (frame), font_object);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4155 return Qnil;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4156 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4157
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4158 DEFUN ("query-font", Fquery_font, Squery_font, 1, 1, 0,
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4159 doc: /* Return information about FONT-OBJECT.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4160 The value is a vector:
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4161 [ NAME FILENAME PIXEL-SIZE SIZE ASCENT DESCENT SPACE-WIDTH AVERAGE-WIDTH
90677
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4162 CAPABILITY ]
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4163
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4164 NAME is a string of the font name (or nil if the font backend doesn't
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4165 provide a name).
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4166
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4167 FILENAME is a string of the font file (or nil if the font backend
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4168 doesn't provide a file name).
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4169
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4170 PIXEL-SIZE is a pixel size by which the font is opened.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4171
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
4172 SIZE is a maximum advance width of the font in pixels.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4173
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4174 ASCENT, DESCENT, SPACE-WIDTH, AVERAGE-WIDTH are metrics of the font in
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
4175 pixels.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4176
90677
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4177 CAPABILITY is a list whose first element is a symbol representing the
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4178 font format \(x, opentype, truetype, type1, pcf, or bdf) and the
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
4179 remaining elements describe the details of the font capability.
90677
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4180
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4181 If the font is OpenType font, the form of the list is
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4182 \(opentype GSUB GPOS)
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4183 where GSUB shows which "GSUB" features the font supports, and GPOS
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4184 shows which "GPOS" features the font supports. Both GSUB and GPOS are
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4185 lists of the format:
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4186 \((SCRIPT (LANGSYS FEATURE ...) ...) ...)
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4187
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4188 If the font is not OpenType font, currently the length of the form is
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4189 one.
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4190
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4191 SCRIPT is a symbol representing OpenType script tag.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4192
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4193 LANGSYS is a symbol representing OpenType langsys tag, or nil
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4194 representing the default langsys.
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4195
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4196 FEATURE is a symbol representing OpenType feature tag.
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4197
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4198 If the font is not OpenType font, CAPABILITY is nil. */)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4199 (font_object)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4200 Lisp_Object font_object;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4201 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4202 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4203 Lisp_Object val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4204
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4205 CHECK_FONT_GET_OBJECT (font_object, font);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4206
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4207 val = Fmake_vector (make_number (9), Qnil);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4208 ASET (val, 0, AREF (font_object, FONT_NAME_INDEX));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4209 ASET (val, 1, AREF (font_object, FONT_FILE_INDEX));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4210 ASET (val, 2, make_number (font->pixel_size));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4211 ASET (val, 3, make_number (font->max_width));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4212 ASET (val, 4, make_number (font->ascent));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4213 ASET (val, 5, make_number (font->descent));
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4214 ASET (val, 6, make_number (font->space_width));
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4215 ASET (val, 7, make_number (font->average_width));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4216 if (font->driver->otf_capability)
90677
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4217 ASET (val, 8, Fcons (Qopentype, font->driver->otf_capability (font)));
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4218 return val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4219 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4220
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4221 DEFUN ("get-font-glyphs", Fget_font_glyphs, Sget_font_glyphs, 2, 2, 0,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4222 doc: /* Return a vector of glyphs of FONT-OBJECT for drawing STRING.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4223 Each element is a vector [GLYPH-CODE LBEARING RBEARING WIDTH ASCENT DESCENT]. */)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4224 (font_object, string)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4225 Lisp_Object font_object, string;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4226 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4227 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4228 int i, len;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4229 Lisp_Object vec;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4230
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4231 CHECK_FONT_GET_OBJECT (font_object, font);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4232 CHECK_STRING (string);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4233 len = SCHARS (string);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4234 vec = Fmake_vector (make_number (len), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4235 for (i = 0; i < len; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4236 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4237 Lisp_Object ch = Faref (string, make_number (i));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4238 Lisp_Object val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4239 int c = XINT (ch);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4240 unsigned code;
91871
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
4241 EMACS_INT cod;
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4242 struct font_metrics metrics;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4243
91871
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
4244 cod = code = font->driver->encode_char (font, c);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4245 if (code == FONT_INVALID_CODE)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4246 continue;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4247 val = Fmake_vector (make_number (6), Qnil);
91871
436548f01688 (Ffont_fill_gstring, Fget_font_glyphs): Fix compilation warnings.
Eli Zaretskii <eliz@gnu.org>
parents: 91553
diff changeset
4248 if (cod <= MOST_POSITIVE_FIXNUM)
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4249 ASET (val, 0, make_number (code));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4250 else
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4251 ASET (val, 0, Fcons (make_number (code >> 16),
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4252 make_number (code & 0xFFFF)));
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4253 font->driver->text_extents (font, &code, 1, &metrics);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4254 ASET (val, 1, make_number (metrics.lbearing));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4255 ASET (val, 2, make_number (metrics.rbearing));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4256 ASET (val, 3, make_number (metrics.width));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4257 ASET (val, 4, make_number (metrics.ascent));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4258 ASET (val, 5, make_number (metrics.descent));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4259 ASET (vec, i, val);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4260 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4261 return vec;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4262 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4263
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4264 DEFUN ("font-match-p", Ffont_match_p, Sfont_match_p, 2, 2, 0,
94745
a995b289585f (Ffont_match_p): Don't use `iff' in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 94394
diff changeset
4265 doc: /* Return t if and only if font-spec SPEC matches with FONT.
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4266 FONT is a font-spec, font-entity, or font-object. */)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4267 (spec, font)
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4268 Lisp_Object spec, font;
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4269 {
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4270 CHECK_FONT_SPEC (spec);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4271 CHECK_FONT (font);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4272
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4273 return (font_match_p (spec, font) ? Qt : Qnil);
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4274 }
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4275
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4276 DEFUN ("font-at", Ffont_at, Sfont_at, 1, 3, 0,
92233
3642a8778bbf (Ffont_spec, Ffont_at): Fix typos in docstrings.
Juanma Barranquero <lekktu@gmail.com>
parents: 92183
diff changeset
4277 doc: /* Return a font-object for displaying a character at POSITION.
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4278 Optional second arg WINDOW, if non-nil, is a window displaying
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4279 the current buffer. It defaults to the currently selected window. */)
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4280 (position, window, string)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4281 Lisp_Object position, window, string;
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4282 {
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4283 struct window *w;
91236
e3ba579aab1f (font_at): Handle the case that the arg C is negative.
Kenichi Handa <handa@m17n.org>
parents: 91192
diff changeset
4284 EMACS_INT pos;
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4285
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4286 if (NILP (string))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4287 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4288 CHECK_NUMBER_COERCE_MARKER (position);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4289 pos = XINT (position);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4290 if (pos < BEGV || pos >= ZV)
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4291 args_out_of_range_3 (position, make_number (BEGV), make_number (ZV));
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4292 }
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4293 else
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4294 {
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4295 CHECK_NUMBER (position);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4296 CHECK_STRING (string);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4297 pos = XINT (position);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4298 if (pos < 0 || pos >= SCHARS (string))
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4299 args_out_of_range (string, position);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4300 }
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4301 if (NILP (window))
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4302 window = selected_window;
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4303 CHECK_LIVE_WINDOW (window);
91273
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
4304 w = XWINDOW (window);
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
4305
f19e3a3100e2 (Ffont_fill_gstring): Stop filling when a character not
Kenichi Handa <handa@m17n.org>
parents: 91267
diff changeset
4306 return font_at (-1, pos, NULL, w, string);
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4307 }
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4308
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4309 #if 0
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4310 DEFUN ("draw-string", Fdraw_string, Sdraw_string, 2, 2, 0,
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4311 doc: /* Draw STRING by FONT-OBJECT on the top left corner of the current frame.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4312 The value is a number of glyphs drawn.
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4313 Type C-l to recover what previously shown. */)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4314 (font_object, string)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4315 Lisp_Object font_object, string;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4316 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4317 Lisp_Object frame = selected_frame;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4318 FRAME_PTR f = XFRAME (frame);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4319 struct font *font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4320 struct face *face;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4321 int i, len, width;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4322 unsigned *code;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4323
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4324 CHECK_FONT_GET_OBJECT (font_object, font);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4325 CHECK_STRING (string);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4326 len = SCHARS (string);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4327 code = alloca (sizeof (unsigned) * len);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4328 for (i = 0; i < len; i++)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4329 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4330 Lisp_Object ch = Faref (string, make_number (i));
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4331 Lisp_Object val;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4332 int c = XINT (ch);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4333
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4334 code[i] = font->driver->encode_char (font, c);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4335 if (code[i] == FONT_INVALID_CODE)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4336 break;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4337 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4338 face = FACE_FROM_ID (f, DEFAULT_FACE_ID);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4339 face->fontp = font;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4340 if (font->driver->prepare_face)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4341 font->driver->prepare_face (f, face);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4342 width = font->driver->text_extents (font, code, i, NULL);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4343 len = font->driver->draw_text (f, face, 0, font->ascent, code, i, width);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4344 if (font->driver->done_face)
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4345 font->driver->done_face (f, face);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4346 face->fontp = NULL;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4347 return make_number (len);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4348 }
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4349 #endif
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4350
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4351 #endif /* FONT_DEBUG */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4352
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4353
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4354 #define BUILD_STYLE_TABLE(TBL) \
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4355 build_style_table ((TBL), sizeof TBL / sizeof (struct table_entry))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4356
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4357 static Lisp_Object
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4358 build_style_table (entry, nelement)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4359 struct table_entry *entry;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4360 int nelement;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4361 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4362 int i, j;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4363 Lisp_Object table, elt;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4364
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4365 table = Fmake_vector (make_number (nelement), Qnil);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4366 for (i = 0; i < nelement; i++)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4367 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4368 for (j = 0; entry[i].names[j]; j++);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4369 elt = Fmake_vector (make_number (j + 1), Qnil);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4370 ASET (elt, 0, make_number (entry[i].numeric));
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4371 for (j = 0; entry[i].names[j]; j++)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4372 ASET (elt, j + 1, intern (entry[i].names[j]));
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4373 ASET (table, i, elt);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4374 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4375 return table;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4376 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4377
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4378 static Lisp_Object Vfont_log;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4379 static int font_log_env_checked;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4380
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4381 void
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4382 font_add_log (action, arg, result)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4383 char *action;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4384 Lisp_Object arg, result;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4385 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4386 Lisp_Object tail, val;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4387 int i;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4388
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4389 if (! font_log_env_checked)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4390 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4391 Vfont_log = egetenv ("EMACS_FONT_LOG") ? Qnil : Qt;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4392 font_log_env_checked = 1;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4393 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4394 if (EQ (Vfont_log, Qt))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4395 return;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4396 if (FONTP (arg))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4397 arg = Ffont_xlfd_name (arg, Qt);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4398 if (FONTP (result))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4399 result = Ffont_xlfd_name (result, Qt);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4400 else if (CONSP (result))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4401 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4402 result = Fcopy_sequence (result);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4403 for (tail = result; CONSP (tail); tail = XCDR (tail))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4404 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4405 val = XCAR (tail);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4406 if (FONTP (val))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4407 val = Ffont_xlfd_name (val, Qt);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4408 XSETCAR (tail, val);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4409 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4410 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4411 else if (VECTORP (result))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4412 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4413 result = Fcopy_sequence (result);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4414 for (i = 0; i < ASIZE (result); i++)
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4415 {
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4416 val = AREF (result, i);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4417 if (FONTP (val))
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4418 val = Ffont_xlfd_name (val, Qt);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4419 ASET (result, i, val);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4420 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4421 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4422 Vfont_log = Fcons (list3 (intern (action), arg, result), Vfont_log);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4423 }
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4424
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4425 extern void syms_of_ftfont P_ (());
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4426 extern void syms_of_xfont P_ (());
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4427 extern void syms_of_xftfont P_ (());
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4428 extern void syms_of_ftxfont P_ (());
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4429 extern void syms_of_bdffont P_ (());
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4430 extern void syms_of_w32font P_ (());
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4431 extern void syms_of_atmfont P_ (());
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4432
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4433 void
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4434 syms_of_font ()
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4435 {
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4436 sort_shift_bits[FONT_SLANT_INDEX] = 0;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4437 sort_shift_bits[FONT_WEIGHT_INDEX] = 7;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4438 sort_shift_bits[FONT_SIZE_INDEX] = 14;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4439 sort_shift_bits[FONT_WIDTH_INDEX] = 21;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4440 sort_shift_bits[FONT_ADSTYLE_INDEX] = 28;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4441 sort_shift_bits[FONT_FOUNDRY_INDEX] = 29;
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4442 sort_shift_bits[FONT_FAMILY_INDEX] = 30;
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4443 /* Note that sort_shift_bits[FONT_SORT_TYPE] and
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4444 sort_shift_bits[FONT_SORT_REGISTRY] are never used. */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4445
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4446 staticpro (&font_charset_alist);
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4447 font_charset_alist = Qnil;
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4448
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4449 DEFSYM (Qfont_spec, "font-spec");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4450 DEFSYM (Qfont_entity, "font-entity");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4451 DEFSYM (Qfont_object, "font-object");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4452
90677
424dec0c7b5d (Qopentype): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90640
diff changeset
4453 DEFSYM (Qopentype, "opentype");
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4454
90439
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
4455 DEFSYM (Qiso8859_1, "iso8859-1");
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
4456 DEFSYM (Qiso10646_1, "iso10646-1");
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
4457 DEFSYM (Qunicode_bmp, "unicode-bmp");
90622
bb9362e3a03b (Qunicode_sip): New variable.
Kenichi Handa <handa@m17n.org>
parents: 90590
diff changeset
4458 DEFSYM (Qunicode_sip, "unicode-sip");
90439
fb253905e9c3 * font.c (Qiso8859_1, Qiso10646_1, Qunicode_bmp): Moved from
Kenichi Handa <handa@m17n.org>
parents: 90427
diff changeset
4459
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4460 DEFSYM (QCotf, ":otf");
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4461 DEFSYM (QClang, ":lang");
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4462 DEFSYM (QCscript, ":script");
91125
6c9a19ff6c55 (Qfontp): Remove unused symbol.
Jason Rumney <jasonr@gnu.org>
parents: 91112
diff changeset
4463 DEFSYM (QCantialias, ":antialias");
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4464
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4465 DEFSYM (QCfoundry, ":foundry");
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4466 DEFSYM (QCadstyle, ":adstyle");
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4467 DEFSYM (QCregistry, ":registry");
90481
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
4468 DEFSYM (QCspacing, ":spacing");
93690200f520 (POINT_TO_PIXEL): Don't divice POINT by 10.
Kenichi Handa <handa@m17n.org>
parents: 90476
diff changeset
4469 DEFSYM (QCdpi, ":dpi");
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4470 DEFSYM (QCscalable, ":scalable");
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4471 DEFSYM (QCavgwidth, ":avgwidth");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4472 DEFSYM (QCfont_entity, ":font-entity");
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4473 DEFSYM (QCfc_unknown_spec, ":fc-unknown-spec");
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4474
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4475 DEFSYM (Qc, "c");
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4476 DEFSYM (Qm, "m");
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4477 DEFSYM (Qp, "p");
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4478 DEFSYM (Qd, "d");
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4479
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4480 staticpro (&null_vector);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4481 null_vector = Fmake_vector (make_number (0), Qnil);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4482
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4483 staticpro (&scratch_font_spec);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4484 scratch_font_spec = Ffont_spec (0, NULL);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4485 staticpro (&scratch_font_prefer);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4486 scratch_font_prefer = Ffont_spec (0, NULL);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4487
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4488 #ifdef HAVE_LIBOTF
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4489 staticpro (&otf_list);
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4490 otf_list = Qnil;
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4491 #endif
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4492
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4493 defsubr (&Sfontp);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4494 defsubr (&Sfont_spec);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4495 defsubr (&Sfont_get);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4496 defsubr (&Sfont_put);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4497 defsubr (&Slist_fonts);
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4498 defsubr (&Sfont_family_list);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4499 defsubr (&Sfind_font);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4500 defsubr (&Sfont_xlfd_name);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4501 defsubr (&Sclear_font_cache);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4502 defsubr (&Sfont_make_gstring);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4503 defsubr (&Sfont_fill_gstring);
91135
49dbc35e3f99 * font.c [HAVE_M17N_FLT]: Include <m17n-flt.h>.
Kenichi Handa <handa@m17n.org>
parents: 91125
diff changeset
4504 defsubr (&Sfont_shape_text);
90817
d2c230a67741 (struct otf_list): Delete it.
Kenichi Handa <handa@m17n.org>
parents: 90811
diff changeset
4505 defsubr (&Sfont_drive_otf);
90556
e56a86aa94cc (font_otf_capability): Fix handling of the default
Kenichi Handa <handa@m17n.org>
parents: 90549
diff changeset
4506 defsubr (&Sfont_otf_alternates);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4507
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4508 #ifdef FONT_DEBUG
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4509 defsubr (&Sopen_font);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4510 defsubr (&Sclose_font);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4511 defsubr (&Squery_font);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4512 defsubr (&Sget_font_glyphs);
90503
8e3ffc0a529f (QCscalable, Qc, Qm, Qp, Qd): New variables.
Kenichi Handa <handa@m17n.org>
parents: 90490
diff changeset
4513 defsubr (&Sfont_match_p);
90541
b7130e76c2f9 Include window.h.
Kenichi Handa <handa@m17n.org>
parents: 90530
diff changeset
4514 defsubr (&Sfont_at);
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4515 #if 0
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4516 defsubr (&Sdraw_string);
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4517 #endif
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4518 #endif /* FONT_DEBUG */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4519
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4520 DEFVAR_LISP ("font-encoding-alist", &Vfont_encoding_alist,
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4521 doc: /*
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4522 Alist of fontname patterns vs the corresponding encoding and repertory info.
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4523 Each element looks like (REGEXP . (ENCODING . REPERTORY)),
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4524 where ENCODING is a charset or a char-table,
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4525 and REPERTORY is a charset, a char-table, or nil.
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4526
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
4527 If ENCODING and REPERTORY are the same, the element can have the form
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4528 \(REGEXP . ENCODING).
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4529
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4530 ENCODING is for converting a character to a glyph code of the font.
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4531 If ENCODING is a charset, encoding a character by the charset gives
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4532 the corresponding glyph code. If ENCODING is a char-table, looking up
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4533 the table by a character gives the corresponding glyph code.
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4534
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4535 REPERTORY specifies a repertory of characters supported by the font.
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4536 If REPERTORY is a charset, all characters beloging to the charset are
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4537 supported. If REPERTORY is a char-table, all characters who have a
95142
f64ddc606a66 (syms-of-font) <font-encoding-alist>:
Juanma Barranquero <lekktu@gmail.com>
parents: 95126
diff changeset
4538 non-nil value in the table are supported. If REPERTORY is nil, Emacs
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4539 gets the repertory information by an opened font and ENCODING. */);
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4540 Vfont_encoding_alist = Qnil;
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4541
95176
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4542 DEFVAR_LISP_NOPRO ("font-weight-table", &Vfont_weight_table,
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4543 doc: /* Vector of valid font weight values.
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4544 Each element has the form:
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4545 [NUMERIC-VALUE SYMBOLIC-NAME ALIAS-NAME ...]
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4546 NUMERIC-VALUE is an integer, and SYMBOLIC-NAME and ALIAS-NAME are symobls. */);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4547 Vfont_weight_table = BUILD_STYLE_TABLE (weight_table);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4548
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4549 DEFVAR_LISP_NOPRO ("font-slant-table", &Vfont_slant_table,
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4550 doc: /* Vector of font slant symbols vs the corresponding numeric values.
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4551 See `font-weight_table' for the format of the vector. */);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4552 Vfont_slant_table = BUILD_STYLE_TABLE (slant_table);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4553
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4554 DEFVAR_LISP_NOPRO ("font-width-table", &Vfont_width_table,
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4555 doc: /* Alist of font width symbols vs the corresponding numeric values.
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4556 See `font-weight_table' for the format of the vector. */);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4557 Vfont_width_table = BUILD_STYLE_TABLE (width_table);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4558
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4559 staticpro (&font_style_table);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4560 font_style_table = Fmake_vector (make_number (3), Qnil);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4561 ASET (font_style_table, 0, Vfont_weight_table);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4562 ASET (font_style_table, 1, Vfont_slant_table);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4563 ASET (font_style_table, 2, Vfont_width_table);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4564
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4565 DEFVAR_LISP ("font-log", &Vfont_log, doc: /*
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4566 *Logging list of font related actions and results.
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4567 The value t means to suppress the logging.
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4568 The initial value is set to nil if the environment variable
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4569 EMACS_FONT_LOG is set. Otherwise, it is set to t. */);
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4570 Vfont_log = Qnil;
686d116f748d Checking of FONT_DEBUG is moved to font.h. All calls of
Kenichi Handa <handa@m17n.org>
parents: 95142
diff changeset
4571
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4572 #ifdef HAVE_WINDOW_SYSTEM
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4573 #ifdef HAVE_FREETYPE
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4574 syms_of_ftfont ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4575 #ifdef HAVE_X_WINDOWS
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4576 syms_of_xfont ();
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4577 syms_of_ftxfont ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4578 #ifdef HAVE_XFT
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4579 syms_of_xftfont ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4580 #endif /* HAVE_XFT */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4581 #endif /* HAVE_X_WINDOWS */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4582 #else /* not HAVE_FREETYPE */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4583 #ifdef HAVE_X_WINDOWS
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4584 syms_of_xfont ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4585 #endif /* HAVE_X_WINDOWS */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4586 #endif /* not HAVE_FREETYPE */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4587 #ifdef HAVE_BDFFONT
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4588 syms_of_bdffont ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4589 #endif /* HAVE_BDFFONT */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4590 #ifdef WINDOWSNT
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4591 syms_of_w32font ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4592 #endif /* WINDOWSNT */
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4593 #ifdef MAC_OS
94926
70a8f8c84456 Include <strings.h>.
Kenichi Handa <handa@m17n.org>
parents: 94745
diff changeset
4594 syms_of_atmfont ();
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4595 #endif /* MAC_OS */
95126
b7cee987e982 (Vfont_encoding_alist, find_font_encoding): Moved from
Kenichi Handa <handa@m17n.org>
parents: 95104
diff changeset
4596 #endif /* HAVE_WINDOW_SYSTEM */
90400
80fff33f74f5 New file.
Kenichi Handa <handa@m17n.org>
parents:
diff changeset
4597 }
90427
ddb25860d044 Add arch tagline
Miles Bader <miles@gnu.org>
parents: 90400
diff changeset
4598
ddb25860d044 Add arch tagline
Miles Bader <miles@gnu.org>
parents: 90400
diff changeset
4599 /* arch-tag: 74c9475d-5976-4c93-a327-942ae3072846
ddb25860d044 Add arch tagline
Miles Bader <miles@gnu.org>
parents: 90400
diff changeset
4600 (do not change this comment) */