Fix part 4 of bug#9771 with assertion violation when wrap-prefix is used
[emacs.git] / src / w32font.c
blob985370c15c14aef91daea77f3982c92855231e07
1 /* Font backend for the Microsoft W32 API.
2 Copyright (C) 2007-2011 Free Software Foundation, Inc.
4 This file is part of GNU Emacs.
6 GNU Emacs is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
11 GNU Emacs is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
19 #include <config.h>
20 #include <windows.h>
21 #include <math.h>
22 #include <ctype.h>
23 #include <commdlg.h>
24 #include <setjmp.h>
26 #include "lisp.h"
27 #include "w32term.h"
28 #include "frame.h"
29 #include "dispextern.h"
30 #include "character.h"
31 #include "charset.h"
32 #include "coding.h"
33 #include "fontset.h"
34 #include "font.h"
35 #include "w32font.h"
37 /* Cleartype available on Windows XP, cleartype_natural from XP SP1.
38 The latter does not try to fit cleartype smoothed fonts into the
39 same bounding box as the non-antialiased version of the font.
41 #ifndef CLEARTYPE_QUALITY
42 #define CLEARTYPE_QUALITY 5
43 #endif
44 #ifndef CLEARTYPE_NATURAL_QUALITY
45 #define CLEARTYPE_NATURAL_QUALITY 6
46 #endif
48 /* VIETNAMESE_CHARSET and JOHAB_CHARSET are not defined in some versions
49 of MSVC headers. */
50 #ifndef VIETNAMESE_CHARSET
51 #define VIETNAMESE_CHARSET 163
52 #endif
53 #ifndef JOHAB_CHARSET
54 #define JOHAB_CHARSET 130
55 #endif
57 Lisp_Object Qgdi;
58 Lisp_Object Quniscribe;
59 static Lisp_Object QCformat;
60 static Lisp_Object Qmonospace, Qsansserif, Qmono, Qsans, Qsans_serif;
61 static Lisp_Object Qserif, Qscript, Qdecorative;
62 static Lisp_Object Qraster, Qoutline, Qunknown;
64 /* antialiasing */
65 extern Lisp_Object Qnone; /* reuse from w32fns.c */
66 static Lisp_Object Qstandard, Qsubpixel, Qnatural;
68 /* languages */
69 static Lisp_Object Qzh;
71 /* scripts */
72 static Lisp_Object Qgreek, Qcoptic, Qcyrillic, Qarmenian, Qhebrew;
73 static Lisp_Object Qarabic, Qsyriac, Qnko, Qthaana, Qdevanagari, Qbengali;
74 static Lisp_Object Qgurmukhi, Qgujarati, Qoriya, Qtamil, Qtelugu;
75 static Lisp_Object Qkannada, Qmalayalam, Qsinhala, Qthai, Qlao;
76 static Lisp_Object Qtibetan, Qmyanmar, Qgeorgian, Qhangul, Qethiopic;
77 static Lisp_Object Qcherokee, Qcanadian_aboriginal, Qogham, Qrunic;
78 static Lisp_Object Qkhmer, Qmongolian, Qsymbol, Qbraille, Qhan;
79 static Lisp_Object Qideographic_description, Qcjk_misc, Qkana, Qbopomofo;
80 static Lisp_Object Qkanbun, Qyi, Qbyzantine_musical_symbol;
81 static Lisp_Object Qmusical_symbol, Qmathematical, Qcham, Qphonetic;
82 /* Not defined in characters.el, but referenced in fontset.el. */
83 static Lisp_Object Qbalinese, Qbuginese, Qbuhid, Qcuneiform, Qcypriot;
84 static Lisp_Object Qdeseret, Qglagolitic, Qgothic, Qhanunoo, Qkharoshthi;
85 static Lisp_Object Qlimbu, Qlinear_b, Qold_italic, Qold_persian, Qosmanya;
86 static Lisp_Object Qphags_pa, Qphoenician, Qshavian, Qsyloti_nagri;
87 static Lisp_Object Qtagalog, Qtagbanwa, Qtai_le, Qtifinagh, Qugaritic;
89 /* W32 charsets: for use in Vw32_charset_info_alist. */
90 static Lisp_Object Qw32_charset_ansi, Qw32_charset_default;
91 static Lisp_Object Qw32_charset_symbol, Qw32_charset_shiftjis;
92 static Lisp_Object Qw32_charset_hangeul, Qw32_charset_gb2312;
93 static Lisp_Object Qw32_charset_chinesebig5, Qw32_charset_oem;
94 static Lisp_Object Qw32_charset_easteurope, Qw32_charset_turkish;
95 static Lisp_Object Qw32_charset_baltic, Qw32_charset_russian;
96 static Lisp_Object Qw32_charset_arabic, Qw32_charset_greek;
97 static Lisp_Object Qw32_charset_hebrew, Qw32_charset_vietnamese;
98 static Lisp_Object Qw32_charset_thai, Qw32_charset_johab, Qw32_charset_mac;
100 /* Font spacing symbols - defined in font.c. */
101 extern Lisp_Object Qc, Qp, Qm;
103 static void fill_in_logfont (FRAME_PTR, LOGFONT *, Lisp_Object);
105 static BYTE w32_antialias_type (Lisp_Object);
106 static Lisp_Object lispy_antialias_type (BYTE);
108 static Lisp_Object font_supported_scripts (FONTSIGNATURE *);
109 static int w32font_full_name (LOGFONT *, Lisp_Object, int, char *, int);
110 static void compute_metrics (HDC, struct w32font_info *, unsigned int,
111 struct w32_metric_cache *);
113 static Lisp_Object w32_registry (LONG, DWORD);
115 /* EnumFontFamiliesEx callbacks. */
116 static int CALLBACK add_font_entity_to_list (ENUMLOGFONTEX *,
117 NEWTEXTMETRICEX *,
118 DWORD, LPARAM);
119 static int CALLBACK add_one_font_entity_to_list (ENUMLOGFONTEX *,
120 NEWTEXTMETRICEX *,
121 DWORD, LPARAM);
122 static int CALLBACK add_font_name_to_list (ENUMLOGFONTEX *,
123 NEWTEXTMETRICEX *,
124 DWORD, LPARAM);
126 /* struct passed in as LPARAM arg to EnumFontFamiliesEx, for keeping track
127 of what we really want. */
128 struct font_callback_data
130 /* The logfont we are matching against. EnumFontFamiliesEx only matches
131 face name and charset, so we need to manually match everything else
132 in the callback function. */
133 LOGFONT pattern;
134 /* The original font spec or entity. */
135 Lisp_Object orig_font_spec;
136 /* The frame the font is being loaded on. */
137 Lisp_Object frame;
138 /* The list to add matches to. */
139 Lisp_Object list;
140 /* Whether to match only opentype fonts. */
141 int opentype_only;
144 /* Handles the problem that EnumFontFamiliesEx will not return all
145 style variations if the font name is not specified. */
146 static void list_all_matching_fonts (struct font_callback_data *);
149 static int
150 memq_no_quit (Lisp_Object elt, Lisp_Object list)
152 while (CONSP (list) && ! EQ (XCAR (list), elt))
153 list = XCDR (list);
154 return (CONSP (list));
157 Lisp_Object
158 intern_font_name (char * string)
160 Lisp_Object obarray, tem, str;
161 int len;
163 str = DECODE_SYSTEM (build_string (string));
164 len = SCHARS (str);
166 /* The following code is copied from the function intern (in lread.c). */
167 obarray = Vobarray;
168 if (!VECTORP (obarray) || ASIZE (obarray) == 0)
169 obarray = check_obarray (obarray);
170 tem = oblookup (obarray, SDATA (str), len, len);
171 if (SYMBOLP (tem))
172 return tem;
173 return Fintern (str, obarray);
176 /* w32 implementation of get_cache for font backend.
177 Return a cache of font-entities on FRAME. The cache must be a
178 cons whose cdr part is the actual cache area. */
179 Lisp_Object
180 w32font_get_cache (FRAME_PTR f)
182 struct w32_display_info *dpyinfo = FRAME_X_DISPLAY_INFO (f);
184 return (dpyinfo->name_list_element);
187 /* w32 implementation of list for font backend.
188 List fonts exactly matching with FONT_SPEC on FRAME. The value
189 is a vector of font-entities. This is the sole API that
190 allocates font-entities. */
191 static Lisp_Object
192 w32font_list (Lisp_Object frame, Lisp_Object font_spec)
194 Lisp_Object fonts = w32font_list_internal (frame, font_spec, 0);
195 FONT_ADD_LOG ("w32font-list", font_spec, fonts);
196 return fonts;
199 /* w32 implementation of match for font backend.
200 Return a font entity most closely matching with FONT_SPEC on
201 FRAME. The closeness is detemined by the font backend, thus
202 `face-font-selection-order' is ignored here. */
203 static Lisp_Object
204 w32font_match (Lisp_Object frame, Lisp_Object font_spec)
206 Lisp_Object entity = w32font_match_internal (frame, font_spec, 0);
207 FONT_ADD_LOG ("w32font-match", font_spec, entity);
208 return entity;
211 /* w32 implementation of list_family for font backend.
212 List available families. The value is a list of family names
213 (symbols). */
214 static Lisp_Object
215 w32font_list_family (Lisp_Object frame)
217 Lisp_Object list = Qnil;
218 LOGFONT font_match_pattern;
219 HDC dc;
220 FRAME_PTR f = XFRAME (frame);
222 memset (&font_match_pattern, 0, sizeof (font_match_pattern));
223 font_match_pattern.lfCharSet = DEFAULT_CHARSET;
225 dc = get_frame_dc (f);
227 EnumFontFamiliesEx (dc, &font_match_pattern,
228 (FONTENUMPROC) add_font_name_to_list,
229 (LPARAM) &list, 0);
230 release_frame_dc (f, dc);
232 return list;
235 /* w32 implementation of open for font backend.
236 Open a font specified by FONT_ENTITY on frame F.
237 If the font is scalable, open it with PIXEL_SIZE. */
238 static Lisp_Object
239 w32font_open (FRAME_PTR f, Lisp_Object font_entity, int pixel_size)
241 Lisp_Object font_object
242 = font_make_object (VECSIZE (struct w32font_info),
243 font_entity, pixel_size);
244 struct w32font_info *w32_font
245 = (struct w32font_info *) XFONT_OBJECT (font_object);
247 ASET (font_object, FONT_TYPE_INDEX, Qgdi);
249 if (!w32font_open_internal (f, font_entity, pixel_size, font_object))
251 return Qnil;
254 /* GDI backend does not use glyph indices. */
255 w32_font->glyph_idx = 0;
257 return font_object;
260 /* w32 implementation of close for font_backend.
261 Close FONT on frame F. */
262 void
263 w32font_close (FRAME_PTR f, struct font *font)
265 int i;
266 struct w32font_info *w32_font = (struct w32font_info *) font;
268 /* Delete the GDI font object. */
269 DeleteObject (w32_font->hfont);
271 /* Free all the cached metrics. */
272 if (w32_font->cached_metrics)
274 for (i = 0; i < w32_font->n_cache_blocks; i++)
276 xfree (w32_font->cached_metrics[i]);
278 xfree (w32_font->cached_metrics);
279 w32_font->cached_metrics = NULL;
283 /* w32 implementation of has_char for font backend.
284 Optional.
285 If FONT_ENTITY has a glyph for character C (Unicode code point),
286 return 1. If not, return 0. If a font must be opened to check
287 it, return -1. */
289 w32font_has_char (Lisp_Object entity, int c)
291 /* We can't be certain about which characters a font will support until
292 we open it. Checking the scripts that the font supports turns out
293 to not be reliable. */
294 return -1;
296 #if 0
297 Lisp_Object supported_scripts, extra, script;
298 DWORD mask;
300 extra = AREF (entity, FONT_EXTRA_INDEX);
301 if (!CONSP (extra))
302 return -1;
304 supported_scripts = assq_no_quit (QCscript, extra);
305 /* If font doesn't claim to support any scripts, then we can't be certain
306 until we open it. */
307 if (!CONSP (supported_scripts))
308 return -1;
310 supported_scripts = XCDR (supported_scripts);
312 script = CHAR_TABLE_REF (Vchar_script_table, c);
314 /* If we don't know what script the character is from, then we can't be
315 certain until we open it. Also if the font claims support for the script
316 the character is from, it may only have partial coverage, so we still
317 can't be certain until we open the font. */
318 if (NILP (script) || memq_no_quit (script, supported_scripts))
319 return -1;
321 /* Font reports what scripts it supports, and none of them are the script
322 the character is from. But we still can't be certain, as some fonts
323 will contain some/most/all of the characters in that script without
324 claiming support for it. */
325 return -1;
326 #endif
329 /* w32 implementation of encode_char for font backend.
330 Return a glyph code of FONT for character C (Unicode code point).
331 If FONT doesn't have such a glyph, return FONT_INVALID_CODE.
333 For speed, the gdi backend uses unicode (Emacs calls encode_char
334 far too often for it to be efficient). But we still need to detect
335 which characters are not supported by the font.
337 static unsigned
338 w32font_encode_char (struct font *font, int c)
340 struct w32font_info * w32_font = (struct w32font_info *)font;
342 if (c < w32_font->metrics.tmFirstChar
343 || c > w32_font->metrics.tmLastChar)
344 return FONT_INVALID_CODE;
345 else
346 return c;
349 /* w32 implementation of text_extents for font backend.
350 Perform the size computation of glyphs of FONT and fillin members
351 of METRICS. The glyphs are specified by their glyph codes in
352 CODE (length NGLYPHS). Apparently metrics can be NULL, in this
353 case just return the overall width. */
355 w32font_text_extents (struct font *font, unsigned *code,
356 int nglyphs, struct font_metrics *metrics)
358 int i;
359 HFONT old_font = NULL;
360 HDC dc = NULL;
361 struct frame * f;
362 int total_width = 0;
363 WORD *wcode;
364 SIZE size;
366 struct w32font_info *w32_font = (struct w32font_info *) font;
368 if (metrics)
370 memset (metrics, 0, sizeof (struct font_metrics));
371 metrics->ascent = font->ascent;
372 metrics->descent = font->descent;
374 for (i = 0; i < nglyphs; i++)
376 struct w32_metric_cache *char_metric;
377 int block = *(code + i) / CACHE_BLOCKSIZE;
378 int pos_in_block = *(code + i) % CACHE_BLOCKSIZE;
380 if (block >= w32_font->n_cache_blocks)
382 if (!w32_font->cached_metrics)
383 w32_font->cached_metrics
384 = xmalloc ((block + 1)
385 * sizeof (struct w32_metric_cache *));
386 else
387 w32_font->cached_metrics
388 = xrealloc (w32_font->cached_metrics,
389 (block + 1)
390 * sizeof (struct w32_metric_cache *));
391 memset (w32_font->cached_metrics + w32_font->n_cache_blocks, 0,
392 ((block + 1 - w32_font->n_cache_blocks)
393 * sizeof (struct w32_metric_cache *)));
394 w32_font->n_cache_blocks = block + 1;
397 if (!w32_font->cached_metrics[block])
399 w32_font->cached_metrics[block]
400 = xmalloc (CACHE_BLOCKSIZE * sizeof (struct w32_metric_cache));
401 memset (w32_font->cached_metrics[block], 0,
402 CACHE_BLOCKSIZE * sizeof (struct w32_metric_cache));
405 char_metric = w32_font->cached_metrics[block] + pos_in_block;
407 if (char_metric->status == W32METRIC_NO_ATTEMPT)
409 if (dc == NULL)
411 /* TODO: Frames can come and go, and their fonts
412 outlive them. So we can't cache the frame in the
413 font structure. Use selected_frame until the API
414 is updated to pass in a frame. */
415 f = XFRAME (selected_frame);
417 dc = get_frame_dc (f);
418 old_font = SelectObject (dc, w32_font->hfont);
420 compute_metrics (dc, w32_font, *(code + i), char_metric);
423 if (char_metric->status == W32METRIC_SUCCESS)
425 metrics->lbearing = min (metrics->lbearing,
426 metrics->width + char_metric->lbearing);
427 metrics->rbearing = max (metrics->rbearing,
428 metrics->width + char_metric->rbearing);
429 metrics->width += char_metric->width;
431 else
432 /* If we couldn't get metrics for a char,
433 use alternative method. */
434 break;
436 /* If we got through everything, return. */
437 if (i == nglyphs)
439 if (dc != NULL)
441 /* Restore state and release DC. */
442 SelectObject (dc, old_font);
443 release_frame_dc (f, dc);
446 return metrics->width;
450 /* For non-truetype fonts, GetGlyphOutlineW is not supported, so
451 fallback on other methods that will at least give some of the metric
452 information. */
454 /* Make array big enough to hold surrogates. */
455 wcode = alloca (nglyphs * sizeof (WORD) * 2);
456 for (i = 0; i < nglyphs; i++)
458 if (code[i] < 0x10000)
459 wcode[i] = code[i];
460 else
462 DWORD surrogate = code[i] - 0x10000;
464 /* High surrogate: U+D800 - U+DBFF. */
465 wcode[i++] = 0xD800 + ((surrogate >> 10) & 0x03FF);
466 /* Low surrogate: U+DC00 - U+DFFF. */
467 wcode[i] = 0xDC00 + (surrogate & 0x03FF);
468 /* An extra glyph. wcode is already double the size of code to
469 cope with this. */
470 nglyphs++;
474 if (dc == NULL)
476 /* TODO: Frames can come and go, and their fonts outlive
477 them. So we can't cache the frame in the font structure. Use
478 selected_frame until the API is updated to pass in a
479 frame. */
480 f = XFRAME (selected_frame);
482 dc = get_frame_dc (f);
483 old_font = SelectObject (dc, w32_font->hfont);
486 if (GetTextExtentPoint32W (dc, wcode, nglyphs, &size))
488 total_width = size.cx;
491 /* On 95/98/ME, only some unicode functions are available, so fallback
492 on doing a dummy draw to find the total width. */
493 if (!total_width)
495 RECT rect;
496 rect.top = 0; rect.bottom = font->height; rect.left = 0; rect.right = 1;
497 DrawTextW (dc, wcode, nglyphs, &rect,
498 DT_CALCRECT | DT_NOPREFIX | DT_SINGLELINE);
499 total_width = rect.right;
502 /* Give our best estimate of the metrics, based on what we know. */
503 if (metrics)
505 metrics->width = total_width - w32_font->metrics.tmOverhang;
506 metrics->lbearing = 0;
507 metrics->rbearing = total_width;
510 /* Restore state and release DC. */
511 SelectObject (dc, old_font);
512 release_frame_dc (f, dc);
514 return total_width;
517 /* w32 implementation of draw for font backend.
518 Optional.
519 Draw glyphs between FROM and TO of S->char2b at (X Y) pixel
520 position of frame F with S->FACE and S->GC. If WITH_BACKGROUND
521 is nonzero, fill the background in advance. It is assured that
522 WITH_BACKGROUND is zero when (FROM > 0 || TO < S->nchars).
524 TODO: Currently this assumes that the colors and fonts are already
525 set in the DC. This seems to be true now, but maybe only due to
526 the old font code setting it up. It may be safer to resolve faces
527 and fonts in here and set them explicitly
531 w32font_draw (struct glyph_string *s, int from, int to,
532 int x, int y, int with_background)
534 UINT options;
535 HRGN orig_clip = NULL;
536 int len = to - from;
537 struct w32font_info *w32font = (struct w32font_info *) s->font;
539 options = w32font->glyph_idx;
541 if (s->num_clips > 0)
543 HRGN new_clip = CreateRectRgnIndirect (s->clip);
545 /* Save clip region for later restoration. */
546 orig_clip = CreateRectRgn (0, 0, 0, 0);
547 if (!GetClipRgn (s->hdc, orig_clip))
549 DeleteObject (orig_clip);
550 orig_clip = NULL;
553 if (s->num_clips > 1)
555 HRGN clip2 = CreateRectRgnIndirect (s->clip + 1);
557 CombineRgn (new_clip, new_clip, clip2, RGN_OR);
558 DeleteObject (clip2);
561 SelectClipRgn (s->hdc, new_clip);
562 DeleteObject (new_clip);
565 /* Using OPAQUE background mode can clear more background than expected
566 when Cleartype is used. Draw the background manually to avoid this. */
567 SetBkMode (s->hdc, TRANSPARENT);
568 if (with_background)
570 HBRUSH brush;
571 RECT rect;
572 struct font *font = s->font;
574 brush = CreateSolidBrush (s->gc->background);
575 rect.left = x;
576 rect.top = y - font->ascent;
577 rect.right = x + s->width;
578 rect.bottom = y + font->descent;
579 FillRect (s->hdc, &rect, brush);
580 DeleteObject (brush);
583 if (s->padding_p)
585 int i;
587 for (i = 0; i < len; i++)
588 ExtTextOutW (s->hdc, x + i, y, options, NULL,
589 s->char2b + from + i, 1, NULL);
591 else
592 ExtTextOutW (s->hdc, x, y, options, NULL, s->char2b + from, len, NULL);
594 /* Restore clip region. */
595 if (s->num_clips > 0)
596 SelectClipRgn (s->hdc, orig_clip);
598 if (orig_clip)
599 DeleteObject (orig_clip);
601 return len;
604 /* w32 implementation of free_entity for font backend.
605 Optional (if FONT_EXTRA_INDEX is not Lisp_Save_Value).
606 Free FONT_EXTRA_INDEX field of FONT_ENTITY.
607 static void
608 w32font_free_entity (Lisp_Object entity);
611 /* w32 implementation of prepare_face for font backend.
612 Optional (if FACE->extra is not used).
613 Prepare FACE for displaying characters by FONT on frame F by
614 storing some data in FACE->extra. If successful, return 0.
615 Otherwise, return -1.
616 static int
617 w32font_prepare_face (FRAME_PTR f, struct face *face);
619 /* w32 implementation of done_face for font backend.
620 Optional.
621 Done FACE for displaying characters by FACE->font on frame F.
622 static void
623 w32font_done_face (FRAME_PTR f, struct face *face); */
625 /* w32 implementation of get_bitmap for font backend.
626 Optional.
627 Store bitmap data for glyph-code CODE of FONT in BITMAP. It is
628 intended that this method is called from the other font-driver
629 for actual drawing.
630 static int
631 w32font_get_bitmap (struct font *font, unsigned code,
632 struct font_bitmap *bitmap, int bits_per_pixel);
634 /* w32 implementation of free_bitmap for font backend.
635 Optional.
636 Free bitmap data in BITMAP.
637 static void
638 w32font_free_bitmap (struct font *font, struct font_bitmap *bitmap);
640 /* w32 implementation of get_outline for font backend.
641 Optional.
642 Return an outline data for glyph-code CODE of FONT. The format
643 of the outline data depends on the font-driver.
644 static void *
645 w32font_get_outline (struct font *font, unsigned code);
647 /* w32 implementation of free_outline for font backend.
648 Optional.
649 Free OUTLINE (that is obtained by the above method).
650 static void
651 w32font_free_outline (struct font *font, void *outline);
653 /* w32 implementation of anchor_point for font backend.
654 Optional.
655 Get coordinates of the INDEXth anchor point of the glyph whose
656 code is CODE. Store the coordinates in *X and *Y. Return 0 if
657 the operations was successfull. Otherwise return -1.
658 static int
659 w32font_anchor_point (struct font *font, unsigned code,
660 int index, int *x, int *y);
662 /* w32 implementation of otf_capability for font backend.
663 Optional.
664 Return a list describing which scripts/languages FONT
665 supports by which GSUB/GPOS features of OpenType tables.
666 static Lisp_Object
667 w32font_otf_capability (struct font *font);
669 /* w32 implementation of otf_drive for font backend.
670 Optional.
671 Apply FONT's OTF-FEATURES to the glyph string.
673 FEATURES specifies which OTF features to apply in this format:
674 (SCRIPT LANGSYS GSUB-FEATURE GPOS-FEATURE)
675 See the documentation of `font-drive-otf' for the detail.
677 This method applies the specified features to the codes in the
678 elements of GSTRING-IN (between FROMth and TOth). The output
679 codes are stored in GSTRING-OUT at the IDXth element and the
680 following elements.
682 Return the number of output codes. If none of the features are
683 applicable to the input data, return 0. If GSTRING-OUT is too
684 short, return -1.
685 static int
686 w32font_otf_drive (struct font *font, Lisp_Object features,
687 Lisp_Object gstring_in, int from, int to,
688 Lisp_Object gstring_out, int idx,
689 int alternate_subst);
692 /* Internal implementation of w32font_list.
693 Additional parameter opentype_only restricts the returned fonts to
694 opentype fonts, which can be used with the Uniscribe backend. */
695 Lisp_Object
696 w32font_list_internal (Lisp_Object frame, Lisp_Object font_spec, int opentype_only)
698 struct font_callback_data match_data;
699 HDC dc;
700 FRAME_PTR f = XFRAME (frame);
702 match_data.orig_font_spec = font_spec;
703 match_data.list = Qnil;
704 match_data.frame = frame;
706 memset (&match_data.pattern, 0, sizeof (LOGFONT));
707 fill_in_logfont (f, &match_data.pattern, font_spec);
709 /* If the charset is unrecognized, then we won't find a font, so don't
710 waste time looking for one. */
711 if (match_data.pattern.lfCharSet == DEFAULT_CHARSET)
713 Lisp_Object spec_charset = AREF (font_spec, FONT_REGISTRY_INDEX);
714 if (!NILP (spec_charset)
715 && !EQ (spec_charset, Qiso10646_1)
716 && !EQ (spec_charset, Qunicode_bmp)
717 && !EQ (spec_charset, Qunicode_sip)
718 && !EQ (spec_charset, Qunknown))
719 return Qnil;
722 match_data.opentype_only = opentype_only;
723 if (opentype_only)
724 match_data.pattern.lfOutPrecision = OUT_OUTLINE_PRECIS;
726 if (match_data.pattern.lfFaceName[0] == '\0')
728 /* EnumFontFamiliesEx does not take other fields into account if
729 font name is blank, so need to use two passes. */
730 list_all_matching_fonts (&match_data);
732 else
734 dc = get_frame_dc (f);
736 EnumFontFamiliesEx (dc, &match_data.pattern,
737 (FONTENUMPROC) add_font_entity_to_list,
738 (LPARAM) &match_data, 0);
739 release_frame_dc (f, dc);
742 return match_data.list;
745 /* Internal implementation of w32font_match.
746 Additional parameter opentype_only restricts the returned fonts to
747 opentype fonts, which can be used with the Uniscribe backend. */
748 Lisp_Object
749 w32font_match_internal (Lisp_Object frame, Lisp_Object font_spec, int opentype_only)
751 struct font_callback_data match_data;
752 HDC dc;
753 FRAME_PTR f = XFRAME (frame);
755 match_data.orig_font_spec = font_spec;
756 match_data.frame = frame;
757 match_data.list = Qnil;
759 memset (&match_data.pattern, 0, sizeof (LOGFONT));
760 fill_in_logfont (f, &match_data.pattern, font_spec);
762 match_data.opentype_only = opentype_only;
763 if (opentype_only)
764 match_data.pattern.lfOutPrecision = OUT_OUTLINE_PRECIS;
766 dc = get_frame_dc (f);
768 EnumFontFamiliesEx (dc, &match_data.pattern,
769 (FONTENUMPROC) add_one_font_entity_to_list,
770 (LPARAM) &match_data, 0);
771 release_frame_dc (f, dc);
773 return NILP (match_data.list) ? Qnil : XCAR (match_data.list);
777 w32font_open_internal (FRAME_PTR f, Lisp_Object font_entity,
778 int pixel_size, Lisp_Object font_object)
780 int len, size;
781 LOGFONT logfont;
782 HDC dc;
783 HFONT hfont, old_font;
784 Lisp_Object val, extra;
785 struct w32font_info *w32_font;
786 struct font * font;
787 OUTLINETEXTMETRICW* metrics = NULL;
789 w32_font = (struct w32font_info *) XFONT_OBJECT (font_object);
790 font = (struct font *) w32_font;
792 if (!font)
793 return 0;
795 memset (&logfont, 0, sizeof (logfont));
796 fill_in_logfont (f, &logfont, font_entity);
798 /* Prefer truetype fonts, to avoid known problems with type1 fonts, and
799 limitations in bitmap fonts. */
800 val = AREF (font_entity, FONT_FOUNDRY_INDEX);
801 if (!EQ (val, Qraster))
802 logfont.lfOutPrecision = OUT_TT_PRECIS;
804 size = XINT (AREF (font_entity, FONT_SIZE_INDEX));
805 if (!size)
806 size = pixel_size;
808 logfont.lfHeight = -size;
809 hfont = CreateFontIndirect (&logfont);
811 if (hfont == NULL)
812 return 0;
814 /* Get the metrics for this font. */
815 dc = get_frame_dc (f);
816 old_font = SelectObject (dc, hfont);
818 /* Try getting the outline metrics (only works for truetype fonts). */
819 len = GetOutlineTextMetricsW (dc, 0, NULL);
820 if (len)
822 metrics = (OUTLINETEXTMETRICW *) alloca (len);
823 if (GetOutlineTextMetricsW (dc, len, metrics))
824 memcpy (&w32_font->metrics, &metrics->otmTextMetrics,
825 sizeof (TEXTMETRICW));
826 else
827 metrics = NULL;
830 if (!metrics)
831 GetTextMetricsW (dc, &w32_font->metrics);
833 w32_font->cached_metrics = NULL;
834 w32_font->n_cache_blocks = 0;
836 SelectObject (dc, old_font);
837 release_frame_dc (f, dc);
839 w32_font->hfont = hfont;
842 char *name;
844 /* We don't know how much space we need for the full name, so start with
845 96 bytes and go up in steps of 32. */
846 len = 96;
847 name = alloca (len);
848 while (name && w32font_full_name (&logfont, font_entity, pixel_size,
849 name, len) < 0)
851 len += 32;
852 name = alloca (len);
854 if (name)
855 font->props[FONT_FULLNAME_INDEX]
856 = DECODE_SYSTEM (build_string (name));
857 else
858 font->props[FONT_FULLNAME_INDEX]
859 = DECODE_SYSTEM (build_string (logfont.lfFaceName));
862 font->max_width = w32_font->metrics.tmMaxCharWidth;
863 /* Parts of Emacs display assume that height = ascent + descent...
864 so height is defined later, after ascent and descent.
865 font->height = w32_font->metrics.tmHeight
866 + w32_font->metrics.tmExternalLeading;
869 font->space_width = font->average_width = w32_font->metrics.tmAveCharWidth;
871 font->vertical_centering = 0;
872 font->encoding_type = 0;
873 font->baseline_offset = 0;
874 font->relative_compose = 0;
875 font->default_ascent = w32_font->metrics.tmAscent;
876 font->font_encoder = NULL;
877 font->pixel_size = size;
878 font->driver = &w32font_driver;
879 /* Use format cached during list, as the information we have access to
880 here is incomplete. */
881 extra = AREF (font_entity, FONT_EXTRA_INDEX);
882 if (CONSP (extra))
884 val = assq_no_quit (QCformat, extra);
885 if (CONSP (val))
886 font->props[FONT_FORMAT_INDEX] = XCDR (val);
887 else
888 font->props[FONT_FORMAT_INDEX] = Qunknown;
890 else
891 font->props[FONT_FORMAT_INDEX] = Qunknown;
893 font->props[FONT_FILE_INDEX] = Qnil;
894 font->encoding_charset = -1;
895 font->repertory_charset = -1;
896 /* TODO: do we really want the minimum width here, which could be negative? */
897 font->min_width = font->space_width;
898 font->ascent = w32_font->metrics.tmAscent;
899 font->descent = w32_font->metrics.tmDescent;
900 font->height = font->ascent + font->descent;
902 if (metrics)
904 font->underline_thickness = metrics->otmsUnderscoreSize;
905 font->underline_position = -metrics->otmsUnderscorePosition;
907 else
909 font->underline_thickness = 0;
910 font->underline_position = -1;
913 /* For temporary compatibility with legacy code that expects the
914 name to be usable in x-list-fonts. Eventually we expect to change
915 x-list-fonts and other places that use fonts so that this can be
916 an fcname or similar. */
917 font->props[FONT_NAME_INDEX] = Ffont_xlfd_name (font_object, Qnil);
919 return 1;
922 /* Callback function for EnumFontFamiliesEx.
923 * Adds the name of a font to a Lisp list (passed in as the lParam arg). */
924 static int CALLBACK
925 add_font_name_to_list (ENUMLOGFONTEX *logical_font,
926 NEWTEXTMETRICEX *physical_font,
927 DWORD font_type, LPARAM list_object)
929 Lisp_Object* list = (Lisp_Object *) list_object;
930 Lisp_Object family;
932 /* Skip vertical fonts (intended only for printing) */
933 if (logical_font->elfLogFont.lfFaceName[0] == '@')
934 return 1;
936 family = intern_font_name (logical_font->elfLogFont.lfFaceName);
937 if (! memq_no_quit (family, *list))
938 *list = Fcons (family, *list);
940 return 1;
943 static int w32_decode_weight (int);
944 static int w32_encode_weight (int);
946 /* Convert an enumerated Windows font to an Emacs font entity. */
947 static Lisp_Object
948 w32_enumfont_pattern_entity (Lisp_Object frame,
949 ENUMLOGFONTEX *logical_font,
950 NEWTEXTMETRICEX *physical_font,
951 DWORD font_type,
952 LOGFONT *requested_font,
953 Lisp_Object backend)
955 Lisp_Object entity, tem;
956 LOGFONT *lf = (LOGFONT*) logical_font;
957 BYTE generic_type;
958 DWORD full_type = physical_font->ntmTm.ntmFlags;
960 entity = font_make_entity ();
962 ASET (entity, FONT_TYPE_INDEX, backend);
963 ASET (entity, FONT_REGISTRY_INDEX, w32_registry (lf->lfCharSet, font_type));
964 ASET (entity, FONT_OBJLIST_INDEX, Qnil);
966 /* Foundry is difficult to get in readable form on Windows.
967 But Emacs crashes if it is not set, so set it to something more
968 generic. These values make xlfds compatible with Emacs 22. */
969 if (lf->lfOutPrecision == OUT_STRING_PRECIS)
970 tem = Qraster;
971 else if (lf->lfOutPrecision == OUT_STROKE_PRECIS)
972 tem = Qoutline;
973 else
974 tem = Qunknown;
976 ASET (entity, FONT_FOUNDRY_INDEX, tem);
978 /* Save the generic family in the extra info, as it is likely to be
979 useful to users looking for a close match. */
980 generic_type = physical_font->ntmTm.tmPitchAndFamily & 0xF0;
981 if (generic_type == FF_DECORATIVE)
982 tem = Qdecorative;
983 else if (generic_type == FF_MODERN)
984 tem = Qmono;
985 else if (generic_type == FF_ROMAN)
986 tem = Qserif;
987 else if (generic_type == FF_SCRIPT)
988 tem = Qscript;
989 else if (generic_type == FF_SWISS)
990 tem = Qsans;
991 else
992 tem = Qnil;
994 ASET (entity, FONT_ADSTYLE_INDEX, tem);
996 if (physical_font->ntmTm.tmPitchAndFamily & 0x01)
997 ASET (entity, FONT_SPACING_INDEX, make_number (FONT_SPACING_PROPORTIONAL));
998 else
999 ASET (entity, FONT_SPACING_INDEX, make_number (FONT_SPACING_CHARCELL));
1001 if (requested_font->lfQuality != DEFAULT_QUALITY)
1003 font_put_extra (entity, QCantialias,
1004 lispy_antialias_type (requested_font->lfQuality));
1006 ASET (entity, FONT_FAMILY_INDEX,
1007 intern_font_name (lf->lfFaceName));
1009 FONT_SET_STYLE (entity, FONT_WEIGHT_INDEX,
1010 make_number (w32_decode_weight (lf->lfWeight)));
1011 FONT_SET_STYLE (entity, FONT_SLANT_INDEX,
1012 make_number (lf->lfItalic ? 200 : 100));
1013 /* TODO: PANOSE struct has this info, but need to call GetOutlineTextMetrics
1014 to get it. */
1015 FONT_SET_STYLE (entity, FONT_WIDTH_INDEX, make_number (100));
1017 if (font_type & RASTER_FONTTYPE)
1018 ASET (entity, FONT_SIZE_INDEX,
1019 make_number (physical_font->ntmTm.tmHeight
1020 + physical_font->ntmTm.tmExternalLeading));
1021 else
1022 ASET (entity, FONT_SIZE_INDEX, make_number (0));
1024 /* Cache unicode codepoints covered by this font, as there is no other way
1025 of getting this information easily. */
1026 if (font_type & TRUETYPE_FONTTYPE)
1028 tem = font_supported_scripts (&physical_font->ntmFontSig);
1029 if (!NILP (tem))
1030 font_put_extra (entity, QCscript, tem);
1033 /* This information is not fully available when opening fonts, so
1034 save it here. Only Windows 2000 and later return information
1035 about opentype and type1 fonts, so need a fallback for detecting
1036 truetype so that this information is not any worse than we could
1037 have obtained later. */
1038 if (EQ (backend, Quniscribe) && (full_type & NTMFLAGS_OPENTYPE))
1039 tem = intern ("opentype");
1040 else if (font_type & TRUETYPE_FONTTYPE)
1041 tem = intern ("truetype");
1042 else if (full_type & NTM_PS_OPENTYPE)
1043 tem = intern ("postscript");
1044 else if (full_type & NTM_TYPE1)
1045 tem = intern ("type1");
1046 else if (font_type & RASTER_FONTTYPE)
1047 tem = intern ("w32bitmap");
1048 else
1049 tem = intern ("w32vector");
1051 font_put_extra (entity, QCformat, tem);
1053 return entity;
1057 /* Convert generic families to the family portion of lfPitchAndFamily. */
1058 static BYTE
1059 w32_generic_family (Lisp_Object name)
1061 /* Generic families. */
1062 if (EQ (name, Qmonospace) || EQ (name, Qmono))
1063 return FF_MODERN;
1064 else if (EQ (name, Qsans) || EQ (name, Qsans_serif) || EQ (name, Qsansserif))
1065 return FF_SWISS;
1066 else if (EQ (name, Qserif))
1067 return FF_ROMAN;
1068 else if (EQ (name, Qdecorative))
1069 return FF_DECORATIVE;
1070 else if (EQ (name, Qscript))
1071 return FF_SCRIPT;
1072 else
1073 return FF_DONTCARE;
1076 static int
1077 logfonts_match (LOGFONT *font, LOGFONT *pattern)
1079 /* Only check height for raster fonts. */
1080 if (pattern->lfHeight && font->lfOutPrecision == OUT_STRING_PRECIS
1081 && font->lfHeight != pattern->lfHeight)
1082 return 0;
1084 /* Have some flexibility with weights. */
1085 if (pattern->lfWeight
1086 && ((font->lfWeight < (pattern->lfWeight - 150))
1087 || font->lfWeight > (pattern->lfWeight + 150)))
1088 return 0;
1090 /* Charset and face should be OK. Italic has to be checked
1091 against the original spec, in case we don't have any preference. */
1092 return 1;
1095 /* Codepage Bitfields in FONTSIGNATURE struct. */
1096 #define CSB_JAPANESE (1 << 17)
1097 #define CSB_KOREAN ((1 << 19) | (1 << 21))
1098 #define CSB_CHINESE ((1 << 18) | (1 << 20))
1100 static int
1101 font_matches_spec (DWORD type, NEWTEXTMETRICEX *font,
1102 Lisp_Object spec, Lisp_Object backend,
1103 LOGFONT *logfont)
1105 Lisp_Object extra, val;
1107 /* Check italic. Can't check logfonts, since it is a boolean field,
1108 so there is no difference between "non-italic" and "don't care". */
1110 int slant = FONT_SLANT_NUMERIC (spec);
1112 if (slant >= 0
1113 && ((slant > 150 && !font->ntmTm.tmItalic)
1114 || (slant <= 150 && font->ntmTm.tmItalic)))
1115 return 0;
1118 /* Check adstyle against generic family. */
1119 val = AREF (spec, FONT_ADSTYLE_INDEX);
1120 if (!NILP (val))
1122 BYTE family = w32_generic_family (val);
1123 if (family != FF_DONTCARE
1124 && family != (font->ntmTm.tmPitchAndFamily & 0xF0))
1125 return 0;
1128 /* Check spacing */
1129 val = AREF (spec, FONT_SPACING_INDEX);
1130 if (INTEGERP (val))
1132 int spacing = XINT (val);
1133 int proportional = (spacing < FONT_SPACING_MONO);
1135 if ((proportional && !(font->ntmTm.tmPitchAndFamily & 0x01))
1136 || (!proportional && (font->ntmTm.tmPitchAndFamily & 0x01)))
1137 return 0;
1140 /* Check extra parameters. */
1141 for (extra = AREF (spec, FONT_EXTRA_INDEX);
1142 CONSP (extra); extra = XCDR (extra))
1144 Lisp_Object extra_entry;
1145 extra_entry = XCAR (extra);
1146 if (CONSP (extra_entry))
1148 Lisp_Object key = XCAR (extra_entry);
1150 val = XCDR (extra_entry);
1151 if (EQ (key, QCscript) && SYMBOLP (val))
1153 /* Only truetype fonts will have information about what
1154 scripts they support. This probably means the user
1155 will have to force Emacs to use raster, postscript
1156 or atm fonts for non-ASCII text. */
1157 if (type & TRUETYPE_FONTTYPE)
1159 Lisp_Object support
1160 = font_supported_scripts (&font->ntmFontSig);
1161 if (! memq_no_quit (val, support))
1162 return 0;
1164 else
1166 /* Return specific matches, but play it safe. Fonts
1167 that cover more than their charset would suggest
1168 are likely to be truetype or opentype fonts,
1169 covered above. */
1170 if (EQ (val, Qlatin))
1172 /* Although every charset but symbol, thai and
1173 arabic contains the basic ASCII set of latin
1174 characters, Emacs expects much more. */
1175 if (font->ntmTm.tmCharSet != ANSI_CHARSET)
1176 return 0;
1178 else if (EQ (val, Qsymbol))
1180 if (font->ntmTm.tmCharSet != SYMBOL_CHARSET)
1181 return 0;
1183 else if (EQ (val, Qcyrillic))
1185 if (font->ntmTm.tmCharSet != RUSSIAN_CHARSET)
1186 return 0;
1188 else if (EQ (val, Qgreek))
1190 if (font->ntmTm.tmCharSet != GREEK_CHARSET)
1191 return 0;
1193 else if (EQ (val, Qarabic))
1195 if (font->ntmTm.tmCharSet != ARABIC_CHARSET)
1196 return 0;
1198 else if (EQ (val, Qhebrew))
1200 if (font->ntmTm.tmCharSet != HEBREW_CHARSET)
1201 return 0;
1203 else if (EQ (val, Qthai))
1205 if (font->ntmTm.tmCharSet != THAI_CHARSET)
1206 return 0;
1208 else if (EQ (val, Qkana))
1210 if (font->ntmTm.tmCharSet != SHIFTJIS_CHARSET)
1211 return 0;
1213 else if (EQ (val, Qbopomofo))
1215 if (font->ntmTm.tmCharSet != CHINESEBIG5_CHARSET)
1216 return 0;
1218 else if (EQ (val, Qhangul))
1220 if (font->ntmTm.tmCharSet != HANGUL_CHARSET
1221 && font->ntmTm.tmCharSet != JOHAB_CHARSET)
1222 return 0;
1224 else if (EQ (val, Qhan))
1226 if (font->ntmTm.tmCharSet != CHINESEBIG5_CHARSET
1227 && font->ntmTm.tmCharSet != GB2312_CHARSET
1228 && font->ntmTm.tmCharSet != HANGUL_CHARSET
1229 && font->ntmTm.tmCharSet != JOHAB_CHARSET
1230 && font->ntmTm.tmCharSet != SHIFTJIS_CHARSET)
1231 return 0;
1233 else
1234 /* Other scripts unlikely to be handled by non-truetype
1235 fonts. */
1236 return 0;
1239 else if (EQ (key, QClang) && SYMBOLP (val))
1241 /* Just handle the CJK languages here, as the lang
1242 parameter is used to select a font with appropriate
1243 glyphs in the cjk unified ideographs block. Other fonts
1244 support for a language can be solely determined by
1245 its character coverage. */
1246 if (EQ (val, Qja))
1248 if (!(font->ntmFontSig.fsCsb[0] & CSB_JAPANESE))
1249 return 0;
1251 else if (EQ (val, Qko))
1253 if (!(font->ntmFontSig.fsCsb[0] & CSB_KOREAN))
1254 return 0;
1256 else if (EQ (val, Qzh))
1258 if (!(font->ntmFontSig.fsCsb[0] & CSB_CHINESE))
1259 return 0;
1261 else
1262 /* Any other language, we don't recognize it. Only the above
1263 currently appear in fontset.el, so it isn't worth
1264 creating a mapping table of codepages/scripts to languages
1265 or opening the font to see if there are any language tags
1266 in it that the W32 API does not expose. Fontset
1267 spec should have a fallback, as some backends do
1268 not recognize language at all. */
1269 return 0;
1271 else if (EQ (key, QCotf) && CONSP (val))
1273 /* OTF features only supported by the uniscribe backend. */
1274 if (EQ (backend, Quniscribe))
1276 if (!uniscribe_check_otf (logfont, val))
1277 return 0;
1279 else
1280 return 0;
1284 return 1;
1287 static int
1288 w32font_coverage_ok (FONTSIGNATURE * coverage, BYTE charset)
1290 DWORD subrange1 = coverage->fsUsb[1];
1292 #define SUBRANGE1_HAN_MASK 0x08000000
1293 #define SUBRANGE1_HANGEUL_MASK 0x01000000
1294 #define SUBRANGE1_JAPANESE_MASK (0x00060000 | SUBRANGE1_HAN_MASK)
1296 if (charset == GB2312_CHARSET || charset == CHINESEBIG5_CHARSET)
1298 return (subrange1 & SUBRANGE1_HAN_MASK) == SUBRANGE1_HAN_MASK;
1300 else if (charset == SHIFTJIS_CHARSET)
1302 return (subrange1 & SUBRANGE1_JAPANESE_MASK) == SUBRANGE1_JAPANESE_MASK;
1304 else if (charset == HANGEUL_CHARSET)
1306 return (subrange1 & SUBRANGE1_HANGEUL_MASK) == SUBRANGE1_HANGEUL_MASK;
1309 return 1;
1313 static int
1314 check_face_name (LOGFONT *font, char *full_name)
1316 char full_iname[LF_FULLFACESIZE+1];
1318 /* Just check for names known to cause problems, since the full name
1319 can contain expanded abbreviations, prefixed foundry, postfixed
1320 style, the latter of which sometimes differs from the style indicated
1321 in the shorter name (eg Lt becomes Light or even Extra Light) */
1323 /* Helvetica is mapped to Arial in Windows, but if a Type-1 Helvetica is
1324 installed, we run into problems with the Uniscribe backend which tries
1325 to avoid non-truetype fonts, and ends up mixing the Type-1 Helvetica
1326 with Arial's characteristics, since that attempt to use Truetype works
1327 some places, but not others. */
1328 if (!xstrcasecmp (font->lfFaceName, "helvetica"))
1330 strncpy (full_iname, full_name, LF_FULLFACESIZE);
1331 full_iname[LF_FULLFACESIZE] = 0;
1332 _strlwr (full_iname);
1333 return strstr ("helvetica", full_iname) != NULL;
1335 /* Same for Helv. */
1336 if (!xstrcasecmp (font->lfFaceName, "helv"))
1338 strncpy (full_iname, full_name, LF_FULLFACESIZE);
1339 full_iname[LF_FULLFACESIZE] = 0;
1340 _strlwr (full_iname);
1341 return strstr ("helv", full_iname) != NULL;
1344 /* Since Times is mapped to Times New Roman, a substring
1345 match is not sufficient to filter out the bogus match. */
1346 else if (!xstrcasecmp (font->lfFaceName, "times"))
1347 return xstrcasecmp (full_name, "times") == 0;
1349 return 1;
1353 /* Callback function for EnumFontFamiliesEx.
1354 * Checks if a font matches everything we are trying to check agaist,
1355 * and if so, adds it to a list. Both the data we are checking against
1356 * and the list to which the fonts are added are passed in via the
1357 * lparam argument, in the form of a font_callback_data struct. */
1358 static int CALLBACK
1359 add_font_entity_to_list (ENUMLOGFONTEX *logical_font,
1360 NEWTEXTMETRICEX *physical_font,
1361 DWORD font_type, LPARAM lParam)
1363 struct font_callback_data *match_data
1364 = (struct font_callback_data *) lParam;
1365 Lisp_Object backend = match_data->opentype_only ? Quniscribe : Qgdi;
1366 Lisp_Object entity;
1368 int is_unicode = physical_font->ntmFontSig.fsUsb[3]
1369 || physical_font->ntmFontSig.fsUsb[2]
1370 || physical_font->ntmFontSig.fsUsb[1]
1371 || physical_font->ntmFontSig.fsUsb[0] & 0x3fffffff;
1373 /* Skip non matching fonts. */
1375 /* For uniscribe backend, consider only truetype or opentype fonts
1376 that have some unicode coverage. */
1377 if (match_data->opentype_only
1378 && ((!physical_font->ntmTm.ntmFlags & NTMFLAGS_OPENTYPE
1379 && !(font_type & TRUETYPE_FONTTYPE))
1380 || !is_unicode))
1381 return 1;
1383 /* Ensure a match. */
1384 if (!logfonts_match (&logical_font->elfLogFont, &match_data->pattern)
1385 || !font_matches_spec (font_type, physical_font,
1386 match_data->orig_font_spec, backend,
1387 &logical_font->elfLogFont)
1388 || !w32font_coverage_ok (&physical_font->ntmFontSig,
1389 match_data->pattern.lfCharSet))
1390 return 1;
1392 /* Avoid substitutions involving raster fonts (eg Helv -> MS Sans Serif)
1393 We limit this to raster fonts, because the test can catch some
1394 genuine fonts (eg the full name of DejaVu Sans Mono Light is actually
1395 DejaVu Sans Mono ExtraLight). Helvetica -> Arial substitution will
1396 therefore get through this test. Since full names can be prefixed
1397 by a foundry, we accept raster fonts if the font name is found
1398 anywhere within the full name. */
1399 if ((logical_font->elfLogFont.lfOutPrecision == OUT_STRING_PRECIS
1400 && !strstr (logical_font->elfFullName,
1401 logical_font->elfLogFont.lfFaceName))
1402 /* Check for well known substitutions that mess things up in the
1403 presence of Type-1 fonts of the same name. */
1404 || (!check_face_name (&logical_font->elfLogFont,
1405 logical_font->elfFullName)))
1406 return 1;
1408 /* Make a font entity for the font. */
1409 entity = w32_enumfont_pattern_entity (match_data->frame, logical_font,
1410 physical_font, font_type,
1411 &match_data->pattern,
1412 backend);
1414 if (!NILP (entity))
1416 Lisp_Object spec_charset = AREF (match_data->orig_font_spec,
1417 FONT_REGISTRY_INDEX);
1419 /* iso10646-1 fonts must contain unicode mapping tables. */
1420 if (EQ (spec_charset, Qiso10646_1))
1422 if (!is_unicode)
1423 return 1;
1425 /* unicode-bmp fonts must contain characters from the BMP. */
1426 else if (EQ (spec_charset, Qunicode_bmp))
1428 if (!physical_font->ntmFontSig.fsUsb[3]
1429 && !(physical_font->ntmFontSig.fsUsb[2] & 0xFFFFFF9E)
1430 && !(physical_font->ntmFontSig.fsUsb[1] & 0xE81FFFFF)
1431 && !(physical_font->ntmFontSig.fsUsb[0] & 0x007F001F))
1432 return 1;
1434 /* unicode-sip fonts must contain characters in unicode plane 2.
1435 so look for bit 57 (surrogates) in the Unicode subranges, plus
1436 the bits for CJK ranges that include those characters. */
1437 else if (EQ (spec_charset, Qunicode_sip))
1439 if (!physical_font->ntmFontSig.fsUsb[1] & 0x02000000
1440 || !physical_font->ntmFontSig.fsUsb[1] & 0x28000000)
1441 return 1;
1444 /* This font matches. */
1446 /* If registry was specified, ensure it is reported as the same. */
1447 if (!NILP (spec_charset))
1448 ASET (entity, FONT_REGISTRY_INDEX, spec_charset);
1450 /* Otherwise if using the uniscribe backend, report ANSI and DEFAULT
1451 fonts as unicode and skip other charsets. */
1452 else if (match_data->opentype_only)
1454 if (logical_font->elfLogFont.lfCharSet == ANSI_CHARSET
1455 || logical_font->elfLogFont.lfCharSet == DEFAULT_CHARSET)
1456 ASET (entity, FONT_REGISTRY_INDEX, Qiso10646_1);
1457 else
1458 return 1;
1461 /* Add this font to the list. */
1462 match_data->list = Fcons (entity, match_data->list);
1464 return 1;
1467 /* Callback function for EnumFontFamiliesEx.
1468 * Terminates the search once we have a match. */
1469 static int CALLBACK
1470 add_one_font_entity_to_list (ENUMLOGFONTEX *logical_font,
1471 NEWTEXTMETRICEX *physical_font,
1472 DWORD font_type, LPARAM lParam)
1474 struct font_callback_data *match_data
1475 = (struct font_callback_data *) lParam;
1476 add_font_entity_to_list (logical_font, physical_font, font_type, lParam);
1478 /* If we have a font in the list, terminate the search. */
1479 return NILP (match_data->list);
1482 /* Old function to convert from x to w32 charset, from w32fns.c. */
1483 static LONG
1484 x_to_w32_charset (char * lpcs)
1486 Lisp_Object this_entry, w32_charset;
1487 char *charset;
1488 int len = strlen (lpcs);
1490 /* Support "*-#nnn" format for unknown charsets. */
1491 if (strncmp (lpcs, "*-#", 3) == 0)
1492 return atoi (lpcs + 3);
1494 /* All Windows fonts qualify as unicode. */
1495 if (!strncmp (lpcs, "iso10646", 8))
1496 return DEFAULT_CHARSET;
1498 /* Handle wildcards by ignoring them; eg. treat "big5*-*" as "big5". */
1499 charset = alloca (len + 1);
1500 strcpy (charset, lpcs);
1501 lpcs = strchr (charset, '*');
1502 if (lpcs)
1503 *lpcs = '\0';
1505 /* Look through w32-charset-info-alist for the character set.
1506 Format of each entry is
1507 (CHARSET_NAME . (WINDOWS_CHARSET . CODEPAGE)).
1509 this_entry = Fassoc (build_string (charset), Vw32_charset_info_alist);
1511 if (NILP (this_entry))
1513 /* At startup, we want iso8859-1 fonts to come up properly. */
1514 if (xstrcasecmp (charset, "iso8859-1") == 0)
1515 return ANSI_CHARSET;
1516 else
1517 return DEFAULT_CHARSET;
1520 w32_charset = Fcar (Fcdr (this_entry));
1522 /* Translate Lisp symbol to number. */
1523 if (EQ (w32_charset, Qw32_charset_ansi))
1524 return ANSI_CHARSET;
1525 if (EQ (w32_charset, Qw32_charset_symbol))
1526 return SYMBOL_CHARSET;
1527 if (EQ (w32_charset, Qw32_charset_shiftjis))
1528 return SHIFTJIS_CHARSET;
1529 if (EQ (w32_charset, Qw32_charset_hangeul))
1530 return HANGEUL_CHARSET;
1531 if (EQ (w32_charset, Qw32_charset_chinesebig5))
1532 return CHINESEBIG5_CHARSET;
1533 if (EQ (w32_charset, Qw32_charset_gb2312))
1534 return GB2312_CHARSET;
1535 if (EQ (w32_charset, Qw32_charset_oem))
1536 return OEM_CHARSET;
1537 if (EQ (w32_charset, Qw32_charset_johab))
1538 return JOHAB_CHARSET;
1539 if (EQ (w32_charset, Qw32_charset_easteurope))
1540 return EASTEUROPE_CHARSET;
1541 if (EQ (w32_charset, Qw32_charset_turkish))
1542 return TURKISH_CHARSET;
1543 if (EQ (w32_charset, Qw32_charset_baltic))
1544 return BALTIC_CHARSET;
1545 if (EQ (w32_charset, Qw32_charset_russian))
1546 return RUSSIAN_CHARSET;
1547 if (EQ (w32_charset, Qw32_charset_arabic))
1548 return ARABIC_CHARSET;
1549 if (EQ (w32_charset, Qw32_charset_greek))
1550 return GREEK_CHARSET;
1551 if (EQ (w32_charset, Qw32_charset_hebrew))
1552 return HEBREW_CHARSET;
1553 if (EQ (w32_charset, Qw32_charset_vietnamese))
1554 return VIETNAMESE_CHARSET;
1555 if (EQ (w32_charset, Qw32_charset_thai))
1556 return THAI_CHARSET;
1557 if (EQ (w32_charset, Qw32_charset_mac))
1558 return MAC_CHARSET;
1560 return DEFAULT_CHARSET;
1564 /* Convert a Lisp font registry (symbol) to a windows charset. */
1565 static LONG
1566 registry_to_w32_charset (Lisp_Object charset)
1568 if (EQ (charset, Qiso10646_1) || EQ (charset, Qunicode_bmp)
1569 || EQ (charset, Qunicode_sip))
1570 return DEFAULT_CHARSET; /* UNICODE_CHARSET not defined in MingW32 */
1571 else if (EQ (charset, Qiso8859_1))
1572 return ANSI_CHARSET;
1573 else if (SYMBOLP (charset))
1574 return x_to_w32_charset (SDATA (SYMBOL_NAME (charset)));
1575 else
1576 return DEFAULT_CHARSET;
1579 /* Old function to convert from w32 to x charset, from w32fns.c. */
1580 static char *
1581 w32_to_x_charset (int fncharset, char *matching)
1583 static char buf[32];
1584 Lisp_Object charset_type;
1585 int match_len = 0;
1587 if (matching)
1589 /* If fully specified, accept it as it is. Otherwise use a
1590 substring match. */
1591 char *wildcard = strchr (matching, '*');
1592 if (wildcard)
1593 *wildcard = '\0';
1594 else if (strchr (matching, '-'))
1595 return matching;
1597 match_len = strlen (matching);
1600 switch (fncharset)
1602 case ANSI_CHARSET:
1603 /* Handle startup case of w32-charset-info-alist not
1604 being set up yet. */
1605 if (NILP (Vw32_charset_info_alist))
1606 return "iso8859-1";
1607 charset_type = Qw32_charset_ansi;
1608 break;
1609 case DEFAULT_CHARSET:
1610 charset_type = Qw32_charset_default;
1611 break;
1612 case SYMBOL_CHARSET:
1613 charset_type = Qw32_charset_symbol;
1614 break;
1615 case SHIFTJIS_CHARSET:
1616 charset_type = Qw32_charset_shiftjis;
1617 break;
1618 case HANGEUL_CHARSET:
1619 charset_type = Qw32_charset_hangeul;
1620 break;
1621 case GB2312_CHARSET:
1622 charset_type = Qw32_charset_gb2312;
1623 break;
1624 case CHINESEBIG5_CHARSET:
1625 charset_type = Qw32_charset_chinesebig5;
1626 break;
1627 case OEM_CHARSET:
1628 charset_type = Qw32_charset_oem;
1629 break;
1630 case EASTEUROPE_CHARSET:
1631 charset_type = Qw32_charset_easteurope;
1632 break;
1633 case TURKISH_CHARSET:
1634 charset_type = Qw32_charset_turkish;
1635 break;
1636 case BALTIC_CHARSET:
1637 charset_type = Qw32_charset_baltic;
1638 break;
1639 case RUSSIAN_CHARSET:
1640 charset_type = Qw32_charset_russian;
1641 break;
1642 case ARABIC_CHARSET:
1643 charset_type = Qw32_charset_arabic;
1644 break;
1645 case GREEK_CHARSET:
1646 charset_type = Qw32_charset_greek;
1647 break;
1648 case HEBREW_CHARSET:
1649 charset_type = Qw32_charset_hebrew;
1650 break;
1651 case VIETNAMESE_CHARSET:
1652 charset_type = Qw32_charset_vietnamese;
1653 break;
1654 case THAI_CHARSET:
1655 charset_type = Qw32_charset_thai;
1656 break;
1657 case MAC_CHARSET:
1658 charset_type = Qw32_charset_mac;
1659 break;
1660 case JOHAB_CHARSET:
1661 charset_type = Qw32_charset_johab;
1662 break;
1664 default:
1665 /* Encode numerical value of unknown charset. */
1666 sprintf (buf, "*-#%u", fncharset);
1667 return buf;
1671 Lisp_Object rest;
1672 char * best_match = NULL;
1673 int matching_found = 0;
1675 /* Look through w32-charset-info-alist for the character set.
1676 Prefer ISO codepages, and prefer lower numbers in the ISO
1677 range. Only return charsets for codepages which are installed.
1679 Format of each entry is
1680 (CHARSET_NAME . (WINDOWS_CHARSET . CODEPAGE)).
1682 for (rest = Vw32_charset_info_alist; CONSP (rest); rest = XCDR (rest))
1684 char * x_charset;
1685 Lisp_Object w32_charset;
1686 Lisp_Object codepage;
1688 Lisp_Object this_entry = XCAR (rest);
1690 /* Skip invalid entries in alist. */
1691 if (!CONSP (this_entry) || !STRINGP (XCAR (this_entry))
1692 || !CONSP (XCDR (this_entry))
1693 || !SYMBOLP (XCAR (XCDR (this_entry))))
1694 continue;
1696 x_charset = SDATA (XCAR (this_entry));
1697 w32_charset = XCAR (XCDR (this_entry));
1698 codepage = XCDR (XCDR (this_entry));
1700 /* Look for Same charset and a valid codepage (or non-int
1701 which means ignore). */
1702 if (EQ (w32_charset, charset_type)
1703 && (!INTEGERP (codepage) || XINT (codepage) == CP_DEFAULT
1704 || IsValidCodePage (XINT (codepage))))
1706 /* If we don't have a match already, then this is the
1707 best. */
1708 if (!best_match)
1710 best_match = x_charset;
1711 if (matching && !strnicmp (x_charset, matching, match_len))
1712 matching_found = 1;
1714 /* If we already found a match for MATCHING, then
1715 only consider other matches. */
1716 else if (matching_found
1717 && strnicmp (x_charset, matching, match_len))
1718 continue;
1719 /* If this matches what we want, and the best so far doesn't,
1720 then this is better. */
1721 else if (!matching_found && matching
1722 && !strnicmp (x_charset, matching, match_len))
1724 best_match = x_charset;
1725 matching_found = 1;
1727 /* If this is fully specified, and the best so far isn't,
1728 then this is better. */
1729 else if ((!strchr (best_match, '-') && strchr (x_charset, '-'))
1730 /* If this is an ISO codepage, and the best so far isn't,
1731 then this is better, but only if it fully specifies the
1732 encoding. */
1733 || (strnicmp (best_match, "iso", 3) != 0
1734 && strnicmp (x_charset, "iso", 3) == 0
1735 && strchr (x_charset, '-')))
1736 best_match = x_charset;
1737 /* If both are ISO8859 codepages, choose the one with the
1738 lowest number in the encoding field. */
1739 else if (strnicmp (best_match, "iso8859-", 8) == 0
1740 && strnicmp (x_charset, "iso8859-", 8) == 0)
1742 int best_enc = atoi (best_match + 8);
1743 int this_enc = atoi (x_charset + 8);
1744 if (this_enc > 0 && this_enc < best_enc)
1745 best_match = x_charset;
1750 /* If no match, encode the numeric value. */
1751 if (!best_match)
1753 sprintf (buf, "*-#%u", fncharset);
1754 return buf;
1757 strncpy (buf, best_match, 31);
1758 /* If the charset is not fully specified, put -0 on the end. */
1759 if (!strchr (best_match, '-'))
1761 int pos = strlen (best_match);
1762 /* Charset specifiers shouldn't be very long. If it is a made
1763 up one, truncating it should not do any harm since it isn't
1764 recognized anyway. */
1765 if (pos > 29)
1766 pos = 29;
1767 strcpy (buf + pos, "-0");
1769 buf[31] = '\0';
1770 return buf;
1774 static Lisp_Object
1775 w32_registry (LONG w32_charset, DWORD font_type)
1777 char *charset;
1779 /* If charset is defaulted, charset is unicode or unknown, depending on
1780 font type. */
1781 if (w32_charset == DEFAULT_CHARSET)
1782 return font_type == TRUETYPE_FONTTYPE ? Qiso10646_1 : Qunknown;
1784 charset = w32_to_x_charset (w32_charset, NULL);
1785 return font_intern_prop (charset, strlen (charset), 1);
1788 static int
1789 w32_decode_weight (int fnweight)
1791 if (fnweight >= FW_HEAVY) return 210;
1792 if (fnweight >= FW_EXTRABOLD) return 205;
1793 if (fnweight >= FW_BOLD) return 200;
1794 if (fnweight >= FW_SEMIBOLD) return 180;
1795 if (fnweight >= FW_NORMAL) return 100;
1796 if (fnweight >= FW_LIGHT) return 50;
1797 if (fnweight >= FW_EXTRALIGHT) return 40;
1798 if (fnweight > FW_THIN) return 20;
1799 return 0;
1802 static int
1803 w32_encode_weight (int n)
1805 if (n >= 210) return FW_HEAVY;
1806 if (n >= 205) return FW_EXTRABOLD;
1807 if (n >= 200) return FW_BOLD;
1808 if (n >= 180) return FW_SEMIBOLD;
1809 if (n >= 100) return FW_NORMAL;
1810 if (n >= 50) return FW_LIGHT;
1811 if (n >= 40) return FW_EXTRALIGHT;
1812 if (n >= 20) return FW_THIN;
1813 return 0;
1816 /* Convert a Windows font weight into one of the weights supported
1817 by fontconfig (see font.c:font_parse_fcname). */
1818 static Lisp_Object
1819 w32_to_fc_weight (int n)
1821 if (n >= FW_EXTRABOLD) return intern ("black");
1822 if (n >= FW_BOLD) return intern ("bold");
1823 if (n >= FW_SEMIBOLD) return intern ("demibold");
1824 if (n >= FW_NORMAL) return intern ("medium");
1825 return intern ("light");
1828 /* Fill in all the available details of LOGFONT from FONT_SPEC. */
1829 static void
1830 fill_in_logfont (FRAME_PTR f, LOGFONT *logfont, Lisp_Object font_spec)
1832 Lisp_Object tmp, extra;
1833 int dpi = FRAME_W32_DISPLAY_INFO (f)->resy;
1835 tmp = AREF (font_spec, FONT_DPI_INDEX);
1836 if (INTEGERP (tmp))
1838 dpi = XINT (tmp);
1840 else if (FLOATP (tmp))
1842 dpi = (int) (XFLOAT_DATA (tmp) + 0.5);
1845 /* Height */
1846 tmp = AREF (font_spec, FONT_SIZE_INDEX);
1847 if (INTEGERP (tmp))
1848 logfont->lfHeight = -1 * XINT (tmp);
1849 else if (FLOATP (tmp))
1850 logfont->lfHeight = (int) (-1.0 * dpi * XFLOAT_DATA (tmp) / 72.27 + 0.5);
1852 /* Escapement */
1854 /* Orientation */
1856 /* Weight */
1857 tmp = AREF (font_spec, FONT_WEIGHT_INDEX);
1858 if (INTEGERP (tmp))
1859 logfont->lfWeight = w32_encode_weight (FONT_WEIGHT_NUMERIC (font_spec));
1861 /* Italic */
1862 tmp = AREF (font_spec, FONT_SLANT_INDEX);
1863 if (INTEGERP (tmp))
1865 int slant = FONT_SLANT_NUMERIC (font_spec);
1866 logfont->lfItalic = slant > 150 ? 1 : 0;
1869 /* Underline */
1871 /* Strikeout */
1873 /* Charset */
1874 tmp = AREF (font_spec, FONT_REGISTRY_INDEX);
1875 if (! NILP (tmp))
1876 logfont->lfCharSet = registry_to_w32_charset (tmp);
1877 else
1878 logfont->lfCharSet = DEFAULT_CHARSET;
1880 /* Out Precision */
1882 /* Clip Precision */
1884 /* Quality */
1885 logfont->lfQuality = DEFAULT_QUALITY;
1887 /* Generic Family and Face Name */
1888 logfont->lfPitchAndFamily = FF_DONTCARE | DEFAULT_PITCH;
1890 tmp = AREF (font_spec, FONT_FAMILY_INDEX);
1891 if (! NILP (tmp))
1893 logfont->lfPitchAndFamily = w32_generic_family (tmp) | DEFAULT_PITCH;
1894 if ((logfont->lfPitchAndFamily & 0xF0) != FF_DONTCARE)
1895 ; /* Font name was generic, don't fill in font name. */
1896 /* Font families are interned, but allow for strings also in case of
1897 user input. */
1898 else if (SYMBOLP (tmp))
1899 strncpy (logfont->lfFaceName,
1900 SDATA (ENCODE_SYSTEM (SYMBOL_NAME (tmp))), LF_FACESIZE);
1903 tmp = AREF (font_spec, FONT_ADSTYLE_INDEX);
1904 if (!NILP (tmp))
1906 /* Override generic family. */
1907 BYTE family = w32_generic_family (tmp);
1908 if (family != FF_DONTCARE)
1909 logfont->lfPitchAndFamily = family | DEFAULT_PITCH;
1912 /* Set pitch based on the spacing property. */
1913 tmp = AREF (font_spec, FONT_SPACING_INDEX);
1914 if (INTEGERP (tmp))
1916 int spacing = XINT (tmp);
1917 if (spacing < FONT_SPACING_MONO)
1918 logfont->lfPitchAndFamily
1919 = logfont->lfPitchAndFamily & 0xF0 | VARIABLE_PITCH;
1920 else
1921 logfont->lfPitchAndFamily
1922 = logfont->lfPitchAndFamily & 0xF0 | FIXED_PITCH;
1925 /* Process EXTRA info. */
1926 for (extra = AREF (font_spec, FONT_EXTRA_INDEX);
1927 CONSP (extra); extra = XCDR (extra))
1929 tmp = XCAR (extra);
1930 if (CONSP (tmp))
1932 Lisp_Object key, val;
1933 key = XCAR (tmp), val = XCDR (tmp);
1934 /* Only use QCscript if charset is not provided, or is unicode
1935 and a single script is specified. This is rather crude,
1936 and is only used to narrow down the fonts returned where
1937 there is a definite match. Some scripts, such as latin, han,
1938 cjk-misc match multiple lfCharSet values, so we can't pre-filter
1939 them. */
1940 if (EQ (key, QCscript)
1941 && logfont->lfCharSet == DEFAULT_CHARSET
1942 && SYMBOLP (val))
1944 if (EQ (val, Qgreek))
1945 logfont->lfCharSet = GREEK_CHARSET;
1946 else if (EQ (val, Qhangul))
1947 logfont->lfCharSet = HANGUL_CHARSET;
1948 else if (EQ (val, Qkana) || EQ (val, Qkanbun))
1949 logfont->lfCharSet = SHIFTJIS_CHARSET;
1950 else if (EQ (val, Qbopomofo))
1951 logfont->lfCharSet = CHINESEBIG5_CHARSET;
1952 /* GB 18030 supports tibetan, yi, mongolian,
1953 fonts that support it should show up if we ask for
1954 GB2312 fonts. */
1955 else if (EQ (val, Qtibetan) || EQ (val, Qyi)
1956 || EQ (val, Qmongolian))
1957 logfont->lfCharSet = GB2312_CHARSET;
1958 else if (EQ (val, Qhebrew))
1959 logfont->lfCharSet = HEBREW_CHARSET;
1960 else if (EQ (val, Qarabic))
1961 logfont->lfCharSet = ARABIC_CHARSET;
1962 else if (EQ (val, Qthai))
1963 logfont->lfCharSet = THAI_CHARSET;
1965 else if (EQ (key, QCantialias) && SYMBOLP (val))
1967 logfont->lfQuality = w32_antialias_type (val);
1973 static void
1974 list_all_matching_fonts (struct font_callback_data *match_data)
1976 HDC dc;
1977 Lisp_Object families = w32font_list_family (match_data->frame);
1978 struct frame *f = XFRAME (match_data->frame);
1980 dc = get_frame_dc (f);
1982 while (!NILP (families))
1984 /* Only fonts from the current locale are given localized names
1985 on Windows, so we can keep backwards compatibility with
1986 Windows 9x/ME by using non-Unicode font enumeration without
1987 sacrificing internationalization here. */
1988 char *name;
1989 Lisp_Object family = CAR (families);
1990 families = CDR (families);
1991 if (NILP (family))
1992 continue;
1993 else if (SYMBOLP (family))
1994 name = SDATA (ENCODE_SYSTEM (SYMBOL_NAME (family)));
1995 else
1996 continue;
1998 strncpy (match_data->pattern.lfFaceName, name, LF_FACESIZE);
1999 match_data->pattern.lfFaceName[LF_FACESIZE - 1] = '\0';
2001 EnumFontFamiliesEx (dc, &match_data->pattern,
2002 (FONTENUMPROC) add_font_entity_to_list,
2003 (LPARAM) match_data, 0);
2006 release_frame_dc (f, dc);
2009 static Lisp_Object
2010 lispy_antialias_type (BYTE type)
2012 Lisp_Object lispy;
2014 switch (type)
2016 case NONANTIALIASED_QUALITY:
2017 lispy = Qnone;
2018 break;
2019 case ANTIALIASED_QUALITY:
2020 lispy = Qstandard;
2021 break;
2022 case CLEARTYPE_QUALITY:
2023 lispy = Qsubpixel;
2024 break;
2025 case CLEARTYPE_NATURAL_QUALITY:
2026 lispy = Qnatural;
2027 break;
2028 default:
2029 lispy = Qnil;
2030 break;
2032 return lispy;
2035 /* Convert antialiasing symbols to lfQuality */
2036 static BYTE
2037 w32_antialias_type (Lisp_Object type)
2039 if (EQ (type, Qnone))
2040 return NONANTIALIASED_QUALITY;
2041 else if (EQ (type, Qstandard))
2042 return ANTIALIASED_QUALITY;
2043 else if (EQ (type, Qsubpixel))
2044 return CLEARTYPE_QUALITY;
2045 else if (EQ (type, Qnatural))
2046 return CLEARTYPE_NATURAL_QUALITY;
2047 else
2048 return DEFAULT_QUALITY;
2051 /* Return a list of all the scripts that the font supports. */
2052 static Lisp_Object
2053 font_supported_scripts (FONTSIGNATURE * sig)
2055 DWORD * subranges = sig->fsUsb;
2056 Lisp_Object supported = Qnil;
2058 /* Match a single subrange. SYM is set if bit N is set in subranges. */
2059 #define SUBRANGE(n,sym) \
2060 if (subranges[(n) / 32] & (1 << ((n) % 32))) \
2061 supported = Fcons ((sym), supported)
2063 /* Match multiple subranges. SYM is set if any MASK bit is set in
2064 subranges[0 - 3]. */
2065 #define MASK_ANY(mask0,mask1,mask2,mask3,sym) \
2066 if ((subranges[0] & (mask0)) || (subranges[1] & (mask1)) \
2067 || (subranges[2] & (mask2)) || (subranges[3] & (mask3))) \
2068 supported = Fcons ((sym), supported)
2070 SUBRANGE (0, Qlatin);
2071 /* The following count as latin too, ASCII should be present in these fonts,
2072 so don't need to mark them separately. */
2073 /* 1: Latin-1 supplement, 2: Latin Extended A, 3: Latin Extended B. */
2074 SUBRANGE (4, Qphonetic);
2075 /* 5: Spacing and tone modifiers, 6: Combining Diacriticals. */
2076 SUBRANGE (7, Qgreek);
2077 SUBRANGE (8, Qcoptic);
2078 SUBRANGE (9, Qcyrillic);
2079 SUBRANGE (10, Qarmenian);
2080 SUBRANGE (11, Qhebrew);
2081 /* 12: Vai. */
2082 SUBRANGE (13, Qarabic);
2083 SUBRANGE (14, Qnko);
2084 SUBRANGE (15, Qdevanagari);
2085 SUBRANGE (16, Qbengali);
2086 SUBRANGE (17, Qgurmukhi);
2087 SUBRANGE (18, Qgujarati);
2088 SUBRANGE (19, Qoriya);
2089 SUBRANGE (20, Qtamil);
2090 SUBRANGE (21, Qtelugu);
2091 SUBRANGE (22, Qkannada);
2092 SUBRANGE (23, Qmalayalam);
2093 SUBRANGE (24, Qthai);
2094 SUBRANGE (25, Qlao);
2095 SUBRANGE (26, Qgeorgian);
2096 SUBRANGE (27, Qbalinese);
2097 /* 28: Hangul Jamo. */
2098 /* 29: Latin Extended, 30: Greek Extended, 31: Punctuation. */
2099 /* 32-47: Symbols (defined below). */
2100 SUBRANGE (48, Qcjk_misc);
2101 /* Match either 49: katakana or 50: hiragana for kana. */
2102 MASK_ANY (0, 0x00060000, 0, 0, Qkana);
2103 SUBRANGE (51, Qbopomofo);
2104 /* 52: Compatibility Jamo */
2105 SUBRANGE (53, Qphags_pa);
2106 /* 54: Enclosed CJK letters and months, 55: CJK Compatibility. */
2107 SUBRANGE (56, Qhangul);
2108 /* 57: Surrogates. */
2109 SUBRANGE (58, Qphoenician);
2110 SUBRANGE (59, Qhan); /* There are others, but this is the main one. */
2111 SUBRANGE (59, Qideographic_description); /* Windows lumps this in. */
2112 SUBRANGE (59, Qkanbun); /* And this. */
2113 /* 60: Private use, 61: CJK strokes and compatibility. */
2114 /* 62: Alphabetic Presentation, 63: Arabic Presentation A. */
2115 /* 64: Combining half marks, 65: Vertical and CJK compatibility. */
2116 /* 66: Small forms, 67: Arabic Presentation B, 68: Half and Full width. */
2117 /* 69: Specials. */
2118 SUBRANGE (70, Qtibetan);
2119 SUBRANGE (71, Qsyriac);
2120 SUBRANGE (72, Qthaana);
2121 SUBRANGE (73, Qsinhala);
2122 SUBRANGE (74, Qmyanmar);
2123 SUBRANGE (75, Qethiopic);
2124 SUBRANGE (76, Qcherokee);
2125 SUBRANGE (77, Qcanadian_aboriginal);
2126 SUBRANGE (78, Qogham);
2127 SUBRANGE (79, Qrunic);
2128 SUBRANGE (80, Qkhmer);
2129 SUBRANGE (81, Qmongolian);
2130 SUBRANGE (82, Qbraille);
2131 SUBRANGE (83, Qyi);
2132 SUBRANGE (84, Qbuhid);
2133 SUBRANGE (84, Qhanunoo);
2134 SUBRANGE (84, Qtagalog);
2135 SUBRANGE (84, Qtagbanwa);
2136 SUBRANGE (85, Qold_italic);
2137 SUBRANGE (86, Qgothic);
2138 SUBRANGE (87, Qdeseret);
2139 SUBRANGE (88, Qbyzantine_musical_symbol);
2140 SUBRANGE (88, Qmusical_symbol); /* Windows doesn't distinguish these. */
2141 SUBRANGE (89, Qmathematical);
2142 /* 90: Private use, 91: Variation selectors, 92: Tags. */
2143 SUBRANGE (93, Qlimbu);
2144 SUBRANGE (94, Qtai_le);
2145 /* 95: New Tai Le */
2146 SUBRANGE (90, Qbuginese);
2147 SUBRANGE (97, Qglagolitic);
2148 SUBRANGE (98, Qtifinagh);
2149 /* 99: Yijing Hexagrams. */
2150 SUBRANGE (100, Qsyloti_nagri);
2151 SUBRANGE (101, Qlinear_b);
2152 /* 102: Ancient Greek Numbers. */
2153 SUBRANGE (103, Qugaritic);
2154 SUBRANGE (104, Qold_persian);
2155 SUBRANGE (105, Qshavian);
2156 SUBRANGE (106, Qosmanya);
2157 SUBRANGE (107, Qcypriot);
2158 SUBRANGE (108, Qkharoshthi);
2159 /* 109: Tai Xuan Jing. */
2160 SUBRANGE (110, Qcuneiform);
2161 /* 111: Counting Rods, 112: Sundanese, 113: Lepcha, 114: Ol Chiki. */
2162 /* 115: Saurashtra, 116: Kayah Li, 117: Rejang. */
2163 SUBRANGE (118, Qcham);
2164 /* 119: Ancient symbols, 120: Phaistos Disc. */
2165 /* 121: Carian, Lycian, Lydian, 122: Dominos, Mah Jong tiles. */
2166 /* 123-127: Reserved. */
2168 /* There isn't really a main symbol range, so include symbol if any
2169 relevant range is set. */
2170 MASK_ANY (0x8000000, 0x0000FFFF, 0, 0, Qsymbol);
2172 /* Missing: Tai Viet (U+AA80-U+AADF). */
2173 #undef SUBRANGE
2174 #undef MASK_ANY
2176 return supported;
2179 /* Generate a full name for a Windows font.
2180 The full name is in fcname format, with weight, slant and antialiasing
2181 specified if they are not "normal". */
2182 static int
2183 w32font_full_name (LOGFONT * font, Lisp_Object font_obj,
2184 int pixel_size, char *name, int nbytes)
2186 int len, height, outline;
2187 char *p;
2188 Lisp_Object antialiasing, weight = Qnil;
2190 len = strlen (font->lfFaceName);
2192 outline = EQ (AREF (font_obj, FONT_FOUNDRY_INDEX), Qoutline);
2194 /* Represent size of scalable fonts by point size. But use pixelsize for
2195 raster fonts to indicate that they are exactly that size. */
2196 if (outline)
2197 len += 11; /* -SIZE */
2198 else
2199 len += 21;
2201 if (font->lfItalic)
2202 len += 7; /* :italic */
2204 if (font->lfWeight && font->lfWeight != FW_NORMAL)
2206 weight = w32_to_fc_weight (font->lfWeight);
2207 len += 1 + SBYTES (SYMBOL_NAME (weight)); /* :WEIGHT */
2210 antialiasing = lispy_antialias_type (font->lfQuality);
2211 if (! NILP (antialiasing))
2212 len += 11 + SBYTES (SYMBOL_NAME (antialiasing)); /* :antialias=NAME */
2214 /* Check that the buffer is big enough */
2215 if (len > nbytes)
2216 return -1;
2218 p = name;
2219 p += sprintf (p, "%s", font->lfFaceName);
2221 height = font->lfHeight ? eabs (font->lfHeight) : pixel_size;
2223 if (height > 0)
2225 if (outline)
2227 float pointsize = height * 72.0 / one_w32_display_info.resy;
2228 /* Round to nearest half point. floor is used, since round is not
2229 supported in MS library. */
2230 pointsize = floor (pointsize * 2 + 0.5) / 2;
2231 p += sprintf (p, "-%1.1f", pointsize);
2233 else
2234 p += sprintf (p, ":pixelsize=%d", height);
2237 if (SYMBOLP (weight) && ! NILP (weight))
2238 p += sprintf (p, ":%s", SDATA (SYMBOL_NAME (weight)));
2240 if (font->lfItalic)
2241 p += sprintf (p, ":italic");
2243 if (SYMBOLP (antialiasing) && ! NILP (antialiasing))
2244 p += sprintf (p, ":antialias=%s", SDATA (SYMBOL_NAME (antialiasing)));
2246 return (p - name);
2249 /* Convert a logfont and point size into a fontconfig style font name.
2250 POINTSIZE is in tenths of points.
2251 If SIZE indicates the size of buffer FCNAME, into which the font name
2252 is written. If the buffer is not large enough to contain the name,
2253 the function returns -1, otherwise it returns the number of bytes
2254 written to FCNAME. */
2255 static int
2256 logfont_to_fcname (LOGFONT* font, int pointsize, char *fcname, int size)
2258 int len, height;
2259 char *p = fcname;
2260 Lisp_Object weight = Qnil;
2262 len = strlen (font->lfFaceName) + 2;
2263 height = pointsize / 10;
2264 while (height /= 10)
2265 len++;
2267 if (pointsize % 10)
2268 len += 2;
2270 if (font->lfItalic)
2271 len += 7; /* :italic */
2272 if (font->lfWeight && font->lfWeight != FW_NORMAL)
2274 weight = w32_to_fc_weight (font->lfWeight);
2275 len += SBYTES (SYMBOL_NAME (weight)) + 1;
2278 if (len > size)
2279 return -1;
2281 p += sprintf (p, "%s-%d", font->lfFaceName, pointsize / 10);
2282 if (pointsize % 10)
2283 p += sprintf (p, ".%d", pointsize % 10);
2285 if (SYMBOLP (weight) && !NILP (weight))
2286 p += sprintf (p, ":%s", SDATA (SYMBOL_NAME (weight)));
2288 if (font->lfItalic)
2289 p += sprintf (p, ":italic");
2291 return (p - fcname);
2294 static void
2295 compute_metrics (HDC dc, struct w32font_info *w32_font, unsigned int code,
2296 struct w32_metric_cache *metrics)
2298 GLYPHMETRICS gm;
2299 MAT2 transform;
2300 unsigned int options = GGO_METRICS;
2302 if (w32_font->glyph_idx)
2303 options |= GGO_GLYPH_INDEX;
2305 memset (&transform, 0, sizeof (transform));
2306 transform.eM11.value = 1;
2307 transform.eM22.value = 1;
2309 if (GetGlyphOutlineW (dc, code, options, &gm, 0, NULL, &transform)
2310 != GDI_ERROR)
2312 metrics->lbearing = gm.gmptGlyphOrigin.x;
2313 metrics->rbearing = gm.gmptGlyphOrigin.x + gm.gmBlackBoxX;
2314 metrics->width = gm.gmCellIncX;
2315 metrics->status = W32METRIC_SUCCESS;
2317 else
2318 metrics->status = W32METRIC_FAIL;
2321 DEFUN ("x-select-font", Fx_select_font, Sx_select_font, 0, 2, 0,
2322 doc: /* Read a font name using a W32 font selection dialog.
2323 Return fontconfig style font string corresponding to the selection.
2325 If FRAME is omitted or nil, it defaults to the selected frame.
2326 If EXCLUDE-PROPORTIONAL is non-nil, exclude proportional fonts
2327 in the font selection dialog. */)
2328 (Lisp_Object frame, Lisp_Object exclude_proportional)
2330 FRAME_PTR f = check_x_frame (frame);
2331 CHOOSEFONT cf;
2332 LOGFONT lf;
2333 TEXTMETRIC tm;
2334 HDC hdc;
2335 HANDLE oldobj;
2336 char buf[100];
2338 memset (&cf, 0, sizeof (cf));
2339 memset (&lf, 0, sizeof (lf));
2341 cf.lStructSize = sizeof (cf);
2342 cf.hwndOwner = FRAME_W32_WINDOW (f);
2343 cf.Flags = CF_FORCEFONTEXIST | CF_SCREENFONTS | CF_NOVERTFONTS;
2345 /* If exclude_proportional is non-nil, limit the selection to
2346 monospaced fonts. */
2347 if (!NILP (exclude_proportional))
2348 cf.Flags |= CF_FIXEDPITCHONLY;
2350 cf.lpLogFont = &lf;
2352 /* Initialize as much of the font details as we can from the current
2353 default font. */
2354 hdc = GetDC (FRAME_W32_WINDOW (f));
2355 oldobj = SelectObject (hdc, FONT_HANDLE (FRAME_FONT (f)));
2356 GetTextFace (hdc, LF_FACESIZE, lf.lfFaceName);
2357 if (GetTextMetrics (hdc, &tm))
2359 lf.lfHeight = tm.tmInternalLeading - tm.tmHeight;
2360 lf.lfWeight = tm.tmWeight;
2361 lf.lfItalic = tm.tmItalic;
2362 lf.lfUnderline = tm.tmUnderlined;
2363 lf.lfStrikeOut = tm.tmStruckOut;
2364 lf.lfCharSet = tm.tmCharSet;
2365 cf.Flags |= CF_INITTOLOGFONTSTRUCT;
2367 SelectObject (hdc, oldobj);
2368 ReleaseDC (FRAME_W32_WINDOW (f), hdc);
2370 if (!ChooseFont (&cf)
2371 || logfont_to_fcname (&lf, cf.iPointSize, buf, 100) < 0)
2372 return Qnil;
2374 return DECODE_SYSTEM (build_string (buf));
2377 static const char *const w32font_booleans [] = {
2378 NULL,
2381 static const char *const w32font_non_booleans [] = {
2382 ":script",
2383 ":antialias",
2384 ":style",
2385 NULL,
2388 static void
2389 w32font_filter_properties (Lisp_Object font, Lisp_Object alist)
2391 font_filter_properties (font, alist, w32font_booleans, w32font_non_booleans);
2394 struct font_driver w32font_driver =
2396 0, /* Qgdi */
2397 0, /* case insensitive */
2398 w32font_get_cache,
2399 w32font_list,
2400 w32font_match,
2401 w32font_list_family,
2402 NULL, /* free_entity */
2403 w32font_open,
2404 w32font_close,
2405 NULL, /* prepare_face */
2406 NULL, /* done_face */
2407 w32font_has_char,
2408 w32font_encode_char,
2409 w32font_text_extents,
2410 w32font_draw,
2411 NULL, /* get_bitmap */
2412 NULL, /* free_bitmap */
2413 NULL, /* get_outline */
2414 NULL, /* free_outline */
2415 NULL, /* anchor_point */
2416 NULL, /* otf_capability */
2417 NULL, /* otf_drive */
2418 NULL, /* start_for_frame */
2419 NULL, /* end_for_frame */
2420 NULL, /* shape */
2421 NULL, /* check */
2422 NULL, /* get_variation_glyphs */
2423 w32font_filter_properties,
2424 NULL, /* cached_font_ok */
2428 /* Initialize state that does not change between invocations. This is only
2429 called when Emacs is dumped. */
2430 void
2431 syms_of_w32font (void)
2433 DEFSYM (Qgdi, "gdi");
2434 DEFSYM (Quniscribe, "uniscribe");
2435 DEFSYM (QCformat, ":format");
2437 /* Generic font families. */
2438 DEFSYM (Qmonospace, "monospace");
2439 DEFSYM (Qserif, "serif");
2440 DEFSYM (Qsansserif, "sansserif");
2441 DEFSYM (Qscript, "script");
2442 DEFSYM (Qdecorative, "decorative");
2443 /* Aliases. */
2444 DEFSYM (Qsans_serif, "sans_serif");
2445 DEFSYM (Qsans, "sans");
2446 DEFSYM (Qmono, "mono");
2448 /* Fake foundries. */
2449 DEFSYM (Qraster, "raster");
2450 DEFSYM (Qoutline, "outline");
2451 DEFSYM (Qunknown, "unknown");
2453 /* Antialiasing. */
2454 DEFSYM (Qstandard, "standard");
2455 DEFSYM (Qsubpixel, "subpixel");
2456 DEFSYM (Qnatural, "natural");
2458 /* Languages */
2459 DEFSYM (Qzh, "zh");
2461 /* Scripts */
2462 DEFSYM (Qlatin, "latin");
2463 DEFSYM (Qgreek, "greek");
2464 DEFSYM (Qcoptic, "coptic");
2465 DEFSYM (Qcyrillic, "cyrillic");
2466 DEFSYM (Qarmenian, "armenian");
2467 DEFSYM (Qhebrew, "hebrew");
2468 DEFSYM (Qarabic, "arabic");
2469 DEFSYM (Qsyriac, "syriac");
2470 DEFSYM (Qnko, "nko");
2471 DEFSYM (Qthaana, "thaana");
2472 DEFSYM (Qdevanagari, "devanagari");
2473 DEFSYM (Qbengali, "bengali");
2474 DEFSYM (Qgurmukhi, "gurmukhi");
2475 DEFSYM (Qgujarati, "gujarati");
2476 DEFSYM (Qoriya, "oriya");
2477 DEFSYM (Qtamil, "tamil");
2478 DEFSYM (Qtelugu, "telugu");
2479 DEFSYM (Qkannada, "kannada");
2480 DEFSYM (Qmalayalam, "malayalam");
2481 DEFSYM (Qsinhala, "sinhala");
2482 DEFSYM (Qthai, "thai");
2483 DEFSYM (Qlao, "lao");
2484 DEFSYM (Qtibetan, "tibetan");
2485 DEFSYM (Qmyanmar, "myanmar");
2486 DEFSYM (Qgeorgian, "georgian");
2487 DEFSYM (Qhangul, "hangul");
2488 DEFSYM (Qethiopic, "ethiopic");
2489 DEFSYM (Qcherokee, "cherokee");
2490 DEFSYM (Qcanadian_aboriginal, "canadian-aboriginal");
2491 DEFSYM (Qogham, "ogham");
2492 DEFSYM (Qrunic, "runic");
2493 DEFSYM (Qkhmer, "khmer");
2494 DEFSYM (Qmongolian, "mongolian");
2495 DEFSYM (Qsymbol, "symbol");
2496 DEFSYM (Qbraille, "braille");
2497 DEFSYM (Qhan, "han");
2498 DEFSYM (Qideographic_description, "ideographic-description");
2499 DEFSYM (Qcjk_misc, "cjk-misc");
2500 DEFSYM (Qkana, "kana");
2501 DEFSYM (Qbopomofo, "bopomofo");
2502 DEFSYM (Qkanbun, "kanbun");
2503 DEFSYM (Qyi, "yi");
2504 DEFSYM (Qbyzantine_musical_symbol, "byzantine-musical-symbol");
2505 DEFSYM (Qmusical_symbol, "musical-symbol");
2506 DEFSYM (Qmathematical, "mathematical");
2507 DEFSYM (Qcham, "cham");
2508 DEFSYM (Qphonetic, "phonetic");
2509 DEFSYM (Qbalinese, "balinese");
2510 DEFSYM (Qbuginese, "buginese");
2511 DEFSYM (Qbuhid, "buhid");
2512 DEFSYM (Qcuneiform, "cuneiform");
2513 DEFSYM (Qcypriot, "cypriot");
2514 DEFSYM (Qdeseret, "deseret");
2515 DEFSYM (Qglagolitic, "glagolitic");
2516 DEFSYM (Qgothic, "gothic");
2517 DEFSYM (Qhanunoo, "hanunoo");
2518 DEFSYM (Qkharoshthi, "kharoshthi");
2519 DEFSYM (Qlimbu, "limbu");
2520 DEFSYM (Qlinear_b, "linear_b");
2521 DEFSYM (Qold_italic, "old_italic");
2522 DEFSYM (Qold_persian, "old_persian");
2523 DEFSYM (Qosmanya, "osmanya");
2524 DEFSYM (Qphags_pa, "phags-pa");
2525 DEFSYM (Qphoenician, "phoenician");
2526 DEFSYM (Qshavian, "shavian");
2527 DEFSYM (Qsyloti_nagri, "syloti_nagri");
2528 DEFSYM (Qtagalog, "tagalog");
2529 DEFSYM (Qtagbanwa, "tagbanwa");
2530 DEFSYM (Qtai_le, "tai_le");
2531 DEFSYM (Qtifinagh, "tifinagh");
2532 DEFSYM (Qugaritic, "ugaritic");
2534 /* W32 font encodings. */
2535 DEFVAR_LISP ("w32-charset-info-alist",
2536 Vw32_charset_info_alist,
2537 doc: /* Alist linking Emacs character sets to Windows fonts and codepages.
2538 Each entry should be of the form:
2540 (CHARSET_NAME . (WINDOWS_CHARSET . CODEPAGE))
2542 where CHARSET_NAME is a string used in font names to identify the charset,
2543 WINDOWS_CHARSET is a symbol that can be one of:
2545 w32-charset-ansi, w32-charset-default, w32-charset-symbol,
2546 w32-charset-shiftjis, w32-charset-hangeul, w32-charset-gb2312,
2547 w32-charset-chinesebig5, w32-charset-johab, w32-charset-hebrew,
2548 w32-charset-arabic, w32-charset-greek, w32-charset-turkish,
2549 w32-charset-vietnamese, w32-charset-thai, w32-charset-easteurope,
2550 w32-charset-russian, w32-charset-mac, w32-charset-baltic,
2551 or w32-charset-oem.
2553 CODEPAGE should be an integer specifying the codepage that should be used
2554 to display the character set, t to do no translation and output as Unicode,
2555 or nil to do no translation and output as 8 bit (or multibyte on far-east
2556 versions of Windows) characters. */);
2557 Vw32_charset_info_alist = Qnil;
2559 DEFSYM (Qw32_charset_ansi, "w32-charset-ansi");
2560 DEFSYM (Qw32_charset_symbol, "w32-charset-symbol");
2561 DEFSYM (Qw32_charset_default, "w32-charset-default");
2562 DEFSYM (Qw32_charset_shiftjis, "w32-charset-shiftjis");
2563 DEFSYM (Qw32_charset_hangeul, "w32-charset-hangeul");
2564 DEFSYM (Qw32_charset_chinesebig5, "w32-charset-chinesebig5");
2565 DEFSYM (Qw32_charset_gb2312, "w32-charset-gb2312");
2566 DEFSYM (Qw32_charset_oem, "w32-charset-oem");
2567 DEFSYM (Qw32_charset_johab, "w32-charset-johab");
2568 DEFSYM (Qw32_charset_easteurope, "w32-charset-easteurope");
2569 DEFSYM (Qw32_charset_turkish, "w32-charset-turkish");
2570 DEFSYM (Qw32_charset_baltic, "w32-charset-baltic");
2571 DEFSYM (Qw32_charset_russian, "w32-charset-russian");
2572 DEFSYM (Qw32_charset_arabic, "w32-charset-arabic");
2573 DEFSYM (Qw32_charset_greek, "w32-charset-greek");
2574 DEFSYM (Qw32_charset_hebrew, "w32-charset-hebrew");
2575 DEFSYM (Qw32_charset_vietnamese, "w32-charset-vietnamese");
2576 DEFSYM (Qw32_charset_thai, "w32-charset-thai");
2577 DEFSYM (Qw32_charset_mac, "w32-charset-mac");
2579 defsubr (&Sx_select_font);
2581 w32font_driver.type = Qgdi;
2582 register_font_driver (&w32font_driver, NULL);