From 38de3491a08633175d7e40d9acabd48d813f755a Mon Sep 17 00:00:00 2001 From: Garret Rieger Date: Wed, 9 Jun 2021 12:54:14 -0700 Subject: [PATCH] [subset] add implementation for get/set flag on subset input. --- src/hb-subset-input.cc | 61 +++++++++++++++++++++++++++++++++--------- src/hb-subset.h | 35 +++++++++++++----------- 2 files changed, 67 insertions(+), 29 deletions(-) diff --git a/src/hb-subset-input.cc b/src/hb-subset-input.cc index c81ee2bf5..647621d54 100644 --- a/src/hb-subset-input.cc +++ b/src/hb-subset-input.cc @@ -258,7 +258,7 @@ hb_subset_input_layout_features_set (hb_subset_input_t *subset_input) HB_EXTERN void hb_subset_input_set_retain_all_features (hb_subset_input_t *subset_input, - hb_bool_t value) + hb_bool_t value) { subset_input->retain_all_layout_features = value; } @@ -278,19 +278,54 @@ hb_subset_input_drop_tables_set (hb_subset_input_t *subset_input) HB_EXTERN hb_bool_t -hb_subset_input_get_bool (hb_subset_property_t property) +hb_subset_input_get_flag (hb_subset_input_t *input, + hb_subset_flag_t flag) { - // TODO(garretrieger): implement. - return false; + switch (flag) + { + case HB_SUBSET_FLAG_HINTING: + return !input->drop_hints; + case HB_SUBSET_FLAG_RETAIN_GIDS: + return input->retain_gids; + case HB_SUBSET_FLAG_DESUBROUTINIZE: + return input->desubroutinize; + case HB_SUBSET_FLAG_NAME_LEGACY: + return input->name_legacy; + case HB_SUBSET_FLAG_SET_OVERLAPS_FLAG: + return input->overlaps_flag; + default: + return false; + } } HB_EXTERN void -hb_subset_input_set_bool (hb_subset_property_t property, hb_bool_t value) +hb_subset_input_set_flag (hb_subset_input_t *input, + hb_subset_flag_t flag, + hb_bool_t value) { - // TODO(garretrieger): implement. + switch (flag) + { + case HB_SUBSET_FLAG_HINTING: + input->drop_hints = !value; + break; + case HB_SUBSET_FLAG_RETAIN_GIDS: + input->retain_gids = value; + break; + case HB_SUBSET_FLAG_DESUBROUTINIZE: + input->desubroutinize = value; + break; + case HB_SUBSET_FLAG_NAME_LEGACY: + input->name_legacy = value; + break; + case HB_SUBSET_FLAG_SET_OVERLAPS_FLAG: + input->overlaps_flag = value; + break; + default: + // Do nothing. + break; + } } - HB_EXTERN void hb_subset_input_set_drop_hints (hb_subset_input_t *subset_input, hb_bool_t drop_hints) @@ -356,7 +391,7 @@ hb_subset_input_get_name_legacy (hb_subset_input_t *subset_input) HB_EXTERN void hb_subset_input_set_overlaps_flag (hb_subset_input_t *subset_input, - hb_bool_t overlaps_flag) + hb_bool_t overlaps_flag) { subset_input->overlaps_flag = overlaps_flag; } @@ -409,10 +444,10 @@ hb_subset_input_get_no_prune_unicode_ranges (hb_subset_input_t *subset_input) **/ hb_bool_t hb_subset_input_set_user_data (hb_subset_input_t *input, - hb_user_data_key_t *key, - void * data, - hb_destroy_func_t destroy, - hb_bool_t replace) + hb_user_data_key_t *key, + void * data, + hb_destroy_func_t destroy, + hb_bool_t replace) { return hb_object_set_user_data (input, key, data, destroy, replace); } @@ -431,7 +466,7 @@ hb_subset_input_set_user_data (hb_subset_input_t *input, **/ void * hb_subset_input_get_user_data (const hb_subset_input_t *input, - hb_user_data_key_t *key) + hb_user_data_key_t *key) { return hb_object_get_user_data (input, key); } diff --git a/src/hb-subset.h b/src/hb-subset.h index b5bf4cc5d..6be93d28d 100644 --- a/src/hb-subset.h +++ b/src/hb-subset.h @@ -39,14 +39,14 @@ HB_BEGIN_DECLS typedef struct hb_subset_input_t hb_subset_input_t; -enum hb_subset_property_t +typedef enum { - HB_SUBSET_PROPERTY_HINTING = 1, - HB_SUBSET_PROPERTY_RETAIN_GIDS = 2, - HB_SUBSET_PROPERTY_DESUBROUTINIZE = 3, - HB_SUBSET_PROPERTY_NAME_LEGACY = 4, - HB_SUBSET_PROPERTY_SET_OVERLAPS_FLAG = 5, -}; + HB_SUBSET_FLAG_HINTING = 1, + HB_SUBSET_FLAG_RETAIN_GIDS = 2, + HB_SUBSET_FLAG_DESUBROUTINIZE = 3, + HB_SUBSET_FLAG_NAME_LEGACY = 4, + HB_SUBSET_FLAG_SET_OVERLAPS_FLAG = 5, +} hb_subset_flag_t; HB_EXTERN hb_subset_input_t * hb_subset_input_create_or_fail (void); @@ -74,7 +74,7 @@ hb_subset_input_layout_features_set (hb_subset_input_t *subset_input); HB_EXTERN void hb_subset_input_set_retain_all_features (hb_subset_input_t *subset_input, - hb_bool_t value); + hb_bool_t value); HB_EXTERN hb_bool_t hb_subset_input_get_retain_all_features (hb_subset_input_t *subset_input); @@ -83,10 +83,13 @@ hb_subset_input_drop_tables_set (hb_subset_input_t *subset_input); HB_EXTERN hb_bool_t -hb_subset_input_get_bool (hb_subset_property_t property); +hb_subset_input_get_flag (hb_subset_input_t *input, + hb_subset_flag_t flag); HB_EXTERN void -hb_subset_input_set_bool (hb_subset_property_t property, hb_bool_t value); +hb_subset_input_set_flag (hb_subset_input_t *input, + hb_subset_flag_t flag, + hb_bool_t value); // TODO(garretrieger): remove bool property get/set methods. @@ -116,7 +119,7 @@ hb_subset_input_get_name_legacy (hb_subset_input_t *subset_input); HB_EXTERN void hb_subset_input_set_overlaps_flag (hb_subset_input_t *subset_input, - hb_bool_t overlaps_flag); + hb_bool_t overlaps_flag); HB_EXTERN hb_bool_t hb_subset_input_get_overlaps_flag (hb_subset_input_t *subset_input); @@ -141,14 +144,14 @@ hb_subset (hb_face_t *source, const hb_subset_input_t *input); HB_EXTERN hb_bool_t hb_subset_input_set_user_data (hb_subset_input_t *input, - hb_user_data_key_t *key, - void * data, - hb_destroy_func_t destroy, - hb_bool_t replace); + hb_user_data_key_t *key, + void * data, + hb_destroy_func_t destroy, + hb_bool_t replace); HB_EXTERN void * hb_subset_input_get_user_data (const hb_subset_input_t *input, - hb_user_data_key_t *key); + hb_user_data_key_t *key); HB_END_DECLS