From: Kenichi Handa Date: Fri, 20 Jun 2008 12:28:22 +0000 (+0000) Subject: (xftfont_open): Add FOUNDRY, SPACING, DPI, SCALABLE to the pattern. X-Git-Tag: emacs-pretest-23.0.90~4657 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=dc2226d0dc1c685f5d9bcd949ea3d2584651eb57;p=emacs.git (xftfont_open): Add FOUNDRY, SPACING, DPI, SCALABLE to the pattern. --- diff --git a/src/ChangeLog b/src/ChangeLog index f005d1bf702..52e8901ff87 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,5 +1,8 @@ 2008-06-20 Kenichi Handa + * xftfont.c (xftfont_open): Add FOUNDRY, SPACING, DPI, SCALABLE to + the pattern. + * fontset.c (fontset_from_font): Copy font_spec before changing the elements. diff --git a/src/xftfont.c b/src/xftfont.c index 7d5bf245cb6..aa6c270e647 100644 --- a/src/xftfont.c +++ b/src/xftfont.c @@ -219,6 +219,23 @@ xftfont_open (f, entity, pixel_size) val = AREF (entity, FONT_FAMILY_INDEX); if (! NILP (val)) FcPatternAddString (pat, FC_FAMILY, (FcChar8 *) SDATA (SYMBOL_NAME (val))); + val = AREF (entity, FONT_FOUNDRY_INDEX); + if (! NILP (val)) + FcPatternAddString (pat, FC_FOUNDRY, (FcChar8 *) SDATA (SYMBOL_NAME (val))); + val = AREF (entity, FONT_SPACING_INDEX); + if (! NILP (val)) + FcPatternAddInteger (pat, FC_SPACING, XINT (val)); + val = AREF (entity, FONT_DPI_INDEX); + if (! NILP (val)) + { + double dbl = XINT (val); + + FcPatternAddDouble (pat, FC_DPI, dbl); + } + val = AREF (entity, FONT_AVGWIDTH_INDEX); + if (INTEGERP (val) && XINT (val) == 0) + FcPatternAddBool (pat, FC_SCALABLE, FcTrue); + for (tail = AREF (entity, FONT_EXTRA_INDEX); CONSP (tail); tail = XCDR (tail)) { Lisp_Object key, val;