[util] Initialize struct members inline

This commit is contained in:
Behdad Esfahbod 2021-08-05 10:33:31 -06:00
parent 21f1054d47
commit e57dd66889
6 changed files with 109 additions and 180 deletions

View File

@ -32,9 +32,8 @@
struct shape_closure_consumer_t : option_group_t struct shape_closure_consumer_t : option_group_t
{ {
shape_closure_consumer_t (option_parser_t *parser) : shape_closure_consumer_t (option_parser_t *parser)
shaper (parser), : shaper (parser)
show_glyph_names (true)
{ {
add_options (parser); add_options (parser);
} }
@ -104,11 +103,11 @@ struct shape_closure_consumer_t : option_group_t
protected: protected:
shape_options_t shaper; shape_options_t shaper;
hb_bool_t show_glyph_names; hb_bool_t show_glyph_names = false;
hb_set_t *glyphs; hb_set_t *glyphs = nullptr;
hb_font_t *font; hb_font_t *font = nullptr;
hb_buffer_t *buffer; hb_buffer_t *buffer = nullptr;
}; };
int int

View File

@ -32,12 +32,8 @@ struct output_buffer_t
{ {
output_buffer_t (option_parser_t *parser) output_buffer_t (option_parser_t *parser)
: options (parser, hb_buffer_serialize_list_formats ()), : options (parser, hb_buffer_serialize_list_formats ()),
format (parser), format (parser)
gs (nullptr), {}
line_no (0),
font (nullptr),
output_format (HB_BUFFER_SERIALIZE_FORMAT_INVALID),
format_flags (HB_BUFFER_SERIALIZE_FLAG_DEFAULT) {}
void init (hb_buffer_t *buffer, const font_options_t *font_opts) void init (hb_buffer_t *buffer, const font_options_t *font_opts)
{ {
@ -147,11 +143,11 @@ struct output_buffer_t
output_options_t options; output_options_t options;
format_options_t format; format_options_t format;
GString *gs; GString *gs = nullptr;
unsigned int line_no; unsigned int line_no = 0;
hb_font_t *font; hb_font_t *font = nullptr;
hb_buffer_serialize_format_t output_format; hb_buffer_serialize_format_t output_format = HB_BUFFER_SERIALIZE_FORMAT_INVALID;
hb_buffer_serialize_flags_t format_flags; hb_buffer_serialize_flags_t format_flags = HB_BUFFER_SERIALIZE_FLAG_DEFAULT;
}; };
template <int eol = '\n'> template <int eol = '\n'>

View File

@ -37,7 +37,9 @@
struct subset_consumer_t struct subset_consumer_t
{ {
subset_consumer_t (option_parser_t *parser) subset_consumer_t (option_parser_t *parser)
: failed (false), options (parser), subset_options (parser), face (nullptr), input (nullptr) {} : options (parser),
subset_options (parser)
{}
void init (hb_buffer_t *buffer_, void init (hb_buffer_t *buffer_,
const font_options_t *font_opts) const font_options_t *font_opts)
@ -116,14 +118,14 @@ struct subset_consumer_t
} }
public: public:
bool failed; bool failed = false;
private: private:
output_options_t options; output_options_t options;
subset_options_t subset_options; subset_options_t subset_options;
hb_face_t *face; hb_face_t *face = nullptr;
hb_subset_input_t *input; hb_subset_input_t *input = nullptr;
}; };
template <int eol = '\n'> template <int eol = '\n'>

View File

@ -67,12 +67,10 @@ struct option_group_t
struct option_parser_t struct option_parser_t
{ {
option_parser_t (const char *usage) option_parser_t (const char *usage)
: usage_str (usage),
context (g_option_context_new (usage)),
to_free (g_ptr_array_new ())
{ {
memset (this, 0, sizeof (*this));
usage_str = usage;
context = g_option_context_new (usage);
to_free = g_ptr_array_new ();
add_main_options (); add_main_options ();
} }
@ -121,14 +119,6 @@ struct view_options_t : option_group_t
{ {
view_options_t (option_parser_t *parser) view_options_t (option_parser_t *parser)
{ {
annotate = false;
fore = nullptr;
back = nullptr;
line_space = 0;
have_font_extents = false;
font_extents.ascent = font_extents.descent = font_extents.line_gap = 0;
margin.t = margin.r = margin.b = margin.l = DEFAULT_MARGIN;
add_options (parser); add_options (parser);
} }
~view_options_t () override ~view_options_t () override
@ -139,17 +129,17 @@ struct view_options_t : option_group_t
void add_options (option_parser_t *parser) override; void add_options (option_parser_t *parser) override;
hb_bool_t annotate; hb_bool_t annotate = false;
char *fore; char *fore = nullptr;
char *back; char *back = nullptr;
double line_space; double line_space = 0;
bool have_font_extents; bool have_font_extents = false;
struct font_extents_t { struct font_extents_t {
double ascent, descent, line_gap; double ascent, descent, line_gap;
} font_extents; } font_extents = {0., 0., 0.};
struct margin_t { struct margin_t {
double t, r, b, l; double t, r, b, l;
} margin; } margin = {DEFAULT_MARGIN, DEFAULT_MARGIN, DEFAULT_MARGIN, DEFAULT_MARGIN};
}; };
@ -157,18 +147,6 @@ struct shape_options_t : option_group_t
{ {
shape_options_t (option_parser_t *parser) shape_options_t (option_parser_t *parser)
{ {
direction = language = script = nullptr;
bot = eot = preserve_default_ignorables = remove_default_ignorables = false;
features = nullptr;
num_features = 0;
shapers = nullptr;
utf8_clusters = false;
invisible_glyph = 0;
cluster_level = HB_BUFFER_CLUSTER_LEVEL_DEFAULT;
normalize_glyphs = false;
verify = false;
num_iterations = 1;
add_options (parser); add_options (parser);
} }
~shape_options_t () override ~shape_options_t () override
@ -431,25 +409,25 @@ struct shape_options_t : option_group_t
} }
/* Buffer properties */ /* Buffer properties */
char *direction; char *direction = nullptr;
char *language; char *language = nullptr;
char *script; char *script = nullptr;
/* Buffer flags */ /* Buffer flags */
hb_bool_t bot; hb_bool_t bot = false;
hb_bool_t eot; hb_bool_t eot = false;
hb_bool_t preserve_default_ignorables; hb_bool_t preserve_default_ignorables = false;
hb_bool_t remove_default_ignorables; hb_bool_t remove_default_ignorables = false;
hb_feature_t *features; hb_feature_t *features = nullptr;
unsigned int num_features; unsigned int num_features = 0;
char **shapers; char **shapers = nullptr;
hb_bool_t utf8_clusters; hb_bool_t utf8_clusters = false;
hb_codepoint_t invisible_glyph; hb_codepoint_t invisible_glyph = 0;
hb_buffer_cluster_level_t cluster_level; hb_buffer_cluster_level_t cluster_level = HB_BUFFER_CLUSTER_LEVEL_DEFAULT;
hb_bool_t normalize_glyphs; hb_bool_t normalize_glyphs = false;
hb_bool_t verify; hb_bool_t verify = false;
unsigned int num_iterations; unsigned int num_iterations = 1;
}; };
@ -458,23 +436,11 @@ struct font_options_t : option_group_t
font_options_t (option_parser_t *parser, font_options_t (option_parser_t *parser,
int default_font_size_, int default_font_size_,
unsigned int subpixel_bits_) unsigned int subpixel_bits_)
: default_font_size (default_font_size_),
subpixel_bits (subpixel_bits_),
font_size_x (default_font_size_),
font_size_y (default_font_size_)
{ {
variations = nullptr;
num_variations = 0;
default_font_size = default_font_size_;
x_ppem = 0;
y_ppem = 0;
ptem = 0.;
subpixel_bits = subpixel_bits_;
font_file = nullptr;
face_index = 0;
font_size_x = font_size_y = default_font_size;
font_funcs = nullptr;
ft_load_flags = 2;
blob = nullptr;
font = nullptr;
add_options (parser); add_options (parser);
} }
~font_options_t () override ~font_options_t () override
@ -489,23 +455,23 @@ struct font_options_t : option_group_t
hb_font_t *get_font () const; hb_font_t *get_font () const;
char *font_file; char *font_file = nullptr;
mutable hb_blob_t *blob; mutable hb_blob_t *blob = nullptr;
unsigned face_index; unsigned face_index = 0;
hb_variation_t *variations; hb_variation_t *variations = nullptr;
unsigned int num_variations; unsigned int num_variations = 0;
int default_font_size; int default_font_size = FONT_SIZE_UPEM;
int x_ppem; int x_ppem = 0;
int y_ppem; int y_ppem = 0;
double ptem; double ptem = 0.;
unsigned int subpixel_bits; unsigned int subpixel_bits = 0;
mutable double font_size_x; mutable double font_size_x = FONT_SIZE_UPEM;
mutable double font_size_y; mutable double font_size_y = FONT_SIZE_UPEM;
char *font_funcs; char *font_funcs = nullptr;
int ft_load_flags; int ft_load_flags = 2;
private: private:
mutable hb_font_t *font; mutable hb_font_t *font = nullptr;
static struct cache_t static struct cache_t
{ {
@ -528,18 +494,6 @@ struct text_options_t : option_group_t
{ {
text_options_t (option_parser_t *parser) text_options_t (option_parser_t *parser)
{ {
text_before = nullptr;
text_after = nullptr;
text_len = -1;
text = nullptr;
text_file = nullptr;
fp = nullptr;
gs = nullptr;
line = nullptr;
line_len = UINT_MAX;
add_options (parser); add_options (parser);
} }
~text_options_t () override ~text_options_t () override
@ -565,32 +519,26 @@ struct text_options_t : option_group_t
const char *get_line (unsigned int *len, int eol = '\n'); const char *get_line (unsigned int *len, int eol = '\n');
char *text_before; char *text_before = nullptr;
char *text_after; char *text_after = nullptr;
int text_len; int text_len = -1;
char *text; char *text = nullptr;
char *text_file; char *text_file = nullptr;
private: private:
FILE *fp; FILE *fp = nullptr;
GString *gs; GString *gs = nullptr;
char *line; char *line = nullptr;
unsigned int line_len; unsigned int line_len = UINT_MAX;
}; };
struct output_options_t : option_group_t struct output_options_t : option_group_t
{ {
output_options_t (option_parser_t *parser, output_options_t (option_parser_t *parser,
const char **supported_formats_ = nullptr) const char **supported_formats_ = nullptr)
: supported_formats (supported_formats_)
{ {
output_file = nullptr;
output_format = nullptr;
supported_formats = supported_formats_;
explicit_output_format = false;
fp = nullptr;
add_options (parser); add_options (parser);
} }
~output_options_t () override ~output_options_t () override
@ -623,28 +571,17 @@ struct output_options_t : option_group_t
FILE *get_file_handle (); FILE *get_file_handle ();
char *output_file; char *output_file = nullptr;
char *output_format; char *output_format = nullptr;
const char **supported_formats; const char **supported_formats = nullptr;
bool explicit_output_format; bool explicit_output_format = false;
mutable FILE *fp; mutable FILE *fp = nullptr;
}; };
struct format_options_t : option_group_t struct format_options_t : option_group_t
{ {
format_options_t (option_parser_t *parser) { format_options_t (option_parser_t *parser) {
show_glyph_names = true;
show_positions = true;
show_advances = true;
show_clusters = true;
show_text = false;
show_unicode = false;
show_line_num = false;
show_extents = false;
show_flags = false;
trace = false;
add_options (parser); add_options (parser);
} }
@ -677,24 +614,23 @@ struct format_options_t : option_group_t
GString *gs); GString *gs);
hb_bool_t show_glyph_names; hb_bool_t show_glyph_names = true;
hb_bool_t show_positions; hb_bool_t show_positions = true;
hb_bool_t show_advances; hb_bool_t show_advances = true;
hb_bool_t show_clusters; hb_bool_t show_clusters = true;
hb_bool_t show_text; hb_bool_t show_text = false;
hb_bool_t show_unicode; hb_bool_t show_unicode = false;
hb_bool_t show_line_num; hb_bool_t show_line_num = false;
hb_bool_t show_extents; hb_bool_t show_extents = false;
hb_bool_t show_flags; hb_bool_t show_flags = false;
hb_bool_t trace; hb_bool_t trace = false;
}; };
struct subset_options_t : option_group_t struct subset_options_t : option_group_t
{ {
subset_options_t (option_parser_t *parser) subset_options_t (option_parser_t *parser)
: input (hb_subset_input_create_or_fail ())
{ {
input = hb_subset_input_create_or_fail ();
num_iterations = 1;
add_options (parser); add_options (parser);
} }
@ -715,8 +651,6 @@ struct subset_options_t : option_group_t
return &flags[sizeof(int) * 8 - 1]; return &flags[sizeof(int) * 8 - 1];
} }
unsigned num_iterations;
hb_subset_input_t * get_input () hb_subset_input_t * get_input ()
{ {
hb_subset_flags_t flags_set = HB_SUBSET_FLAGS_DEFAULT; hb_subset_flags_t flags_set = HB_SUBSET_FLAGS_DEFAULT;
@ -729,9 +663,9 @@ struct subset_options_t : option_group_t
return input; return input;
} }
unsigned num_iterations = 1;
hb_subset_input_t *input = nullptr;
hb_bool_t flags[sizeof(int) * 8] = {0}; hb_bool_t flags[sizeof(int) * 8] = {0};
hb_subset_input_t *input;
}; };
/* fallback implementation for scalbn()/scalbnf() for pre-2013 MSVC */ /* fallback implementation for scalbn()/scalbnf() for pre-2013 MSVC */

View File

@ -35,11 +35,9 @@ template <typename output_t>
struct shape_consumer_t struct shape_consumer_t
{ {
shape_consumer_t (option_parser_t *parser) shape_consumer_t (option_parser_t *parser)
: failed (false), : shaper (parser),
shaper (parser), output (parser)
output (parser), {}
font (nullptr),
buffer (nullptr) {}
void init (hb_buffer_t *buffer_, void init (hb_buffer_t *buffer_,
const font_options_t *font_opts) const font_options_t *font_opts)
@ -87,14 +85,14 @@ struct shape_consumer_t
} }
public: public:
bool failed; bool failed = false;
protected: protected:
shape_options_t shaper; shape_options_t shaper;
output_t output; output_t output;
hb_font_t *font; hb_font_t *font = nullptr;
hb_buffer_t *buffer; hb_buffer_t *buffer = nullptr;
}; };

View File

@ -36,10 +36,10 @@ struct view_cairo_t
{ {
view_cairo_t (option_parser_t *parser) view_cairo_t (option_parser_t *parser)
: output_options (parser, helper_cairo_supported_formats), : output_options (parser, helper_cairo_supported_formats),
view_options (parser), view_options (parser)
direction (HB_DIRECTION_INVALID), {}
lines (0), scale_bits (0) {} ~view_cairo_t ()
~view_cairo_t () { {
cairo_debug_reset_static_data (); cairo_debug_reset_static_data ();
} }
@ -82,14 +82,14 @@ struct view_cairo_t
protected: protected:
void render (const font_options_t *font_opts);
output_options_t output_options; output_options_t output_options;
view_options_t view_options; view_options_t view_options;
void render (const font_options_t *font_opts); hb_direction_t direction = HB_DIRECTION_INVALID; // Remove this, make segment_properties accessible
GArray *lines = nullptr;
hb_direction_t direction; // Remove this, make segment_properties accessible int scale_bits = 0;
GArray *lines;
int scale_bits;
}; };
#endif #endif