From c226da8c3517ae9524903208a016358e682c21e9 Mon Sep 17 00:00:00 2001 From: Khaled Hosny Date: Sun, 23 Mar 2025 15:22:47 +0200 Subject: [PATCH 1/2] [test/directwrite] Make the variations test actually test variations --- test/api/test-directwrite.cc | 54 ++++++++++++++++++++++++++++++------ 1 file changed, 46 insertions(+), 8 deletions(-) diff --git a/test/api/test-directwrite.cc b/test/api/test-directwrite.cc index 85d80d1ea..b89970a79 100644 --- a/test/api/test-directwrite.cc +++ b/test/api/test-directwrite.cc @@ -76,21 +76,59 @@ test_native_directwrite_basic (void) static void test_native_directwrite_variations (void) { - IDWriteFontFace *dwfontface; + IDWriteFontFace *dw_face; + IDWriteFontResource *dw_fontresource; + IDWriteFontFace5 *dw_face5, *dw_facevariations; + DWRITE_FONT_AXIS_VALUE dw_axisvalues[5]; hb_font_t *font; + const float *coords; unsigned int length; - dwfontface = get_dwfontface ("fonts/AdobeVFPrototype.abc.otf"); - g_assert_nonnull (dwfontface); + dw_face = get_dwfontface ("fonts/AdobeVFPrototype.abc.otf"); + g_assert_nonnull (dw_face); - font = hb_directwrite_font_create (dwfontface); - hb_font_get_var_coords_normalized(font, &length); - // Currently we optimize out coords if none is non-zero - //g_assert_cmpuint (length, !=, 0); + dw_face->QueryInterface (__uuidof(IDWriteFontFace5), (void **)&dw_face5); + dw_face->Release (); + g_assert_nonnull (dw_face5); + + // Check that wght axis originally set on the face is different from what we will set. + if (!dw_face5->HasVariations ()) + { + g_test_skip ("Font has no variations. Possiply using Wine’s DWrite.dll"); + return; + } + g_assert_cmpuint (dw_face5->GetFontAxisValueCount (), ==, 5); + dw_face5->GetFontAxisValues (dw_axisvalues, 5); + g_assert_cmpuint (dw_axisvalues[0].axisTag, ==, DWRITE_FONT_AXIS_TAG_WEIGHT); + g_assert_cmpfloat (dw_axisvalues[0].value, !=, 900.0f); + + dw_face5->GetFontResource (&dw_fontresource); + dw_face5->Release(); + g_assert_nonnull (dw_fontresource); + + // Set wght axis to 900.0 + dw_axisvalues[0].value = 900.0f; + dw_fontresource->CreateFontFace (DWRITE_FONT_SIMULATIONS_NONE, dw_axisvalues, 5, &dw_facevariations); + dw_fontresource->Release (); + g_assert_nonnull (dw_facevariations); + + // Check that wght axis is now set to 900.0 + g_assert_cmpuint (dw_facevariations->GetFontAxisValueCount (), ==, 5); + dw_facevariations->GetFontAxisValues (dw_axisvalues, 5); + g_assert_cmpuint (dw_axisvalues[0].axisTag, ==, DWRITE_FONT_AXIS_TAG_WEIGHT); + g_assert_cmpfloat (dw_axisvalues[0].value, ==, 900.0f); + + font = hb_directwrite_font_create (dw_facevariations); + + // Check that wght axis is also set to 900.0 on the hb_font_t + coords = hb_font_get_var_coords_design(font, &length); + g_assert_cmpuint (length, ==, 2); + g_assert_cmpfloat (coords[0], ==, 900.0f); hb_font_destroy (font); - dwfontface->Release (); + // FIXME: This crashes! + //dw_facevariations->Release (); } From 8d62ad3b357e3cc3001bc1af43559affcd099ef6 Mon Sep 17 00:00:00 2001 From: Khaled Hosny Date: Sun, 23 Mar 2025 15:27:36 +0200 Subject: [PATCH 2/2] =?UTF-8?q?[directwrite]=20Don=E2=80=99t=20release=20I?= =?UTF-8?q?DWriteFace=20pass=20to=20hb=5Fdirectwrite=5Ffont=5Fcreate?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit That was a leftover from previous code and is incorrect now as we would be double releasing it. --- src/hb-directwrite.cc | 4 +--- test/api/test-directwrite.cc | 6 ++---- 2 files changed, 3 insertions(+), 7 deletions(-) diff --git a/src/hb-directwrite.cc b/src/hb-directwrite.cc index b891554bc..4c2a8e1d6 100644 --- a/src/hb-directwrite.cc +++ b/src/hb-directwrite.cc @@ -346,7 +346,7 @@ hb_directwrite_font_create (IDWriteFontFace *dw_face) hb_face_destroy (face); if (unlikely (hb_object_is_immutable (font))) - goto done; + return font; /* Copy font variations */ if (SUCCEEDED (dw_face->QueryInterface (__uuidof (IDWriteFontFace5), (void**) &dw_face5))) @@ -378,8 +378,6 @@ hb_directwrite_font_create (IDWriteFontFace *dw_face) dw_face->AddRef (); font->data.directwrite.cmpexch (nullptr, (hb_directwrite_font_data_t *) dw_face); -done: - dw_face->Release (); return font; } diff --git a/test/api/test-directwrite.cc b/test/api/test-directwrite.cc index b89970a79..a9d3a4bb5 100644 --- a/test/api/test-directwrite.cc +++ b/test/api/test-directwrite.cc @@ -45,8 +45,7 @@ get_dwfontface (const char *font_path) dw_font_face->AddRef (); - // Don't destroy face, as dw_font_face is backed by its data I think. - //hb_face_destroy (face); + hb_face_destroy (face); return dw_font_face; } @@ -127,8 +126,7 @@ test_native_directwrite_variations (void) hb_font_destroy (font); - // FIXME: This crashes! - //dw_facevariations->Release (); + dw_facevariations->Release (); }