From 382f7920abcf7df46b5b44462c6c71de54454b0e Mon Sep 17 00:00:00 2001 From: Po Lu Date: Mon, 20 Jun 2022 02:16:34 +0000 Subject: [PATCH] Respect `:antialias' on Haiku * src/haiku_font_support.cc (BFont_find): Pass through FSPEC_ANTIALIAS. (be_set_font_antialiasing): New function. * src/haiku_support.h (enum haiku_font_specification): New enum FSPEC_ANTIALIAS. (struct haiku_font_pattern): New field `use_antialiasing'. * src/haikufont.c (haikufont_pattern_to_entity) (haikufont_spec_or_entity_to_pattern, haikufont_open): Respect antialiasing. (syms_of_haikufont): New defsym `:indices'. --- src/haiku_font_support.cc | 23 ++++++++ src/haiku_support.h | 6 +++ src/haikufont.c | 110 +++++++++++++++++++++++--------------- 3 files changed, 97 insertions(+), 42 deletions(-) diff --git a/src/haiku_font_support.cc b/src/haiku_font_support.cc index ca6aaf71204..d824cc59ae2 100644 --- a/src/haiku_font_support.cc +++ b/src/haiku_font_support.cc @@ -598,6 +598,12 @@ BFont_find (struct haiku_font_pattern *pt) p->last = NULL; p->next_family = r; r = p; + + if (pt->specified & FSPEC_ANTIALIAS) + { + p->specified |= FSPEC_ANTIALIAS; + p->use_antialiasing = pt->use_antialiasing; + } } else if (sty_count) { @@ -623,6 +629,12 @@ BFont_find (struct haiku_font_pattern *pt) p->family_index = fi; p->style_index = si; + if (pt->specified & FSPEC_ANTIALIAS) + { + p->specified |= FSPEC_ANTIALIAS; + p->use_antialiasing = pt->use_antialiasing; + } + if (p->specified & FSPEC_SLANT && (p->slant == SLANT_OBLIQUE || p->slant == SLANT_ITALIC)) @@ -916,3 +928,14 @@ be_find_font_indices (struct haiku_font_pattern *pattern, return 1; } + +void +be_set_font_antialiasing (void *font, bool antialias_p) +{ + BFont *font_object; + + font_object = (BFont *) font; + font_object->SetFlags (antialias_p + ? B_FORCE_ANTIALIASING + : B_DISABLE_ANTIALIASING); +} diff --git a/src/haiku_support.h b/src/haiku_support.h index 7f8d471b650..97c2b6904af 100644 --- a/src/haiku_support.h +++ b/src/haiku_support.h @@ -271,6 +271,7 @@ enum haiku_font_specification FSPEC_WIDTH = 1 << 7, FSPEC_LANGUAGE = 1 << 8, FSPEC_INDICES = 1 << 9, + FSPEC_ANTIALIAS = 1 << 10, }; typedef char haiku_font_family_or_style[64]; @@ -390,6 +391,10 @@ struct haiku_font_pattern /* Temporary field used during font enumeration. */ int oblique_seen_p; + + /* Whether or not to enable antialising in the font. This field is + special in that it's not handled by `BFont_open_pattern'. */ + int use_antialiasing; }; struct haiku_scroll_bar_value_event @@ -684,6 +689,7 @@ extern const char *be_find_setting (const char *); extern haiku_font_family_or_style *be_list_font_families (size_t *); extern void be_font_style_to_flags (char *, struct haiku_font_pattern *); extern void *be_open_font_at_index (int, int, float); +extern void be_set_font_antialiasing (void *, bool); extern int be_get_ui_color (const char *, uint32_t *); extern void BMessage_delete (void *); diff --git a/src/haikufont.c b/src/haikufont.c index 54f11c6e413..77aa4006310 100644 --- a/src/haikufont.c +++ b/src/haikufont.c @@ -381,54 +381,67 @@ haikufont_maybe_handle_special_family (Lisp_Object family, static Lisp_Object haikufont_pattern_to_entity (struct haiku_font_pattern *ptn) { - Lisp_Object ent; + Lisp_Object entity, extras; + + entity = font_make_entity (); + extras = Qnil; + + ASET (entity, FONT_TYPE_INDEX, Qhaiku); + ASET (entity, FONT_FOUNDRY_INDEX, Qhaiku); + ASET (entity, FONT_FAMILY_INDEX, Qdefault); + ASET (entity, FONT_ADSTYLE_INDEX, Qnil); + ASET (entity, FONT_REGISTRY_INDEX, Qiso10646_1); + ASET (entity, FONT_SIZE_INDEX, make_fixnum (0)); + ASET (entity, FONT_AVGWIDTH_INDEX, make_fixnum (0)); + ASET (entity, FONT_SPACING_INDEX, make_fixnum (FONT_SPACING_MONO)); + + /* FONT_EXTRA_INDEX in a font entity can contain a cons of two + numbers (STYLE . IDX) under the key :indices that tell Emacs how + to open a font. */ + if (ptn->specified & FSPEC_INDICES) + extras = Fcons (Fcons (QCindices, + Fcons (make_fixnum (ptn->family_index), + make_fixnum (ptn->style_index))), + extras); - ent = font_make_entity (); - ASET (ent, FONT_TYPE_INDEX, Qhaiku); - ASET (ent, FONT_FOUNDRY_INDEX, Qhaiku); - ASET (ent, FONT_FAMILY_INDEX, Qdefault); - ASET (ent, FONT_ADSTYLE_INDEX, Qnil); - ASET (ent, FONT_REGISTRY_INDEX, Qiso10646_1); - ASET (ent, FONT_SIZE_INDEX, make_fixnum (0)); - ASET (ent, FONT_AVGWIDTH_INDEX, make_fixnum (0)); - ASET (ent, FONT_SPACING_INDEX, make_fixnum (FONT_SPACING_MONO)); + if (ptn->specified & FSPEC_ANTIALIAS) + extras = Fcons (Fcons (QCantialias, + ptn->use_antialiasing ? Qt : Qnil), + extras); - /* FONT_EXTRA_INDEX in a font entity can be a cons of two numbers - (STYLE . IDX) that tell Emacs how to open a font. */ - if (ptn->specified & FSPEC_INDICES) - ASET (ent, FONT_EXTRA_INDEX, - Fcons (make_fixnum (ptn->family_index), - make_fixnum (ptn->style_index))); + ASET (entity, FONT_EXTRA_INDEX, extras); - FONT_SET_STYLE (ent, FONT_WIDTH_INDEX, Qnormal); - FONT_SET_STYLE (ent, FONT_WEIGHT_INDEX, Qnormal); - FONT_SET_STYLE (ent, FONT_SLANT_INDEX, Qnormal); + FONT_SET_STYLE (entity, FONT_WIDTH_INDEX, Qnormal); + FONT_SET_STYLE (entity, FONT_WEIGHT_INDEX, Qnormal); + FONT_SET_STYLE (entity, FONT_SLANT_INDEX, Qnormal); if (ptn->specified & FSPEC_FAMILY) - ASET (ent, FONT_FAMILY_INDEX, intern (ptn->family)); + ASET (entity, FONT_FAMILY_INDEX, intern (ptn->family)); else - ASET (ent, FONT_FAMILY_INDEX, Qdefault); + ASET (entity, FONT_FAMILY_INDEX, Qdefault); if (ptn->specified & FSPEC_STYLE) - ASET (ent, FONT_ADSTYLE_INDEX, intern (ptn->style)); + ASET (entity, FONT_ADSTYLE_INDEX, intern (ptn->style)); else { if (ptn->specified & FSPEC_WEIGHT) - FONT_SET_STYLE (ent, FONT_WEIGHT_INDEX, + FONT_SET_STYLE (entity, FONT_WEIGHT_INDEX, haikufont_weight_to_lisp (ptn->weight)); if (ptn->specified & FSPEC_SLANT) - FONT_SET_STYLE (ent, FONT_SLANT_INDEX, + FONT_SET_STYLE (entity, FONT_SLANT_INDEX, haikufont_slant_to_lisp (ptn->slant)); if (ptn->specified & FSPEC_WIDTH) - FONT_SET_STYLE (ent, FONT_WIDTH_INDEX, + FONT_SET_STYLE (entity, FONT_WIDTH_INDEX, haikufont_width_to_lisp (ptn->width)); } if (ptn->specified & FSPEC_SPACING) - ASET (ent, FONT_SPACING_INDEX, - make_fixnum (ptn->mono_spacing_p ? - FONT_SPACING_MONO : FONT_SPACING_PROPORTIONAL)); - return ent; + ASET (entity, FONT_SPACING_INDEX, + make_fixnum (ptn->mono_spacing_p + ? FONT_SPACING_MONO + : FONT_SPACING_PROPORTIONAL)); + + return entity; } static void @@ -613,6 +626,13 @@ haikufont_spec_or_entity_to_pattern (Lisp_Object ent, int list_p, } } + tem = assq_no_quit (QCantialias, AREF (ent, FONT_EXTRA_INDEX)); + if (CONSP (tem)) + { + ptn->specified |= FSPEC_ANTIALIAS; + ptn->use_antialiasing = !NILP (XCDR (tem)); + } + tem = AREF (ent, FONT_REGISTRY_INDEX); if (SYMBOLP (tem)) haikufont_apply_registry (ptn, tem); @@ -732,10 +752,10 @@ haikufont_open (struct frame *f, Lisp_Object font_entity, int x) struct haiku_font_pattern ptn; struct font *font; void *be_font; - Lisp_Object font_object, tem, extra; - int px_size, min_width, max_width, - avg_width, height, space_width, ascent, - descent, underline_pos, underline_thickness; + Lisp_Object font_object, tem, extra, indices, antialias; + int px_size, min_width, max_width; + int avg_width, height, space_width, ascent; + int descent, underline_pos, underline_thickness; if (x <= 0) { @@ -746,15 +766,21 @@ haikufont_open (struct frame *f, Lisp_Object font_entity, int x) extra = AREF (font_entity, FONT_EXTRA_INDEX); + indices = assq_no_quit (QCindices, extra); + antialias = assq_no_quit (QCantialias, extra); + + if (CONSP (indices)) + indices = XCDR (indices); + /* If the font's indices is already available, open the font using those instead. */ - if (CONSP (extra) && FIXNUMP (XCAR (extra)) - && FIXNUMP (XCDR (extra))) + if (CONSP (indices) && FIXNUMP (XCAR (indices)) + && FIXNUMP (XCDR (indices))) { block_input (); - be_font = be_open_font_at_index (XFIXNUM (XCAR (extra)), - XFIXNUM (XCDR (extra)), x); + be_font = be_open_font_at_index (XFIXNUM (XCAR (indices)), + XFIXNUM (XCDR (indices)), x); unblock_input (); if (!be_font) @@ -778,13 +804,8 @@ haikufont_open (struct frame *f, Lisp_Object font_entity, int x) block_input (); - /* `font_make_object' tries to treat the extra data as an alist. - There is never any real data here, so clear that field. */ - - ASET (font_entity, FONT_EXTRA_INDEX, Qnil); font_object = font_make_object (VECSIZE (struct haikufont_info), font_entity, x); - ASET (font_entity, FONT_EXTRA_INDEX, extra); ASET (font_object, FONT_TYPE_INDEX, Qhaiku); font_info = (struct haikufont_info *) XFONT_OBJECT (font_object); @@ -799,6 +820,9 @@ haikufont_open (struct frame *f, Lisp_Object font_entity, int x) font_info->be_font = be_font; font_info->glyphs = xzalloc (0x100 * sizeof *font_info->glyphs); + if (CONSP (antialias)) + be_set_font_antialiasing (be_font, !NILP (XCDR (antialias))); + font->pixel_size = 0; font->driver = &haikufont_driver; font->encoding_charset = -1; @@ -1270,6 +1294,8 @@ syms_of_haikufont (void) DEFSYM (Qko, "ko"); DEFSYM (Qjp, "jp"); + DEFSYM (QCindices, ":indices"); + #ifdef USE_BE_CAIRO Fput (Qhaiku, Qfont_driver_superseded_by, Qftcr); #endif -- 2.39.2