[util/hb-subset] Keep face around instead of font

This commit is contained in:
Behdad Esfahbod 2021-08-04 20:23:48 -06:00
parent 8c0c217b5a
commit 21f1054d47
1 changed files with 7 additions and 8 deletions

View File

@ -37,12 +37,12 @@
struct subset_consumer_t
{
subset_consumer_t (option_parser_t *parser)
: failed (false), options (parser), subset_options (parser), font (nullptr), input (nullptr) {}
: failed (false), options (parser), subset_options (parser), face (nullptr), input (nullptr) {}
void init (hb_buffer_t *buffer_,
const font_options_t *font_opts)
{
font = hb_font_reference (font_opts->get_font ());
face = hb_face_reference (hb_font_get_face (font_opts->get_font ()));
input = hb_subset_input_reference (subset_options.get_input ());
}
@ -55,7 +55,6 @@ struct subset_consumer_t
hb_set_t *codepoints = hb_subset_input_unicode_set (input);
if (0 == strcmp (text, "*"))
{
hb_face_t *face = hb_font_get_face (font);
hb_face_collect_unicodes (face, codepoints);
return;
}
@ -96,10 +95,9 @@ struct subset_consumer_t
void finish (const font_options_t *font_opts)
{
hb_face_t *face = hb_font_get_face (font);
hb_face_t *new_face = nullptr;
for (unsigned i = 0; i < subset_options.num_iterations; i++) {
for (unsigned i = 0; i < subset_options.num_iterations; i++)
{
hb_face_destroy (new_face);
new_face = hb_subset_or_fail (face, input);
}
@ -114,7 +112,7 @@ struct subset_consumer_t
hb_subset_input_destroy (input);
hb_face_destroy (new_face);
hb_font_destroy (font);
hb_face_destroy (face);
}
public:
@ -123,7 +121,8 @@ struct subset_consumer_t
private:
output_options_t options;
subset_options_t subset_options;
hb_font_t *font;
hb_face_t *face;
hb_subset_input_t *input;
};