[util] Use inheritence to embed inherent options of objects
This commit is contained in:
parent
06d661803c
commit
4e97678ebb
|
@ -38,18 +38,18 @@ const unsigned SUBPIXEL_BITS = 0;
|
||||||
* Command line interface to the harfbuzz font subsetter.
|
* Command line interface to the harfbuzz font subsetter.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct subset_consumer_t
|
struct subset_consumer_t : subset_options_t
|
||||||
{
|
{
|
||||||
void add_options (option_parser_t *parser)
|
void add_options (option_parser_t *parser)
|
||||||
{
|
{
|
||||||
|
subset_options_t::add_options (parser);
|
||||||
output_options.add_options (parser);
|
output_options.add_options (parser);
|
||||||
subset_options.add_options (parser);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void init (const face_options_t *face_opts)
|
void init (const face_options_t *face_opts)
|
||||||
{
|
{
|
||||||
face = hb_face_reference (face_opts->get_face ());
|
face = hb_face_reference (face_opts->get_face ());
|
||||||
input = hb_subset_input_reference (subset_options.get_input ());
|
input = hb_subset_input_reference (get_input ());
|
||||||
}
|
}
|
||||||
|
|
||||||
void consume_line (const char *text,
|
void consume_line (const char *text,
|
||||||
|
@ -102,7 +102,7 @@ struct subset_consumer_t
|
||||||
void finish (const face_options_t *face_opts)
|
void finish (const face_options_t *face_opts)
|
||||||
{
|
{
|
||||||
hb_face_t *new_face = nullptr;
|
hb_face_t *new_face = nullptr;
|
||||||
for (unsigned i = 0; i < subset_options.num_iterations; i++)
|
for (unsigned i = 0; i < num_iterations; i++)
|
||||||
{
|
{
|
||||||
hb_face_destroy (new_face);
|
hb_face_destroy (new_face);
|
||||||
new_face = hb_subset_or_fail (face, input);
|
new_face = hb_subset_or_fail (face, input);
|
||||||
|
@ -126,7 +126,6 @@ struct subset_consumer_t
|
||||||
|
|
||||||
private:
|
private:
|
||||||
output_options_t output_options;
|
output_options_t output_options;
|
||||||
subset_options_t subset_options;
|
|
||||||
|
|
||||||
hb_face_t *face = nullptr;
|
hb_face_t *face = nullptr;
|
||||||
hb_subset_input_t *input = nullptr;
|
hb_subset_input_t *input = nullptr;
|
||||||
|
|
|
@ -32,11 +32,11 @@
|
||||||
|
|
||||||
|
|
||||||
template <typename output_t>
|
template <typename output_t>
|
||||||
struct shape_consumer_t
|
struct shape_consumer_t : shape_options_t
|
||||||
{
|
{
|
||||||
void add_options (option_parser_t *parser)
|
void add_options (option_parser_t *parser)
|
||||||
{
|
{
|
||||||
shaper.add_options (parser);
|
shape_options_t::add_options (parser);
|
||||||
output.add_options (parser);
|
output.add_options (parser);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -55,14 +55,14 @@ struct shape_consumer_t
|
||||||
{
|
{
|
||||||
output.new_line ();
|
output.new_line ();
|
||||||
|
|
||||||
for (unsigned int n = shaper.num_iterations; n; n--)
|
for (unsigned int n = num_iterations; n; n--)
|
||||||
{
|
{
|
||||||
const char *error = nullptr;
|
const char *error = nullptr;
|
||||||
|
|
||||||
shaper.populate_buffer (buffer, text, text_len, text_before, text_after);
|
populate_buffer (buffer, text, text_len, text_before, text_after);
|
||||||
if (n == 1)
|
if (n == 1)
|
||||||
output.consume_text (buffer, text, text_len, shaper.utf8_clusters);
|
output.consume_text (buffer, text, text_len, utf8_clusters);
|
||||||
if (!shaper.shape (font, buffer, &error))
|
if (!shape (font, buffer, &error))
|
||||||
{
|
{
|
||||||
failed = true;
|
failed = true;
|
||||||
output.error (error);
|
output.error (error);
|
||||||
|
@ -73,7 +73,7 @@ struct shape_consumer_t
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
output.consume_glyphs (buffer, text, text_len, shaper.utf8_clusters);
|
output.consume_glyphs (buffer, text, text_len, utf8_clusters);
|
||||||
}
|
}
|
||||||
void finish (const font_options_t *font_opts)
|
void finish (const font_options_t *font_opts)
|
||||||
{
|
{
|
||||||
|
@ -88,7 +88,6 @@ struct shape_consumer_t
|
||||||
bool failed = false;
|
bool failed = false;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
shape_options_t shaper;
|
|
||||||
output_t output;
|
output_t output;
|
||||||
|
|
||||||
hb_font_t *font = nullptr;
|
hb_font_t *font = nullptr;
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
#include "helper-cairo.hh"
|
#include "helper-cairo.hh"
|
||||||
|
|
||||||
|
|
||||||
struct view_cairo_t
|
struct view_cairo_t : view_options_t
|
||||||
{
|
{
|
||||||
~view_cairo_t ()
|
~view_cairo_t ()
|
||||||
{
|
{
|
||||||
|
@ -41,8 +41,8 @@ struct view_cairo_t
|
||||||
|
|
||||||
void add_options (option_parser_t *parser)
|
void add_options (option_parser_t *parser)
|
||||||
{
|
{
|
||||||
|
view_options_t::add_options (parser);
|
||||||
output_options.add_options (parser, helper_cairo_supported_formats);
|
output_options.add_options (parser, helper_cairo_supported_formats);
|
||||||
view_options.add_options (parser);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void init (hb_buffer_t *buffer, const font_options_t *font_opts)
|
void init (hb_buffer_t *buffer, const font_options_t *font_opts)
|
||||||
|
@ -87,7 +87,6 @@ struct view_cairo_t
|
||||||
void render (const font_options_t *font_opts);
|
void render (const font_options_t *font_opts);
|
||||||
|
|
||||||
output_options_t output_options;
|
output_options_t output_options;
|
||||||
view_options_t view_options;
|
|
||||||
|
|
||||||
hb_direction_t direction = HB_DIRECTION_INVALID; // Remove this, make segment_properties accessible
|
hb_direction_t direction = HB_DIRECTION_INVALID; // Remove this, make segment_properties accessible
|
||||||
GArray *lines = nullptr;
|
GArray *lines = nullptr;
|
||||||
|
@ -106,24 +105,24 @@ view_cairo_t::render (const font_options_t *font_opts)
|
||||||
|
|
||||||
hb_font_t *font = font_opts->get_font();
|
hb_font_t *font = font_opts->get_font();
|
||||||
|
|
||||||
view_options_t::font_extents_t extents = view_options.font_extents;
|
if (!have_font_extents)
|
||||||
if (!view_options.have_font_extents)
|
|
||||||
{
|
{
|
||||||
hb_font_extents_t hb_extents;
|
hb_font_extents_t hb_extents;
|
||||||
hb_font_get_extents_for_direction (font, direction, &hb_extents);
|
hb_font_get_extents_for_direction (font, direction, &hb_extents);
|
||||||
extents.ascent = scalbn ((double) hb_extents.ascender, scale_bits);
|
font_extents.ascent = scalbn ((double) hb_extents.ascender, scale_bits);
|
||||||
extents.descent = -scalbn ((double) hb_extents.descender, scale_bits);
|
font_extents.descent = -scalbn ((double) hb_extents.descender, scale_bits);
|
||||||
extents.line_gap = scalbn ((double) hb_extents.line_gap, scale_bits);
|
font_extents.line_gap = scalbn ((double) hb_extents.line_gap, scale_bits);
|
||||||
|
have_font_extents = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
double ascent = y_sign * extents.ascent;
|
double ascent = y_sign * font_extents.ascent;
|
||||||
double descent = y_sign * extents.descent;
|
double descent = y_sign * font_extents.descent;
|
||||||
double line_gap = y_sign * extents.line_gap + view_options.line_space;
|
double line_gap = y_sign * font_extents.line_gap + line_space;
|
||||||
double leading = ascent + descent + line_gap;
|
double leading = ascent + descent + line_gap;
|
||||||
|
|
||||||
/* Calculate surface size. */
|
/* Calculate surface size. */
|
||||||
double w = 0, h = 0;
|
double w = 0, h = 0;
|
||||||
(vertical ? w : h) = (int) lines->len * leading - (extents.line_gap + view_options.line_space);
|
(vertical ? w : h) = (int) lines->len * leading - (font_extents.line_gap + line_space);
|
||||||
(vertical ? h : w) = 0;
|
(vertical ? h : w) = 0;
|
||||||
for (unsigned int i = 0; i < lines->len; i++) {
|
for (unsigned int i = 0; i < lines->len; i++) {
|
||||||
helper_cairo_line_t &line = g_array_index (lines, helper_cairo_line_t, i);
|
helper_cairo_line_t &line = g_array_index (lines, helper_cairo_line_t, i);
|
||||||
|
@ -143,13 +142,13 @@ view_cairo_t::render (const font_options_t *font_opts)
|
||||||
content = CAIRO_CONTENT_COLOR;
|
content = CAIRO_CONTENT_COLOR;
|
||||||
|
|
||||||
/* Create surface. */
|
/* Create surface. */
|
||||||
cairo_t *cr = helper_cairo_create_context (w + view_options.margin.l + view_options.margin.r,
|
cairo_t *cr = helper_cairo_create_context (w + margin.l + margin.r,
|
||||||
h + view_options.margin.t + view_options.margin.b,
|
h + margin.t + margin.b,
|
||||||
&view_options, &output_options, content);
|
static_cast<view_options_t *> (this), &output_options, content);
|
||||||
cairo_set_scaled_font (cr, scaled_font);
|
cairo_set_scaled_font (cr, scaled_font);
|
||||||
|
|
||||||
/* Setup coordinate system. */
|
/* Setup coordinate system. */
|
||||||
cairo_translate (cr, view_options.margin.l, view_options.margin.t);
|
cairo_translate (cr, margin.l, margin.t);
|
||||||
if (vertical)
|
if (vertical)
|
||||||
cairo_translate (cr,
|
cairo_translate (cr,
|
||||||
w - ascent, /* We currently always stack lines right to left */
|
w - ascent, /* We currently always stack lines right to left */
|
||||||
|
@ -169,7 +168,7 @@ view_cairo_t::render (const font_options_t *font_opts)
|
||||||
|
|
||||||
cairo_translate (cr, -vert * leading, +horiz * leading);
|
cairo_translate (cr, -vert * leading, +horiz * leading);
|
||||||
|
|
||||||
if (view_options.annotate) {
|
if (annotate) {
|
||||||
cairo_save (cr);
|
cairo_save (cr);
|
||||||
|
|
||||||
/* Draw actual glyph origins */
|
/* Draw actual glyph origins */
|
||||||
|
|
Loading…
Reference in New Issue