Mercurial > hg > xemacs-beta
annotate src/font-mgr.c @ 4809:0d3ccd5a2509
Initialize the result variable passed to FcFontMatch. See xemacs-patches
message <870180fe1001071349i63d185bfu4906c5a4399407cd@mail.gmail.com>.
author | Jerry James <james@xemacs.org> |
---|---|
date | Thu, 07 Jan 2010 14:50:24 -0700 |
parents | ca99a807b025 |
children | b3ea9c582280 |
rev | line source |
---|---|
3354 | 1 /* Lisp font handling implementation for X with Xft. |
2 | |
3 Copyright (C) 2003 Eric Knauel and Matthias Neubauer | |
4 Copyright (C) 2005 Eric Knauel | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
5 Copyright (C) 2004-2009 Free Software Foundation, Inc. |
3354 | 6 |
7 Authors: Eric Knauel <knauel@informatik.uni-tuebingen.de> | |
8 Matthias Neubauer <neubauer@informatik.uni-freiburg.de> | |
9 Stephen J. Turnbull <stephen@xemacs.org> | |
10 Created: 27 Oct 2003 | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
11 Updated: 18 November 2009 by Stephen J. Turnbull |
3354 | 12 |
13 This file is part of XEmacs. | |
14 | |
15 XEmacs is free software; you can redistribute it and/or modify it | |
16 under the terms of the GNU General Public License as published by the | |
17 Free Software Foundation; either version 2, or (at your option) any | |
18 later version. | |
19 | |
20 XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
21 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
22 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
23 for more details. | |
24 | |
25 You should have received a copy of the GNU General Public License | |
26 along with XEmacs; see the file COPYING. If not, write to | |
27 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
28 Boston, MA 02111-1307, USA. */ | |
29 | |
30 /* Synched up with: Not in GNU Emacs. */ | |
31 | |
32 /* This module provides the Lisp interface to fonts in X11, including Xft, | |
33 but (at least at first) not GTK+ or Qt. | |
34 | |
35 Sealevel code should be in ../lwlib/lwlib-fonts.c or | |
36 ../lwlib/lwlib-colors.c. | |
37 */ | |
38 | |
39 #include <config.h> | |
40 #include "lisp.h" | |
41 #include "device.h" | |
42 #include "device-impl.h" | |
43 #include "console-x-impl.h" | |
44 #include "objects-x.h" | |
45 #include "objects-x-impl.h" | |
46 #include "hash.h" | |
47 #include "font-mgr.h" | |
48 | |
49 /* #### TO DO #### | |
50 . The "x-xft-*" and "x_xft_*" nomenclature is mostly redundant, especially | |
51 if we separate X fonts from Xft fonts, and use fontconfig more generally. | |
52 . We should support the most recent Xft first, old Xft libraries later. | |
53 . We may (think about it) wish to use fontconfig generally, even if we're | |
54 not using Xft. Either way, names that are really from fontconfig should | |
55 use the Fc* namespace. | |
56 . Mule-ize this file. | |
57 . Separate X Font Struct ops from Xft Font ops; give precedence to Xft but | |
58 allow fallback to X. | |
59 . Push decisions about font choice, defaults, fallbacks to Lisp; if we | |
60 really need efficiency, can reimplement in C later. | |
61 . Implement symbols interned in this file in the Q* namespace. | |
62 . Implement FcMatrix (Lisp vector). | |
63 . Implement FcCharSets (Lisp chartable? For implementation hints, see | |
64 FcCharSetFirstPage and FcCharSetNextPage). | |
65 . Implement FcConfigs. | |
66 DONE | |
67 . Fontconfig fontnames are encoded in UTF-8. | |
68 */ | |
69 | |
3360 | 70 Lisp_Object Qfont_mgr; |
3354 | 71 Lisp_Object Qfc_patternp; |
72 /* Lisp_Object Qfc_result_match; */ /* FcResultMatch */ | |
73 Lisp_Object Qfc_result_type_mismatch; /* FcResultTypeMismatch */ | |
74 Lisp_Object Qfc_result_no_match; /* FcResultNoMatch */ | |
75 Lisp_Object Qfc_result_no_id; /* FcResultNoId */ | |
76 Lisp_Object Qfc_internal_error; | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
77 Lisp_Object Qfc_match_pattern; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
78 Lisp_Object Qfc_match_font; |
3354 | 79 Lisp_Object Vxlfd_font_name_regexp; /* #### Really needed? */ |
3935 | 80 Fixnum xft_version; |
81 Fixnum fc_version; | |
3354 | 82 Fixnum debug_xft; /* Set to 1 enables lots of obnoxious messages. |
83 Setting it to 2 or 3 enables even more. */ | |
3931 | 84 #ifdef FONTCONFIG_EXPOSE_CONFIG |
85 Lisp_Object Qfc_configp; | |
86 static Lisp_Object Vfc_config_weak_list; | |
87 #endif | |
3354 | 88 |
89 /**************************************************************** | |
90 * FcPattern objects * | |
91 ****************************************************************/ | |
92 | |
93 static void | |
94 finalize_fc_pattern (void *header, int UNUSED (for_disksave)) | |
95 { | |
96 struct fc_pattern *p = (struct fc_pattern *) header; | |
97 if (p->fcpatPtr) | |
98 { | |
99 FcPatternDestroy (p->fcpatPtr); | |
100 p->fcpatPtr = 0; | |
101 } | |
102 } | |
103 | |
3906 | 104 static void |
105 print_fc_pattern (Lisp_Object obj, Lisp_Object printcharfun, | |
106 int UNUSED(escapeflag)) | |
107 { | |
108 struct fc_pattern *c = XFCPATTERN (obj); | |
109 if (print_readably) | |
110 printing_unreadable_object ("#<fc-pattern 0x%x>", c->header.uid); | |
111 write_fmt_string (printcharfun, "#<fc-pattern 0x%x>", c->header.uid); | |
112 } | |
113 | |
114 /* #### We really need an equal method and a hash method (required if you | |
115 have an equal method). For the equal method, we can probably use one | |
116 or both of | |
117 | |
118 -- Function: FcBool FcPatternEqual (const FcPattern *pa, const | |
119 FcPattern *pb); | |
120 Returns whether PA and PB are exactly alike. | |
121 | |
122 -- Function: FcBool FcPatternEqualSubset (const FcPattern *pa, const | |
123 FcPattern *pb, const FcObjectSet *os) | |
124 Returns whether PA and PB have exactly the same values for all of | |
125 the objects in OS. | |
126 | |
127 For the hash, we'll have to extract some subset of attributes. | |
128 | |
129 #### Crap. It's altogether unobvious what we need. x_color_instance | |
130 does have a hash method, but fonts are apparently special. I get the | |
131 feeling that for this to work properly we're going to need to switch | |
132 to fontconfig-based font specifications (although we can allow the | |
133 platform syntaxes, the underlying specification object will need to | |
134 conform to the fontconfig API, or more precisely the font-mgr API). | |
135 | |
136 I think the whole `font-truename' interface needs to be dropped. */ | |
137 | |
3354 | 138 static const struct memory_description fcpattern_description [] = { |
139 /* #### nothing here, is this right?? */ | |
140 { XD_END } | |
141 }; | |
142 | |
3906 | 143 DEFINE_LRECORD_IMPLEMENTATION("fc-pattern", fc_pattern, 0, |
144 0, print_fc_pattern, finalize_fc_pattern, | |
145 0, 0, fcpattern_description, | |
3354 | 146 struct fc_pattern); |
147 | |
148 /* | |
149 * Helper Functions | |
150 */ | |
151 static Lisp_Object make_xlfd_font_regexp (void); | |
152 static void string_list_to_fcobjectset (Lisp_Object list, FcObjectSet *os); | |
153 | |
154 /* | |
155 extract the C representation of the Lisp string STR and convert it | |
156 to the encoding used by the Fontconfig API for property and font | |
157 names. I suppose that Qnative is the right encoding, the manual | |
158 doesn't say much about this topic. This functions assumes that STR | |
159 is a Lisp string. | |
160 */ | |
161 #define extract_fcapi_string(str) \ | |
3469 | 162 (NEW_LISP_STRING_TO_EXTERNAL ((str), Qfc_font_name_encoding)) |
3354 | 163 |
3906 | 164 #define build_fcapi_string(str) \ |
165 (build_ext_string ((Extbyte *) (str), Qfc_font_name_encoding)) | |
166 | |
3360 | 167 /* #### This homebrew lashup should be replaced with FcConstants. |
168 | |
169 fontconfig assumes that objects (property names) are statically allocated, | |
3354 | 170 and you will get bizarre results if you pass Lisp string data or strings |
171 allocated on the stack as objects. fontconfig _does_ copy values, so we | |
172 (I hope) don't have to worry about that member. | |
173 | |
174 Probably these functions don't get called so often that the memory leak | |
175 due to strdup'ing every time we add a property would matter, but XEmacs | |
176 _is_ a long-running process. So we hash them. | |
177 | |
178 I suspect that using symbol names or even keywords does not provide | |
179 assurance that the string won't move in memory. So we hash them | |
3360 | 180 ourselves; hash.c hashtables do not interpret the value pointers. |
181 | |
182 This array should be FcChar8**, but GCC 4.x bitches about signedness. */ | |
183 static Extbyte *fc_standard_properties[] = { | |
184 /* treated specially, ordered first */ | |
185 "family", "size", | |
186 /* remaining are alphabetized by group */ | |
187 /* standard properties in fontconfig and Xft v.2 */ | |
188 "antialias", "aspect", "autohint", "charset", "dpi", "file", | |
3354 | 189 "foundry", "ftface", "globaladvance", "hinting", "index", "lang", |
190 "minspace", "outline", "pixelsize", "rasterizer", "rgba", "scalable", | |
3360 | 191 "scale", "slant", "spacing", "style", "verticallayout", "weight", |
192 /* common in modern fonts */ | |
193 "fontformat", "fontversion", | |
3354 | 194 /* obsolete after Xft v. 1 */ |
195 "charwidth", "charheight", "core", "encoding", "render" | |
196 }; | |
197 | |
198 static struct hash_table *fc_property_name_hash_table; | |
199 | |
200 /* #### Maybe fc_intern should be exposed to LISP? The idea is that | |
201 fc-pattern-add could warn or error if the property isn't interned. */ | |
202 | |
3469 | 203 static const Extbyte * |
3354 | 204 fc_intern (Lisp_Object property) |
205 { | |
206 const void *dummy; | |
3469 | 207 const Extbyte *prop = extract_fcapi_string (property); |
3354 | 208 const void *val = gethash (prop, fc_property_name_hash_table, &dummy); |
209 | |
210 /* extract_fcapi_string returns something alloca'd | |
211 so we can just drop the old value of prop on the floor */ | |
212 if (val) | |
3469 | 213 prop = (const Extbyte *) val; |
3354 | 214 else |
215 { | |
3469 | 216 prop = (const Extbyte *) FcStrCopy ((FcChar8 *) prop); |
3354 | 217 puthash (prop, NULL, fc_property_name_hash_table); |
218 } | |
219 return prop; | |
220 } | |
221 | |
222 DEFUN("fc-pattern-p", Ffc_pattern_p, 1, 1, 0, /* | |
223 Returns t if OBJECT is of type fc-pattern, nil otherwise. | |
224 */ | |
225 (object)) | |
226 { | |
227 return FCPATTERNP(object) ? Qt : Qnil; | |
228 } | |
229 | |
230 DEFUN("fc-pattern-create", Ffc_pattern_create, 0, 0, 0, /* | |
231 Return a new, empty fc-pattern object. | |
232 */ | |
233 ()) | |
234 { | |
235 fc_pattern *fcpat = | |
236 ALLOC_LCRECORD_TYPE (struct fc_pattern, &lrecord_fc_pattern); | |
237 | |
238 fcpat->fcpatPtr = FcPatternCreate(); | |
239 return wrap_fcpattern(fcpat); | |
240 } | |
241 | |
242 DEFUN("fc-name-parse", Ffc_name_parse, 1, 1, 0, /* | |
243 Parse an Fc font name and return its representation as a fc pattern object. | |
244 */ | |
245 (name)) | |
246 { | |
247 struct fc_pattern *fcpat = | |
248 ALLOC_LCRECORD_TYPE (struct fc_pattern, &lrecord_fc_pattern); | |
249 | |
3906 | 250 CHECK_STRING(name); |
3354 | 251 |
3469 | 252 fcpat->fcpatPtr = FcNameParse ((FcChar8 *) extract_fcapi_string (name)); |
3354 | 253 return wrap_fcpattern(fcpat); |
254 } | |
255 | |
256 /* #### Ga-a-ack! Xft's similar function is actually a different API. | |
257 We provide both. */ | |
258 DEFUN("fc-name-unparse", Ffc_name_unparse, 1, 1, 0, /* | |
259 Unparse an fc pattern object to a string. | |
260 */ | |
261 (pattern)) | |
262 { | |
4799
ca99a807b025
Free, rather than discard, the return value of FcNameUnparse. See message
Jerry James <james@xemacs.org>
parents:
4758
diff
changeset
|
263 FcChar8 *name; |
ca99a807b025
Free, rather than discard, the return value of FcNameUnparse. See message
Jerry James <james@xemacs.org>
parents:
4758
diff
changeset
|
264 Lisp_Object result; |
3354 | 265 CHECK_FCPATTERN(pattern); |
4799
ca99a807b025
Free, rather than discard, the return value of FcNameUnparse. See message
Jerry James <james@xemacs.org>
parents:
4758
diff
changeset
|
266 name = FcNameUnparse (XFCPATTERN_PTR (pattern)); |
ca99a807b025
Free, rather than discard, the return value of FcNameUnparse. See message
Jerry James <james@xemacs.org>
parents:
4758
diff
changeset
|
267 result = build_fcapi_string (name); |
ca99a807b025
Free, rather than discard, the return value of FcNameUnparse. See message
Jerry James <james@xemacs.org>
parents:
4758
diff
changeset
|
268 xfree (name, FcChar8 *); |
ca99a807b025
Free, rather than discard, the return value of FcNameUnparse. See message
Jerry James <james@xemacs.org>
parents:
4758
diff
changeset
|
269 return result; |
3354 | 270 } |
271 | |
272 DEFUN("fc-pattern-duplicate", Ffc_pattern_duplicate, 1, 1, 0, /* | |
273 Make a copy of the fc pattern object PATTERN and return it. | |
274 */ | |
275 (pattern)) | |
276 { | |
277 struct fc_pattern *copy = NULL; | |
278 CHECK_FCPATTERN(pattern); | |
279 | |
280 copy = ALLOC_LCRECORD_TYPE (struct fc_pattern, &lrecord_fc_pattern); | |
281 copy->fcpatPtr = FcPatternDuplicate(XFCPATTERN_PTR(pattern)); | |
282 return wrap_fcpattern(copy); | |
283 } | |
284 | |
285 DEFUN("fc-pattern-add", Ffc_pattern_add, 3, 3, 0, /* | |
286 Add attributes to the pattern object PATTERN. PROPERTY is a string naming | |
287 the attribute to add, VALUE the value for this attribute. | |
288 | |
289 VALUE may be a string, integer, float, or symbol, in which case the value | |
290 will be added as an FcChar8[], int, double, or FcBool respectively. | |
291 */ | |
292 (pattern, property, value)) | |
293 { | |
294 Bool res = 0; | |
3469 | 295 const Extbyte *obj; |
3354 | 296 FcPattern *fcpat; |
297 | |
298 CHECK_FCPATTERN(pattern); | |
299 CHECK_STRING(property); | |
300 | |
301 obj = fc_intern (property); | |
302 fcpat = XFCPATTERN_PTR (pattern); | |
303 | |
304 if (STRINGP(value)) | |
305 { | |
306 FcChar8 *str = (FcChar8 *) extract_fcapi_string (value); | |
307 res = FcPatternAddString (fcpat, obj, str); | |
308 } | |
309 else if (INTP(value)) | |
310 { | |
311 res = FcPatternAddInteger (fcpat, obj, XINT(value)); | |
312 } | |
313 else if (FLOATP(value)) | |
314 { | |
315 res = FcPatternAddDouble (fcpat, obj, (double) XFLOAT_DATA(value)); | |
316 } | |
317 else if (SYMBOLP(value)) | |
318 { | |
319 res = FcPatternAddBool (fcpat, obj, !NILP(value)); | |
320 } | |
321 /* else ... maybe we should wta here? */ | |
322 | |
323 return res ? Qt : Qnil; | |
324 } | |
325 | |
326 DEFUN("fc-pattern-del", Ffc_pattern_del, 2, 2, 0, /* | |
327 Remove attribute PROPERTY from fc pattern object OBJECT. | |
328 */ | |
329 (pattern, property)) | |
330 { | |
331 Bool res; | |
332 | |
333 CHECK_FCPATTERN(pattern); | |
334 CHECK_STRING(property); | |
335 | |
3469 | 336 res = FcPatternDel(XFCPATTERN_PTR(pattern), extract_fcapi_string (property)); |
3354 | 337 return res ? Qt : Qnil; |
338 } | |
339 | |
340 /* Generic interface to FcPatternGet() | |
341 * Don't support the losing symbol-for-property interface. | |
342 */ | |
343 DEFUN("fc-pattern-get", Ffc_pattern_get, 2, 4, 0, /* | |
344 From PATTERN, extract PROPERTY for the ID'th member, of type TYPE. | |
345 | |
346 PATTERN is an Xft (fontconfig) pattern object. | |
347 PROPERTY is a string naming an fontconfig font property. | |
348 Optional ID is a nonnegative integer indexing the list of values for PROPERTY | |
349 stored in PATTERN, defaulting to 0 (the first value). | |
350 Optional TYPE is a symbol, one of 'string, 'boolean, 'integer, 'float, | |
351 'double, 'matrix, 'charset, or 'void, corresponding to the FcValue types. | |
352 ('float is an alias for 'double). | |
353 | |
354 The Lisp types returned will conform to TYPE: | |
355 string string | |
356 boolean `t' or `nil' | |
357 integer integer | |
358 double (float) float | |
359 matrix not implemented | |
360 charset not implemented | |
361 void not implemented | |
362 | |
363 Symbols with names of the form "fc-result-DESCRIPTION" are returned when | |
364 the desired value is not available. These are | |
365 | |
366 fc-result-type-mismatch the value found has an unexpected type | |
367 fc-result-no-match there is no such attribute | |
368 fc-result-no-id there is no value for the requested ID | |
369 | |
370 The types of the following standard properties are predefined by fontconfig. | |
371 The symbol 'fc-result-type-mismatch will be returned if the object exists but | |
372 TYPE does not match the predefined type. It is best not to specify a type | |
373 for predefined properties, as a mistake here ensures error returns on the | |
374 correct type. | |
375 | |
376 Each standard property has a convenience accessor defined in fontconfig.el, | |
377 named in the form "fc-pattern-get-PROPERTY". The convenience functions are | |
378 preferred to `fc-pattern-get' since a typo in the string naming a property | |
379 will result in a silent null return, while a typo in a function name will | |
380 usually result in a compiler or runtime \"not fboundp\" error. You may use | |
381 `defsubst' to define convenience functions for non-standard properties. | |
382 | |
383 family String Font family name | |
384 style String Font style. Overrides weight and slant | |
385 slant Int Italic, oblique or roman | |
386 weight Int Light, medium, demibold, bold or black | |
387 size Double Point size | |
388 aspect Double Stretches glyphs horizontally before hinting | |
389 pixelsize Double Pixel size | |
390 spacing Int Proportional, monospace or charcell | |
391 foundry String Font foundry name | |
392 antialias Bool Whether glyphs can be antialiased | |
393 hinting Bool Whether the rasterizer should use hinting | |
394 verticallayout Bool Use vertical layout | |
395 autohint Bool Use autohinter instead of normal hinter | |
396 globaladvance Bool Use font global advance data | |
397 file String The filename holding the font | |
398 index Int The index of the font within the file | |
399 ftface FT_Face Use the specified FreeType face object | |
400 rasterizer String Which rasterizer is in use | |
401 outline Bool Whether the glyphs are outlines | |
402 scalable Bool Whether glyphs can be scaled | |
403 scale Double Scale factor for point->pixel conversions | |
404 dpi Double Target dots per inch | |
405 rgba Int unknown, rgb, bgr, vrgb, vbgr, none - subpixel geometry | |
406 minspace Bool Eliminate leading from line spacing | |
407 charset CharSet Unicode chars encoded by the font | |
408 lang String List of RFC-3066-style languages this font supports | |
409 | |
410 The FT_Face, Matrix, CharSet types are unimplemented, so the corresponding | |
411 properties are not accessible from Lisp at this time. If the value of a | |
412 property returned has type FT_Face, FcCharSet, or FcMatrix, | |
413 `fc-result-type-mismatch' is returned. | |
414 | |
415 The following properties which were standard in Xft v.1 are obsolete in | |
416 Xft v.2: encoding, charwidth, charheight, core, and render. */ | |
417 (pattern, property, id, type)) | |
418 { | |
3469 | 419 Extbyte *fc_property; |
3354 | 420 FcResult fc_result; |
421 FcValue fc_value; | |
422 | |
423 /* | |
424 process arguments | |
425 */ | |
426 CHECK_FCPATTERN (pattern); | |
427 | |
428 #if 0 | |
429 /* Don't support the losing symbol-for-property interface. */ | |
430 property = SYMBOLP (property) ? symbol_name (XSYMBOL (property)) : property; | |
431 #endif | |
432 if (STRINGP (property)) | |
433 { | |
3469 | 434 fc_property = extract_fcapi_string (property); |
3354 | 435 } |
436 else | |
437 { | |
438 /* if we allow symbols, this would need to be | |
439 list3 (Qlambda, list1 (Qobject), | |
440 list3 (Qor, list2 (Qstringp, Qobject), | |
441 list2 (Qsymbolp, Qobject))) | |
442 or something like that? */ | |
443 dead_wrong_type_argument (Qstringp, property); | |
444 } | |
445 | |
446 if (!NILP (id)) CHECK_NATNUM (id); | |
447 if (!NILP (type)) CHECK_SYMBOL (type); | |
448 | |
449 /* get property */ | |
450 fc_result = FcPatternGet (XFCPATTERN_PTR (pattern), | |
451 fc_property, | |
452 NILP (id) ? 0 : XINT(id), | |
453 &fc_value); | |
454 | |
455 switch (fc_result) | |
456 { | |
457 case FcResultMatch: | |
458 /* wrap it and return */ | |
459 switch (fc_value.type) | |
460 { | |
461 case FcTypeInteger: | |
462 return ((!NILP (type) && !EQ (type, Qinteger)) | |
463 ? Qfc_result_type_mismatch : make_int (fc_value.u.i)); | |
464 case FcTypeDouble: | |
465 return ((!NILP (type) && !EQ (type, intern ("double")) | |
466 && !EQ (type, Qfloat)) | |
467 ? Qfc_result_type_mismatch : make_float (fc_value.u.d)); | |
468 case FcTypeString: | |
469 return ((!NILP (type) && !EQ (type, Qstring)) | |
470 ? Qfc_result_type_mismatch | |
3906 | 471 : build_fcapi_string (fc_value.u.s)); |
3354 | 472 case FcTypeBool: |
473 return ((!NILP (type) && !EQ (type, Qboolean)) | |
474 ? Qfc_result_type_mismatch : fc_value.u.b ? Qt : Qnil); | |
475 case FcTypeMatrix: | |
476 return Qfc_result_type_mismatch; | |
477 /* #### unimplemented | |
478 return ((!NILP (type) && !EQ (type, intern ("matrix"))) | |
479 ? Qfc_result_type_mismatch : make_int (fc_value.u.m)); | |
480 */ | |
481 case FcTypeCharSet: | |
482 return Qfc_result_type_mismatch; | |
483 /* #### unimplemented | |
484 return ((!NILP (type) && !EQ (type, intern ("charset"))) | |
485 ? Qfc_result_type_mismatch : make_int (fc_value.u.c)); | |
486 */ | |
487 } | |
488 case FcResultTypeMismatch: | |
489 return Qfc_result_type_mismatch; | |
490 case FcResultNoMatch: | |
491 return Qfc_result_no_match; | |
492 case FcResultNoId: | |
493 return Qfc_result_no_id; | |
494 default: | |
495 return Qfc_internal_error; | |
496 } | |
497 } | |
498 | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
499 /* FcConfig handling functions. */ |
3354 | 500 |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
501 /* We obviously need to be careful about garbage collecting the current |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
502 FcConfig. I infer from the documentation of FcConfigDestroy that that |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
503 is the only reference maintained by fontconfig. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
504 So we keep track of our own references on a weak list, and only cons a |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
505 new object if we don't already have a reference to it there. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
506 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
507 enum DestroyFontsetP { DestroyNo = 0, DestroyYes = 1 }; |
3354 | 508 |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
509 static Lisp_Object |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
510 fc_config_create_using (FcConfig * (*create_function) ()) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
511 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
512 FcConfig *fc = (*create_function) (); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
513 Lisp_Object configs = XWEAK_LIST_LIST (Vfc_config_weak_list); |
3354 | 514 |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
515 /* Linear search: fc_configs are not going to multiply like conses. */ |
3360 | 516 { |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
517 LIST_LOOP_2 (cfg, configs) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
518 if (fc == XFCCONFIG_PTR (cfg)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
519 return cfg; |
3360 | 520 } |
521 | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
522 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
523 fc_config *fccfg = |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
524 ALLOC_LCRECORD_TYPE (struct fc_config, &lrecord_fc_config); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
525 fccfg->fccfgPtr = fc; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
526 configs = Fcons (wrap_fcconfig (fccfg), configs); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
527 XWEAK_LIST_LIST (Vfc_config_weak_list) = configs; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
528 return wrap_fcconfig (fccfg); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
529 } |
3354 | 530 } |
531 | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
532 static Lisp_Object |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
533 fc_strlist_to_lisp_using (FcStrList * (*getter) (FcConfig *), |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
534 Lisp_Object config) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
535 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
536 FcChar8 *thing; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
537 Lisp_Object value = Qnil; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
538 FcStrList *thing_list; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
539 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
540 CHECK_FCCONFIG (config); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
541 thing_list = (*getter) (XFCCONFIG_PTR(config)); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
542 /* Yes, we need to do this check -- sheesh, Keith! */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
543 if (!thing_list) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
544 return Qnil; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
545 while ((thing = FcStrListNext (thing_list))) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
546 value = Fcons (build_fcapi_string (thing), value); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
547 FcStrListDone (thing_list); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
548 return value; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
549 } |
3931 | 550 |
3354 | 551 static Lisp_Object |
3931 | 552 fontset_to_list (FcFontSet *fontset, enum DestroyFontsetP destroyp) |
3354 | 553 { |
554 int idx; | |
555 Lisp_Object fontlist = Qnil; | |
556 fc_pattern *fcpat; | |
557 | |
558 /* #### improve this error message */ | |
559 if (!fontset) | |
560 Fsignal (Qinvalid_state, | |
561 list1 (build_string ("failed to create FcFontSet"))); | |
562 for (idx = 0; idx < fontset->nfont; ++idx) | |
563 { | |
564 fcpat = | |
565 ALLOC_LCRECORD_TYPE (struct fc_pattern, &lrecord_fc_pattern); | |
566 fcpat->fcpatPtr = FcPatternDuplicate (fontset->fonts[idx]); | |
567 fontlist = Fcons (wrap_fcpattern(fcpat), fontlist); | |
568 } | |
3931 | 569 if (destroyp) |
570 FcFontSetDestroy (fontset); | |
3354 | 571 return fontlist; |
572 } | |
573 | |
3931 | 574 DEFUN("fc-config-p", Ffc_config_p, 1, 1, 0, /* |
575 Returns t if OBJECT is of type fc-config, nil otherwise. | |
576 */ | |
577 (object)) | |
578 { | |
579 return FCCONFIGP (object) ? Qt : Qnil; | |
580 } | |
581 | |
582 DEFUN("fc-config-create", Ffc_config_create, 0, 0, 0, /* | |
583 -- Function: FcConfig *FcConfigCreate (void) | |
584 Creates an empty configuration. */ | |
585 ()) | |
586 { | |
587 return fc_config_create_using (&FcConfigCreate); | |
588 } | |
589 | |
590 #if 0 | |
591 /* I'm sorry, but we just don't do this in Lisp, OK? | |
592 Don't even think about implementing this. */ | |
593 DEFUN("fc-config-destroy", Ffc_config_destroy, 1, 1, 0, /* | |
594 -- Function: void FcConfigDestroy (FcConfig *config) | |
595 Destroys a configuration and any data associated with it. Note | |
596 that calling this function with the return value from | |
597 FcConfigGetCurrent will place the library in an indeterminate | |
598 state. */ | |
599 (config)) | |
600 { | |
601 signal_error (Qunimplemented, "No user-servicable parts!", | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
602 intern ("fc-config-destroy")); |
3931 | 603 } |
604 #endif | |
605 | |
606 DEFUN("fc-config-up-to-date", Ffc_config_up_to_date, 1, 1, 0, /* | |
607 -- Function: FcBool FcConfigUptoDate (FcConfig *config) | |
608 Checks all of the files related to 'config' and returns whether the | |
609 in-memory version is in sync with the disk version. */ | |
610 (config)) | |
611 { | |
612 CHECK_FCCONFIG (config); | |
613 return FcConfigUptoDate (XFCCONFIG_PTR (config)) == FcFalse ? Qnil : Qt; | |
614 } | |
615 | |
616 DEFUN("fc-config-build-fonts", Ffc_config_build_fonts, 1, 1, 0, /* | |
617 -- Function: FcBool FcConfigBuildFonts (FcConfig *config) | |
618 Builds the set of available fonts for the given configuration. | |
619 Note that any changes to the configuration after this call have | |
620 indeterminate effects. Returns FcFalse if this operation runs out | |
621 of memory. | |
622 XEmacs: signal out-of-memory, or return nil on success. */ | |
623 (config)) | |
624 { | |
625 CHECK_FCCONFIG (config); | |
626 if (FcConfigBuildFonts (XFCCONFIG_PTR (config)) == FcFalse) | |
627 out_of_memory ("FcConfigBuildFonts failed", config); | |
628 return Qnil; | |
629 } | |
630 | |
631 DEFUN("fc-config-get-config-dirs", Ffc_config_get_config_dirs, 1, 1, 0, /* | |
632 -- Function: FcStrList *FcConfigGetConfigDirs (FcConfig *config) | |
633 Returns the list of font directories specified in the | |
634 configuration files for 'config'. Does not include any | |
635 subdirectories. */ | |
636 (config)) | |
637 { | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
638 return fc_strlist_to_lisp_using (&FcConfigGetConfigDirs, config); |
3931 | 639 } |
640 | |
641 DEFUN("fc-config-get-font-dirs", Ffc_config_get_font_dirs, 1, 1, 0, /* | |
642 -- Function: FcStrList *FcConfigGetFontDirs (FcConfig *config) | |
643 Returns the list of font directories in 'config'. This includes the | |
644 configured font directories along with any directories below those | |
645 in the filesystem. */ | |
646 (config)) | |
647 { | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
648 return fc_strlist_to_lisp_using (&FcConfigGetFontDirs, config); |
3931 | 649 } |
650 | |
651 DEFUN("fc-config-get-config-files", Ffc_config_get_config_files, 1, 1, 0, /* | |
652 -- Function: FcStrList *FcConfigGetConfigFiles (FcConfig *config) | |
653 Returns the list of known configuration files used to generate | |
654 'config'. Note that this will not include any configuration done | |
655 with FcConfigParse. */ | |
656 (config)) | |
657 { | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
658 return fc_strlist_to_lisp_using (&FcConfigGetConfigFiles, config); |
3931 | 659 } |
660 | |
661 DEFUN("fc-config-get-cache", Ffc_config_get_cache, 1, 1, 0, /* | |
662 -- Function: char *FcConfigGetCache (FcConfig *config) | |
663 Returns the name of the file used to store per-user font | |
664 information. */ | |
665 (config)) | |
666 { | |
667 CHECK_FCCONFIG (config); | |
668 /* Surely FcConfigGetCache just casts an FcChar8* to char*. */ | |
669 return build_fcapi_string ((FcChar8 *) FcConfigGetCache (XFCCONFIG_PTR (config))); | |
670 } | |
671 | |
672 DEFUN("fc-config-get-fonts", Ffc_config_get_fonts, 2, 2, 0, /* | |
673 -- Function: FcFontSet *FcConfigGetFonts (FcConfig *config, FcSetName set) | |
674 Returns one of the two sets of fonts from the configuration as | |
675 specified by 'set'. | |
676 `FcSetName' | |
677 Specifies one of the two sets of fonts available in a | |
678 configuration; FcSetSystem for those fonts specified in the | |
679 configuration and FcSetApplication which holds fonts provided by | |
680 the application. */ | |
681 (config, set)) | |
682 { | |
683 FcSetName name = FcSetSystem; | |
684 FcFontSet *fs = NULL; | |
685 | |
686 CHECK_FCCONFIG (config); | |
687 CHECK_SYMBOL (set); | |
688 | |
689 if (EQ (set, intern ("fc-set-system"))) | |
690 name = FcSetSystem; | |
691 else if (EQ (set, intern ("fc-set-application"))) | |
692 name = FcSetApplication; | |
693 else | |
694 wtaerror ("must be in (fc-set-system fc-set-application)", set); | |
695 | |
696 fs = FcConfigGetFonts (XFCCONFIG_PTR (config), name); | |
697 return fs ? fontset_to_list (fs, DestroyNo) : Qnil; | |
698 } | |
699 | |
700 DEFUN("fc-config-set-current", Ffc_config_set_current, 1, 1, 0, /* | |
701 -- Function: FcBool FcConfigSetCurrent (FcConfig *config) | |
702 Sets the current default configuration to 'config'. Implicitly | |
703 calls FcConfigBuildFonts if necessary, returning FcFalse if that | |
704 call fails. | |
705 XEmacs: signals out-of-memory if FcConfigBuildFonts fails, or args-out-of-range | |
706 if the resulting FcConfig has no fonts (which would crash XEmacs if installed). | |
707 */ | |
708 (config)) | |
709 { | |
710 CHECK_FCCONFIG (config); | |
711 /* *sigh* "Success" DOES NOT mean you have any fonts available. It is | |
712 easy to crash fontconfig, and XEmacs with it. Without the following | |
713 check, this will do it: | |
714 (progn | |
715 (fc-config-set-current (fc-config-create)) | |
716 (set-face-font 'default "serif-12")) | |
717 */ | |
718 | |
719 if (FcConfigBuildFonts (XFCCONFIG_PTR (config)) == FcFalse) | |
720 out_of_memory ("FcConfigBuildFonts failed", config); | |
721 /* #### We'd like to avoid this consing, and FcConfigGetFonts sometimes | |
722 returns NULL, but it doesn't always. This will do for now .... */ | |
723 if (NILP (Ffc_config_get_fonts (config, intern ("fc-set-system"))) | |
724 && NILP (Ffc_config_get_fonts (config, intern ("fc-set-application")))) | |
725 signal_error (intern ("args-out-of-range"), "no fonts found", config); | |
726 /* Should never happen, but I don't trust Keith anymore .... */ | |
727 if (FcConfigSetCurrent (XFCCONFIG_PTR (config)) == FcFalse) | |
728 out_of_memory ("FcConfigBuildFonts failed in set", config); | |
729 return Qnil; | |
730 } | |
731 | |
732 DEFUN("fc-config-get-blanks", Ffc_config_get_blanks, 1, 1, 0, /* | |
733 -- Function: FcBlanks *FcConfigGetBlanks (FcConfig *config) | |
734 Returns the FcBlanks object associated with the given | |
735 configuration, if no blanks were present in the configuration, | |
736 this function will return 0. | |
737 XEmacs: should convert to a chartable. | |
738 #### Unimplemented. */ | |
739 (config)) | |
740 { | |
741 CHECK_FCCONFIG (config); | |
742 signal_error (Qunimplemented, "no method to convert FcBlanks object", | |
743 intern ("fc-config-get-blanks")); | |
744 } | |
745 | |
746 DEFUN("fc-config-get-rescan-interval", Ffc_config_get_rescan_interval, 1, 1, 0, /* | |
4328
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3935
diff
changeset
|
747 -- Function: int FcConfigGetRescanInterval (FcConfig *config) |
3931 | 748 Returns the interval between automatic checks of the configuration |
749 (in seconds) specified in 'config'. The configuration is checked | |
750 during a call to FcFontList when this interval has passed since | |
751 the last check. */ | |
752 (config)) | |
753 { | |
754 CHECK_FCCONFIG (config); | |
4328
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3935
diff
changeset
|
755 return make_int (FcConfigGetRescanInterval (XFCCONFIG_PTR (config))); |
3931 | 756 } |
757 | |
758 DEFUN("fc-config-set-rescan-interval", Ffc_config_set_rescan_interval, 2, 2, 0, /* | |
4328
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3935
diff
changeset
|
759 -- Function: FcBool FcConfigSetRescanInterval (FcConfig *config, int |
3931 | 760 rescanInterval) |
761 Sets the rescan interval; returns FcFalse if an error occurred. | |
762 XEmacs: signal such error, or return nil on success. */ | |
763 (config, rescan_interval)) | |
764 { | |
765 CHECK_FCCONFIG (config); | |
766 CHECK_INT (rescan_interval); | |
4328
dfd878799ef0
Autoconfiscate the recent fontconfig spelling change.
Aidan Kehoe <kehoea@parhasard.net>
parents:
3935
diff
changeset
|
767 if (FcConfigSetRescanInterval (XFCCONFIG_PTR (config), |
3931 | 768 XINT (rescan_interval)) == FcFalse) |
769 signal_error (Qio_error, "FcConfigSetRescanInverval barfed", | |
770 intern ("fc-config-set-rescan-interval")); | |
771 return Qnil; | |
772 } | |
773 | |
774 /* #### This might usefully be made interactive. */ | |
775 DEFUN("fc-config-app-font-add-file", Ffc_config_app_font_add_file, 2, 2, 0, /* | |
776 -- Function: FcBool FcConfigAppFontAddFile (FcConfig *config, const | |
777 char *file) | |
778 Adds an application-specific font to the configuration. */ | |
779 (config, file)) | |
780 { | |
781 CHECK_FCCONFIG (config); | |
782 CHECK_STRING (file); | |
783 if (FcConfigAppFontAddFile | |
784 (XFCCONFIG_PTR (config), | |
785 /* #### FIXME! is this really Qnative? */ | |
786 (FcChar8 *) NEW_LISP_STRING_TO_EXTERNAL ((file), Qnative)) == FcFalse) | |
787 return Qnil; | |
788 else | |
789 return Qt; | |
790 } | |
791 | |
792 /* #### This might usefully be made interactive. */ | |
793 DEFUN("fc-config-app-font-add-dir", Ffc_config_app_font_add_dir, 2, 2, 0, /* | |
794 -- Function: FcBool FcConfigAppFontAddDir (FcConfig *config, const | |
795 char *dir) | |
796 Scans the specified directory for fonts, adding each one found to | |
797 the application-specific set of fonts. */ | |
798 (config, dir)) | |
799 { | |
800 CHECK_FCCONFIG (config); | |
801 CHECK_STRING (dir); | |
802 if (FcConfigAppFontAddDir | |
803 (XFCCONFIG_PTR (config), | |
804 /* #### FIXME! is this really Qnative? */ | |
805 (FcChar8 *) NEW_LISP_STRING_TO_EXTERNAL ((dir), Qnative)) == FcFalse) | |
806 return Qnil; | |
807 else | |
808 return Qt; | |
809 } | |
810 | |
811 /* #### This might usefully be made interactive. */ | |
812 DEFUN("fc-config-app-font-clear", Ffc_config_app_font_clear, 1, 1, 0, /* | |
813 -- Function: void FcConfigAppFontClear (FcConfig *config) | |
814 Clears the set of application-specific fonts. */ | |
815 (config)) | |
816 { | |
817 CHECK_FCCONFIG (config); | |
818 FcConfigAppFontClear (XFCCONFIG_PTR (config)); | |
819 return Qnil; | |
820 } | |
821 | |
822 /* These functions provide some control over how the default | |
823 configuration of the library is initialized. (This configuration is | |
824 normally implicitly initialized.) */ | |
825 | |
826 DEFUN("fc-config-filename", Ffc_config_filename, 1, 1, 0, /* | |
827 -- Function: char *FcConfigFilename (const char *name) | |
828 Given the specified external entity name, return the associated | |
829 filename. This provides applications a way to convert various | |
830 configuration file references into filename form. | |
831 | |
832 A null or empty 'name' indicates that the default configuration | |
833 file should be used; which file this references can be overridden | |
834 with the FC_CONFIG_FILE environment variable. Next, if the name | |
835 starts with '~', it refers to a file in the current users home | |
836 directory. Otherwise if the name doesn't start with '/', it | |
837 refers to a file in the default configuration directory; the | |
838 built-in default directory can be overridden with the | |
839 FC_CONFIG_DIR environment variable. */ | |
840 (name)) | |
841 { | |
842 char *fcname = ""; | |
843 | |
844 if (!NILP (name)) | |
845 { | |
846 CHECK_STRING (name); | |
847 /* #### FIXME! is this really Qnative? */ | |
848 fcname = NEW_LISP_STRING_TO_EXTERNAL (name, Qnative); | |
849 } | |
850 return (build_fcapi_string (FcConfigFilename ((FcChar8 *) fcname))); | |
851 } | |
852 | |
853 DEFUN("fc-init-load-config", Ffc_init_load_config, 0, 0, 0, /* | |
854 -- Function: FcConfig *FcInitLoadConfig (void) | |
855 Loads the default configuration file and returns the resulting | |
856 configuration. Does not load any font information. */ | |
857 ()) | |
858 { | |
859 return fc_config_create_using (&FcInitLoadConfig); | |
860 } | |
861 | |
862 DEFUN("fc-init-load-config-and-fonts", Ffc_init_load_config_and_fonts, 0, 0, 0, /* | |
863 -- Function: FcConfig *FcInitLoadConfigAndFonts (void) | |
864 Loads the default configuration file and builds information about | |
865 the available fonts. Returns the resulting configuration. */ | |
866 ()) | |
867 { | |
868 return fc_config_create_using (&FcInitLoadConfigAndFonts); | |
869 } | |
870 | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
871 DEFUN("fc-config-get-current", Ffc_config_get_current, 0, 0, 0, /* |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
872 -- Function: FcConfig *FcConfigGetCurrent (void) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
873 Returns the current default configuration. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
874 ()) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
875 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
876 return fc_config_create_using (&FcConfigGetCurrent); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
877 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
878 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
879 /* Pattern manipulation functions. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
880 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
881 DEFUN("fc-default-substitute", Ffc_default_substitute, 1, 1, 0, /* |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
882 Adds defaults for certain attributes if not specified in PATTERN. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
883 FcPattern PATTERN is modified in-place, and nil is returned. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
884 * Patterns without a specified style or weight are set to Medium |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
885 * Patterns without a specified style or slant are set to Roman |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
886 * Patterns without a specified pixel size are given one computed from any |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
887 specified point size (default 12), dpi (default 75) and scale (default 1). */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
888 (pattern)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
889 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
890 CHECK_FCPATTERN (pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
891 FcDefaultSubstitute (XFCPATTERN_PTR (pattern)); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
892 return Qnil; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
893 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
894 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
895 /* -- Function: FcBool FcConfigSubstituteWithPat (FcConfig *config, |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
896 FcPattern *p, FcPattern *p_pat FcMatchKind kind) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
897 OMITTED: use optional arguments in `fc-config-substitute'. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
898 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
899 DEFUN("fc-config-substitute", Ffc_config_substitute, 1, 4, 0, /* |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
900 Modifies PATTERN according to KIND and TESTPAT using operations from CONFIG. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
901 PATTERN is modified in-place. Returns an undocumented Boolean value. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
902 If optional KIND is `fc-match-pattern', then those tagged as pattern operations |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
903 are applied, else if KIND is `fc-match-font', those tagged as font operations |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
904 are applied and TESTPAT is used for <test> elements with target=pattern. KIND |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
905 defaults to `fc-match-font'. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
906 If optional TESTPAT is nil, it is ignored. Otherwise it must be an FcPattern. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
907 Optional CONFIG must be an FcConfig, defaulting to the current one. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
908 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
909 Note that this function actually corresponds to FcConfigSubstituteWithPat, and |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
910 the argument order is changed to take advantage of Lisp optional arguments. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
911 (pattern, kind, testpat, config)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
912 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
913 FcMatchKind knd; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
914 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
915 /* There ought to be a standard idiom for this.... */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
916 if (NILP (kind) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
917 || EQ (kind, Qfc_match_font)) { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
918 knd = FcMatchFont; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
919 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
920 else if (EQ (kind, Qfc_match_pattern)) { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
921 knd = FcMatchPattern; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
922 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
923 else { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
924 Fsignal (Qwrong_type_argument, |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
925 list2 (build_string ("need `fc-match-pattern' or `fc-match-font'"), |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
926 kind)); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
927 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
928 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
929 /* Typecheck arguments */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
930 CHECK_FCPATTERN (pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
931 if (!NILP (testpat)) CHECK_FCPATTERN (testpat); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
932 if (!NILP (config)) CHECK_FCCONFIG (config); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
933 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
934 return (FcConfigSubstituteWithPat |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
935 (NILP (config) ? FcConfigGetCurrent () : XFCCONFIG_PTR (config), |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
936 XFCPATTERN_PTR (pattern), |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
937 NILP (testpat) ? NULL : XFCPATTERN_PTR (testpat), |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
938 knd) == FcTrue) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
939 ? Qt : Qnil; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
940 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
941 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
942 /* Pattern matching functions. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
943 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
944 /* The following functions return fonts that match a certain pattern. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
945 `FcFontRenderPrepare' and `FcFontMatch' always return a single best |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
946 match. `FcFontList' returns the list of fonts that match a given |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
947 pattern on a certain set of properties. `FcFontSort' returns the |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
948 entire list of fonts, sorted in order of match quality, possibly |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
949 filtering out fonts that do not provide additional characters beyond |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
950 those provided by preferred fonts. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
951 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
952 DEFUN("fc-font-render-prepare", Ffc_font_render_prepare, 2, 3, 0, /* |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
953 Return a new pattern blending PATTERN and FONT. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
954 Optional CONFIG is an FcConfig, defaulting to the current one. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
955 The returned pattern consists of elements of FONT not appearing in PATTERN, |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
956 elements of PATTERN not appearing in FONT, and the best matching value from |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
957 PATTERN for elements appearing in both. The result is passed to |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
958 FcConfigSubstitute with 'kind' FcMatchFont and then returned. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
959 (pattern, font, config)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
960 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
961 if (NILP (config)) { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
962 config = Ffc_config_get_current (); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
963 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
964 CHECK_FCPATTERN (pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
965 CHECK_FCPATTERN (font); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
966 CHECK_FCCONFIG (config); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
967 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
968 /* I don't think this can fail? */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
969 return wrap_fcpattern (FcFontRenderPrepare (XFCCONFIG_PTR(config), |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
970 XFCPATTERN_PTR(font), |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
971 XFCPATTERN_PTR(pattern))); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
972 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
973 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
974 DEFUN("fc-font-match", Ffc_font_match, 2, 3, 0, /* |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
975 Return the font on DEVICE that most closely matches PATTERN. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
976 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
977 DEVICE is an X11 device. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
978 PATTERN is a fontconfig pattern object. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
979 Optional CONFIG is an FcConfig, defaulting to the current one. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
980 Returns a fontconfig pattern object representing the closest match to the |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
981 given pattern, or an error code. Possible error codes are |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
982 `fc-result-no-match' and `fc-result-no-id'. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
983 PATTERN is massaged with FcConfigSubstitute and FcDefaultSubstitute before |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
984 being processed by FcFontMatch. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
985 (device, pattern, config)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
986 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
987 FcResult res; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
988 struct fc_pattern *res_fcpat; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
989 FcPattern *p; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
990 FcConfig *fcc; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
991 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
992 CHECK_FCPATTERN(pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
993 if (NILP(device)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
994 return Qnil; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
995 CHECK_X_DEVICE(device); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
996 if (!DEVICE_LIVE_P(XDEVICE(device))) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
997 return Qnil; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
998 if (!NILP (config)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
999 CHECK_FCCONFIG (config); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1000 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1001 res_fcpat = ALLOC_LCRECORD_TYPE (struct fc_pattern, &lrecord_fc_pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1002 p = XFCPATTERN_PTR(pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1003 fcc = NILP (config) ? FcConfigGetCurrent () : XFCCONFIG_PTR (config); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1004 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1005 FcConfigSubstitute (fcc, p, FcMatchPattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1006 FcDefaultSubstitute (p); |
4809
0d3ccd5a2509
Initialize the result variable passed to FcFontMatch. See xemacs-patches
Jerry James <james@xemacs.org>
parents:
4799
diff
changeset
|
1007 res = FcResultMatch; |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1008 res_fcpat->fcpatPtr = FcFontMatch (fcc, p, &res); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1009 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1010 if (res_fcpat->fcpatPtr == NULL) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1011 switch (res) { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1012 case FcResultNoMatch: |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1013 return Qfc_result_no_match; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1014 case FcResultNoId: |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1015 return Qfc_result_no_id; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1016 default: |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1017 return Qfc_internal_error; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1018 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1019 else |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1020 return wrap_fcpattern(res_fcpat); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1021 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1022 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1023 /* #### fix this name to correspond to Ben's new nomenclature */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1024 DEFUN("fc-list-fonts-pattern-objects", Ffc_list_fonts_pattern_objects, |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1025 3, 3, 0, /* |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1026 Return a list of fonts on DEVICE that match PATTERN for PROPERTIES. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1027 Each font is represented by a fontconfig pattern object. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1028 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1029 DEVICE is an X11 device. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1030 PATTERN is a fontconfig pattern to be matched. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1031 PROPERTIES is a list of property names (strings) that should match. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1032 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1033 #### DEVICE is unused, ignored, and may be removed if it's not needed to |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1034 match other font-listing APIs. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1035 (UNUSED (device), pattern, properties)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1036 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1037 FcObjectSet *os; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1038 FcFontSet *fontset; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1039 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1040 CHECK_FCPATTERN (pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1041 CHECK_LIST (properties); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1042 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1043 os = FcObjectSetCreate (); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1044 string_list_to_fcobjectset (properties, os); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1045 /* #### why don't we need to do the "usual substitutions"? */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1046 fontset = FcFontList (NULL, XFCPATTERN_PTR (pattern), os); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1047 FcObjectSetDestroy (os); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1048 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1049 return fontset_to_list (fontset, DestroyYes); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1050 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1051 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1052 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1053 /* #### maybe this can/should be folded into fc-list-fonts-pattern-objects? */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1054 DEFUN("fc-font-sort", Ffc_font_sort, 2, 4, 0, /* |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1055 Return a list of all fonts sorted by proximity to PATTERN. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1056 Each font is represented by a fontconfig pattern object. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1057 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1058 DEVICE is an X11 device. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1059 PATTERN is a fontconfig pattern to be matched. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1060 Optional argument TRIM, if non-nil, means to trim trailing fonts that do not |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1061 contribute new characters to the union repertoire. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1062 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1063 #### Optional argument NOSUB, if non-nil, suppresses some of the usual |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1064 property substitutions. DON'T USE THIS in production code, it is intended |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1065 for exploring behavior of fontconfig and will be removed when this code is |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1066 stable. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1067 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1068 #### DEVICE is unused, ignored, and may be removed if it's not needed to |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1069 match other font-listing APIs. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1070 (UNUSED (device), pattern, trim, nosub)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1071 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1072 CHECK_FCPATTERN (pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1073 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1074 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1075 FcConfig *fcc = FcConfigGetCurrent(); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1076 FcFontSet *fontset; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1077 FcPattern *p = XFCPATTERN_PTR (pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1078 FcResult fcresult; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1079 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1080 if (NILP(nosub)) /* #### temporary debug hack */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1081 FcDefaultSubstitute (p); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1082 FcConfigSubstitute (fcc, p, FcMatchPattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1083 fontset = FcFontSort (fcc, p, !NILP(trim), NULL, &fcresult); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1084 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1085 return fontset_to_list (fontset, DestroyYes); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1086 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1087 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1088 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1089 #ifdef FONTCONFIG_EXPOSE_CONFIG |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1090 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1091 /* Configuration routines --- for debugging |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1092 Don't depend on these routines being available in the future! |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1093 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1094 3.2.10 Initialization |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1095 --------------------- |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1096 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1097 An FcConfig object holds the internal representation of a configuration. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1098 There is a default configuration which applications may use by passing |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1099 0 to any function using the data within an FcConfig. |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1100 */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1101 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1102 static void |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1103 finalize_fc_config (void *header, int UNUSED (for_disksave)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1104 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1105 struct fc_config *p = (struct fc_config *) header; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1106 if (p->fccfgPtr && p->fccfgPtr != FcConfigGetCurrent()) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1107 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1108 /* If we get here, all of *our* references are garbage (see comment on |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1109 fc_config_create_using() for why), and the only reference that |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1110 fontconfig keeps is the current FcConfig. */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1111 FcConfigDestroy (p->fccfgPtr); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1112 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1113 p->fccfgPtr = 0; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1114 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1115 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1116 static void |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1117 print_fc_config (Lisp_Object obj, Lisp_Object printcharfun, |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1118 int UNUSED(escapeflag)) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1119 { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1120 struct fc_config *c = XFCCONFIG (obj); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1121 if (print_readably) |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1122 printing_unreadable_object ("#<fc-config 0x%x>", c->header.uid); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1123 write_fmt_string (printcharfun, "#<fc-config 0x%x>", c->header.uid); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1124 } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1125 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1126 static const struct memory_description fcconfig_description [] = { |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1127 /* #### nothing here, is this right?? */ |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1128 { XD_END } |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1129 }; |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1130 |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1131 DEFINE_LRECORD_IMPLEMENTATION("fc-config", fc_config, 0, |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1132 0, print_fc_config, finalize_fc_config, 0, 0, |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1133 fcconfig_description, |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1134 struct fc_config); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1135 |
3931 | 1136 DEFUN("fc-init", Ffc_init, 0, 0, 0, /* |
1137 -- Function: FcBool FcInit (void) | |
1138 Loads the default configuration file and the fonts referenced | |
1139 therein and sets the default configuration to that result. | |
1140 Returns whether this process succeeded or not. If the default | |
1141 configuration has already been loaded, this routine does nothing | |
1142 and returns FcTrue. */ | |
1143 ()) | |
1144 { | |
1145 return (FcInit () == FcTrue) ? Qt : Qnil; | |
1146 } | |
1147 | |
1148 DEFUN("fc-get-version", Ffc_get_version, 0, 0, 0, /* | |
1149 -- Function: int FcGetVersion (void) | |
1150 Returns the version number of the library. | |
3935 | 1151 XEmacs: No, this should NOT return a pretty string. |
3931 | 1152 (let ((i (fc-get-version))) |
1153 (format "%d.%d.%d" (/ i 10000) (mod (/ i 100) 100) (mod i 100))) | |
3935 | 1154 gives the usual x.y.z format. This is the version of the .so. It can be |
1155 checked against `fc-version', which is the version of fontconfig.h. | |
1156 It's probably not a disaster if `(> (fc-get-version) fc-version)'. */ | |
3931 | 1157 ()) |
1158 { | |
1159 return make_int (FcGetVersion ()); | |
1160 } | |
1161 | |
1162 DEFUN("fc-init-reinitialize", Ffc_init_reinitialize, 0, 0, 0, /* | |
1163 -- Function: FcBool FcInitReinitialize (void) | |
1164 Forces the default configuration file to be reloaded and resets | |
1165 the default configuration. */ | |
1166 ()) | |
1167 { | |
1168 return (FcInitReinitialize () == FcTrue) ? Qt : Qnil; | |
1169 } | |
1170 | |
1171 DEFUN("fc-init-bring-up-to-date", Ffc_init_bring_up_to_date, 0, 0, 0, /* | |
1172 -- Function: FcBool FcInitBringUptoDate (void) | |
1173 Checks the rescan interval in the default configuration, checking | |
1174 the configuration if the interval has passed and reloading the | |
1175 configuration when any changes are detected. */ | |
1176 ()) | |
1177 { | |
1178 return (FcInitBringUptoDate () == FcTrue) ? Qt : Qnil; | |
1179 } | |
1180 | |
1181 #endif /* FONTCONFIG_EXPOSE_CONFIG */ | |
1182 | |
3354 | 1183 DEFUN("xlfd-font-name-p", Fxlfd_font_name_p, 1, 1, 0, /* |
1184 Check whether the string FONTNAME is a XLFD font name. */ | |
1185 (fontname)) | |
1186 { | |
1187 CHECK_STRING(fontname); | |
1188 /* #### should bind `case-fold-search' here? */ | |
1189 return Fstring_match(Vxlfd_font_name_regexp, fontname, Qnil, Qnil); | |
1190 } | |
1191 | |
1192 /* FcPatternPrint: there is no point in having wrappers fc-pattern-print, | |
1193 Ffc_pattern_print since this function prints to stdout. */ | |
1194 | |
1195 /* Initialization of font-mgr */ | |
1196 | |
1197 #define XE_XLFD_SEPARATOR "-" | |
1198 /* XLFD specifies ISO 8859-1 encoding, but we can't handle non-ASCII | |
1199 in Mule when this function is called. So use HPC. */ | |
1200 #if 0 | |
1201 #define XE_XLFD_PREFIX "\\(\\+[\040-\176\240-\377]*\\)?-" | |
1202 #define XE_XLFD_OPT_TEXT "\\([\040-\044\046-\176\240-\377]*\\)" | |
1203 #define XE_XLFD_TEXT "\\([\040-\044\046-\176\240-\377]+\\)" | |
1204 #else | |
1205 #define XE_XLFD_PREFIX "\\(\\+[\040-\176]*\\)?-" | |
1206 #define XE_XLFD_OPT_TEXT "\\([^-]*\\)" | |
1207 #define XE_XLFD_TEXT "\\([^-]+\\)" | |
1208 #endif | |
1209 | |
1210 #define XE_XLFD_SLANT "\\([0-9ior?*][iot]?\\)" | |
1211 #define XE_XLFD_SPACING "\\([cmp?*]\\)" | |
1212 /* Hyphen as minus conflicts with use as separator. */ | |
1213 #define XE_XLFD_OPT_NEGATE "~?" | |
1214 #define XE_XLFD_NUMBER "\\([0-9?*]+\\)" | |
1215 #define XE_XLFD_PSIZE "\\([0-9?*]+\\|\\[[ 0-9+~.e?*]+\\]\\)" | |
1216 | |
1217 /* Call this only from the init code | |
1218 #### This is really horrible, let's get rid of it, please. */ | |
1219 static Lisp_Object | |
1220 make_xlfd_font_regexp (void) | |
1221 { | |
1222 struct gcpro gcpro1; | |
1223 unsigned i; | |
1224 Lisp_Object reg = Qnil; | |
1225 const Extbyte *re[] = /* #### This could just be catenated by | |
1226 cpp and passed to build_ext_string. */ | |
1227 { | |
1228 /* Regular expression matching XLFDs as defined by XLFD v. 1.5. | |
1229 Matches must be case-insensitive. | |
1230 PSIZE is a pixel or point size, which may be a "matrix". The | |
1231 syntax of a matrix is not checked, just some lexical properties. | |
1232 AFAICT none of the TEXT fields except adstyle is optional. | |
1233 | |
1234 NB. It should not be a problem if this matches "too much", since | |
1235 an "old" server will simply not be able to find a matching font. */ | |
1236 "\\`", | |
1237 XE_XLFD_PREFIX, /* prefix */ | |
1238 XE_XLFD_TEXT, /* foundry */ | |
1239 XE_XLFD_SEPARATOR, | |
1240 XE_XLFD_TEXT, /* family */ | |
1241 XE_XLFD_SEPARATOR, | |
1242 XE_XLFD_TEXT, /* weight */ | |
1243 XE_XLFD_SEPARATOR, | |
1244 XE_XLFD_SLANT, /* slant */ | |
1245 XE_XLFD_SEPARATOR, | |
1246 XE_XLFD_TEXT, /* swidth */ | |
1247 XE_XLFD_SEPARATOR, | |
1248 XE_XLFD_OPT_TEXT, /* adstyle */ | |
1249 XE_XLFD_SEPARATOR, | |
1250 XE_XLFD_PSIZE, /* pixelsize */ | |
1251 XE_XLFD_SEPARATOR, | |
1252 XE_XLFD_PSIZE, /* pointsize */ | |
1253 XE_XLFD_SEPARATOR, | |
1254 XE_XLFD_NUMBER, /* resx */ | |
1255 XE_XLFD_SEPARATOR, | |
1256 XE_XLFD_NUMBER, /* resy */ | |
1257 XE_XLFD_SEPARATOR, | |
1258 XE_XLFD_SPACING, /* spacing */ | |
1259 XE_XLFD_SEPARATOR, | |
1260 XE_XLFD_OPT_NEGATE, /* avgwidth */ | |
1261 XE_XLFD_NUMBER, | |
1262 XE_XLFD_SEPARATOR, | |
1263 XE_XLFD_TEXT, /* registry */ | |
1264 XE_XLFD_SEPARATOR, | |
1265 XE_XLFD_TEXT, /* encoding */ | |
1266 "\\'" | |
1267 }; | |
1268 | |
1269 GCPRO1 (reg); | |
1270 for (i = 0; i < sizeof(re)/sizeof(Extbyte *); i++) | |
1271 { | |
1272 /* #### Currently this is Host Portable Coding, not ISO 8859-1. */ | |
1273 reg = concat2(reg, build_ext_string (re[i], Qx_font_name_encoding)); | |
1274 } | |
1275 | |
1276 RETURN_UNGCPRO (reg); | |
1277 } | |
1278 #undef XE_XLFD_SEPARATOR | |
1279 #undef XE_XLFD_PREFIX | |
1280 #undef XE_XLFD_OPT_TEXT | |
1281 #undef XE_XLFD_TEXT | |
1282 #undef XE_XLFD_OPT_SLANT | |
1283 #undef XE_XLFD_OPT_SPACING | |
1284 #undef XE_XLFD_OPT_NEGATE | |
1285 #undef XE_XLFD_NUMBER | |
1286 #undef XE_XLFD_PSIZE | |
1287 | |
1288 #define MINL(x,y) ((((unsigned long) (x)) < ((unsigned long) (y))) \ | |
1289 ? ((unsigned long) (x)) : ((unsigned long) (y))) | |
1290 | |
1291 static void | |
1292 string_list_to_fcobjectset (Lisp_Object list, FcObjectSet *os) | |
1293 { | |
1294 EXTERNAL_LIST_LOOP_2 (elt, list) | |
1295 { | |
3469 | 1296 const Extbyte *s; |
3354 | 1297 |
1298 CHECK_STRING (elt); | |
1299 s = fc_intern (elt); | |
1300 FcObjectSetAdd (os, s); | |
1301 } | |
1302 } | |
1303 | |
1304 void | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1305 syms_of_font_mgr (void) { |
3354 | 1306 INIT_LRECORD_IMPLEMENTATION(fc_pattern); |
1307 | |
1308 DEFSYMBOL_MULTIWORD_PREDICATE(Qfc_patternp); | |
1309 | |
1310 DEFSYMBOL(Qfc_result_type_mismatch); | |
1311 DEFSYMBOL(Qfc_result_no_match); | |
1312 DEFSYMBOL(Qfc_result_no_id); | |
1313 DEFSYMBOL(Qfc_internal_error); | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1314 DEFSYMBOL(Qfc_match_pattern); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1315 DEFSYMBOL(Qfc_match_font); |
3360 | 1316 DEFSYMBOL(Qfont_mgr); |
3354 | 1317 |
1318 DEFSUBR(Ffc_pattern_p); | |
1319 DEFSUBR(Ffc_pattern_create); | |
1320 DEFSUBR(Ffc_name_parse); | |
1321 DEFSUBR(Ffc_name_unparse); | |
1322 DEFSUBR(Ffc_pattern_duplicate); | |
1323 DEFSUBR(Ffc_pattern_add); | |
1324 DEFSUBR(Ffc_pattern_del); | |
1325 DEFSUBR(Ffc_pattern_get); | |
1326 DEFSUBR(Ffc_list_fonts_pattern_objects); | |
1327 DEFSUBR(Ffc_font_sort); | |
1328 DEFSUBR(Ffc_font_match); | |
4758
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1329 DEFSUBR(Ffc_default_substitute); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1330 DEFSUBR(Ffc_config_substitute); |
75975fd0b7fc
Implement more of the fontconfig API.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4757
diff
changeset
|
1331 DEFSUBR(Ffc_font_render_prepare); |
3354 | 1332 DEFSUBR(Fxlfd_font_name_p); |
3931 | 1333 |
1334 #ifdef FONTCONFIG_EXPOSE_CONFIG | |
1335 INIT_LRECORD_IMPLEMENTATION(fc_config); | |
1336 | |
1337 DEFSYMBOL_MULTIWORD_PREDICATE(Qfc_configp); | |
1338 | |
1339 DEFSUBR(Ffc_config_p); | |
1340 DEFSUBR(Ffc_config_create); | |
1341 #if 0 | |
1342 DEFSUBR(Ffc_config_destroy); | |
1343 #endif | |
1344 DEFSUBR(Ffc_config_set_current); | |
1345 DEFSUBR(Ffc_config_get_current); | |
1346 DEFSUBR(Ffc_config_up_to_date); | |
1347 DEFSUBR(Ffc_config_build_fonts); | |
1348 DEFSUBR(Ffc_config_get_config_dirs); | |
1349 DEFSUBR(Ffc_config_get_font_dirs); | |
1350 DEFSUBR(Ffc_config_get_config_files); | |
1351 DEFSUBR(Ffc_config_get_cache); | |
1352 DEFSUBR(Ffc_config_get_fonts); | |
1353 DEFSUBR(Ffc_config_get_blanks); | |
1354 DEFSUBR(Ffc_config_get_rescan_interval); | |
1355 DEFSUBR(Ffc_config_set_rescan_interval); | |
1356 DEFSUBR(Ffc_config_app_font_add_file); | |
1357 DEFSUBR(Ffc_config_app_font_add_dir); | |
1358 DEFSUBR(Ffc_config_app_font_clear); | |
1359 DEFSUBR(Ffc_config_filename); | |
1360 DEFSUBR(Ffc_init_load_config); | |
1361 DEFSUBR(Ffc_init_load_config_and_fonts); | |
1362 DEFSUBR(Ffc_init); | |
1363 DEFSUBR(Ffc_get_version); | |
1364 DEFSUBR(Ffc_init_reinitialize); | |
1365 DEFSUBR(Ffc_init_bring_up_to_date); | |
1366 #endif /* FONTCONFIG_EXPOSE_CONFIG */ | |
3354 | 1367 } |
1368 | |
1369 void | |
1370 vars_of_font_mgr (void) | |
1371 { | |
3935 | 1372 /* #### The next two DEFVARs belong somewhere else. */ |
3354 | 1373 |
1374 /* #### I know, but the right fix is use the generic debug facility. */ | |
1375 DEFVAR_INT ("xft-debug-level", &debug_xft /* | |
1376 Level of debugging messages to issue to stderr for Xft. | |
1377 A nonnegative integer. Set to 0 to suppress all warnings. | |
1378 Default is 1 to ensure a minimum of debugging output at initialization. | |
1379 Higher levels give even more information. | |
1380 */ ); | |
4757
a23ac8f90a49
Improve warning and error messages from Xft.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
4328
diff
changeset
|
1381 debug_xft = 0; |
3354 | 1382 |
3935 | 1383 DEFVAR_CONST_INT("xft-version", &xft_version /* |
3354 | 1384 The major version number of the Xft library being used. |
1385 */ ); | |
3935 | 1386 xft_version = XFT_VERSION; |
1387 | |
1388 DEFVAR_CONST_INT("fc-version", &fc_version /* | |
1389 The version number of fontconfig.h. It can be checked against | |
1390 `(fc-get-version)', which is the version of the .so. | |
1391 It's probably not a disaster if `(> (fc-get-version) fc-version)'. | |
1392 */ ); | |
1393 fc_version = FC_VERSION; | |
3354 | 1394 |
3360 | 1395 Fprovide (intern ("font-mgr")); |
3354 | 1396 } |
1397 | |
1398 void | |
1399 complex_vars_of_font_mgr (void) | |
1400 { | |
3931 | 1401 #ifdef FONTCONFIG_EXPOSE_CONFIG |
1402 Vfc_config_weak_list = make_weak_list (WEAK_LIST_SIMPLE); | |
1403 staticpro (&Vfc_config_weak_list); | |
1404 #endif | |
1405 | |
3354 | 1406 DEFVAR_LISP("xft-xlfd-font-regexp", &Vxlfd_font_name_regexp /* |
1407 The regular expression used to match XLFD font names. */ | |
1408 ); | |
1409 Vxlfd_font_name_regexp = make_xlfd_font_regexp(); | |
1410 } | |
1411 | |
1412 void | |
1413 reinit_vars_of_font_mgr (void) | |
1414 { | |
1415 int i, size = (int) countof (fc_standard_properties); | |
1416 | |
1417 FcInit (); | |
1418 | |
1419 fc_property_name_hash_table = make_string_hash_table (size); | |
1420 for (i = 0; i < size; ++i) | |
1421 puthash (fc_standard_properties[i], NULL, fc_property_name_hash_table); | |
1422 } | |
1423 |