diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/composite.c | 18 | ||||
| -rw-r--r-- | src/font.c | 4 | ||||
| -rw-r--r-- | src/font.h | 2 |
3 files changed, 16 insertions, 8 deletions
diff --git a/src/composite.c b/src/composite.c index 53e6930b5f2..364d5c9316e 100644 --- a/src/composite.c +++ b/src/composite.c | |||
| @@ -818,6 +818,11 @@ fill_gstring_body (Lisp_Object gstring) | |||
| 818 | Lisp_Object header = AREF (gstring, 0); | 818 | Lisp_Object header = AREF (gstring, 0); |
| 819 | ptrdiff_t len = LGSTRING_CHAR_LEN (gstring); | 819 | ptrdiff_t len = LGSTRING_CHAR_LEN (gstring); |
| 820 | ptrdiff_t i; | 820 | ptrdiff_t i; |
| 821 | struct font *font = NULL; | ||
| 822 | unsigned int code; | ||
| 823 | |||
| 824 | if (FONT_OBJECT_P (font_object)) | ||
| 825 | font = XFONT_OBJECT (font_object); | ||
| 821 | 826 | ||
| 822 | for (i = 0; i < len; i++) | 827 | for (i = 0; i < len; i++) |
| 823 | { | 828 | { |
| @@ -832,10 +837,15 @@ fill_gstring_body (Lisp_Object gstring) | |||
| 832 | LGLYPH_SET_FROM (g, i); | 837 | LGLYPH_SET_FROM (g, i); |
| 833 | LGLYPH_SET_TO (g, i); | 838 | LGLYPH_SET_TO (g, i); |
| 834 | LGLYPH_SET_CHAR (g, c); | 839 | LGLYPH_SET_CHAR (g, c); |
| 835 | if (FONT_OBJECT_P (font_object)) | 840 | |
| 836 | { | 841 | if (font != NULL) |
| 837 | font_fill_lglyph_metrics (g, font_object); | 842 | code = font->driver->encode_char (font, LGLYPH_CHAR (g)); |
| 838 | } | 843 | else |
| 844 | code = FONT_INVALID_CODE; | ||
| 845 | if (code != FONT_INVALID_CODE) | ||
| 846 | { | ||
| 847 | font_fill_lglyph_metrics (g, font, code); | ||
| 848 | } | ||
| 839 | else | 849 | else |
| 840 | { | 850 | { |
| 841 | int width = XFIXNAT (CHAR_TABLE_REF (Vchar_width_table, c)); | 851 | int width = XFIXNAT (CHAR_TABLE_REF (Vchar_width_table, c)); |
diff --git a/src/font.c b/src/font.c index 2b90903c909..39ec1b3562a 100644 --- a/src/font.c +++ b/src/font.c | |||
| @@ -4416,10 +4416,8 @@ DEFUN ("clear-font-cache", Fclear_font_cache, Sclear_font_cache, 0, 0, 0, | |||
| 4416 | 4416 | ||
| 4417 | 4417 | ||
| 4418 | void | 4418 | void |
| 4419 | font_fill_lglyph_metrics (Lisp_Object glyph, Lisp_Object font_object) | 4419 | font_fill_lglyph_metrics (Lisp_Object glyph, struct font *font, unsigned int code) |
| 4420 | { | 4420 | { |
| 4421 | struct font *font = XFONT_OBJECT (font_object); | ||
| 4422 | unsigned code = font->driver->encode_char (font, LGLYPH_CHAR (glyph)); | ||
| 4423 | struct font_metrics metrics; | 4421 | struct font_metrics metrics; |
| 4424 | 4422 | ||
| 4425 | LGLYPH_SET_CODE (glyph, code); | 4423 | LGLYPH_SET_CODE (glyph, code); |
diff --git a/src/font.h b/src/font.h index 633d92709c5..6f4792afe55 100644 --- a/src/font.h +++ b/src/font.h | |||
| @@ -886,7 +886,7 @@ extern Lisp_Object font_update_drivers (struct frame *f, Lisp_Object list); | |||
| 886 | extern Lisp_Object font_range (ptrdiff_t, ptrdiff_t, ptrdiff_t *, | 886 | extern Lisp_Object font_range (ptrdiff_t, ptrdiff_t, ptrdiff_t *, |
| 887 | struct window *, struct face *, | 887 | struct window *, struct face *, |
| 888 | Lisp_Object); | 888 | Lisp_Object); |
| 889 | extern void font_fill_lglyph_metrics (Lisp_Object, Lisp_Object); | 889 | extern void font_fill_lglyph_metrics (Lisp_Object, struct font *, unsigned int); |
| 890 | 890 | ||
| 891 | extern Lisp_Object font_put_extra (Lisp_Object font, Lisp_Object prop, | 891 | extern Lisp_Object font_put_extra (Lisp_Object font, Lisp_Object prop, |
| 892 | Lisp_Object val); | 892 | Lisp_Object val); |