< prev index next >

src/java.desktop/share/native/libfontmanager/harfbuzz/hb-font.hh

Print this page

        

*** 24,70 **** * * Red Hat Author(s): Behdad Esfahbod * Google Author(s): Behdad Esfahbod */ ! #ifndef HB_FONT_PRIVATE_HH ! #define HB_FONT_PRIVATE_HH ! #include "hb-private.hh" ! ! #include "hb-object-private.hh" ! #include "hb-face-private.hh" ! #include "hb-shaper-private.hh" /* * hb_font_funcs_t */ #define HB_FONT_FUNCS_IMPLEMENT_CALLBACKS \ HB_FONT_FUNC_IMPLEMENT (font_h_extents) \ HB_FONT_FUNC_IMPLEMENT (font_v_extents) \ HB_FONT_FUNC_IMPLEMENT (nominal_glyph) \ HB_FONT_FUNC_IMPLEMENT (variation_glyph) \ HB_FONT_FUNC_IMPLEMENT (glyph_h_advance) \ HB_FONT_FUNC_IMPLEMENT (glyph_v_advance) \ HB_FONT_FUNC_IMPLEMENT (glyph_h_origin) \ HB_FONT_FUNC_IMPLEMENT (glyph_v_origin) \ HB_FONT_FUNC_IMPLEMENT (glyph_h_kerning) \ HB_FONT_FUNC_IMPLEMENT (glyph_v_kerning) \ HB_FONT_FUNC_IMPLEMENT (glyph_extents) \ HB_FONT_FUNC_IMPLEMENT (glyph_contour_point) \ HB_FONT_FUNC_IMPLEMENT (glyph_name) \ HB_FONT_FUNC_IMPLEMENT (glyph_from_name) \ /* ^--- Add new callbacks here */ ! struct hb_font_funcs_t { hb_object_header_t header; - ASSERT_POD (); - - hb_bool_t immutable; struct { #define HB_FONT_FUNC_IMPLEMENT(name) void *name; HB_FONT_FUNCS_IMPLEMENT_CALLBACKS #undef HB_FONT_FUNC_IMPLEMENT --- 24,69 ---- * * Red Hat Author(s): Behdad Esfahbod * Google Author(s): Behdad Esfahbod */ ! #ifndef HB_FONT_HH ! #define HB_FONT_HH ! #include "hb.hh" + #include "hb-face.hh" + #include "hb-shaper.hh" /* * hb_font_funcs_t */ #define HB_FONT_FUNCS_IMPLEMENT_CALLBACKS \ HB_FONT_FUNC_IMPLEMENT (font_h_extents) \ HB_FONT_FUNC_IMPLEMENT (font_v_extents) \ HB_FONT_FUNC_IMPLEMENT (nominal_glyph) \ + HB_FONT_FUNC_IMPLEMENT (nominal_glyphs) \ HB_FONT_FUNC_IMPLEMENT (variation_glyph) \ HB_FONT_FUNC_IMPLEMENT (glyph_h_advance) \ HB_FONT_FUNC_IMPLEMENT (glyph_v_advance) \ + HB_FONT_FUNC_IMPLEMENT (glyph_h_advances) \ + HB_FONT_FUNC_IMPLEMENT (glyph_v_advances) \ HB_FONT_FUNC_IMPLEMENT (glyph_h_origin) \ HB_FONT_FUNC_IMPLEMENT (glyph_v_origin) \ HB_FONT_FUNC_IMPLEMENT (glyph_h_kerning) \ HB_FONT_FUNC_IMPLEMENT (glyph_v_kerning) \ HB_FONT_FUNC_IMPLEMENT (glyph_extents) \ HB_FONT_FUNC_IMPLEMENT (glyph_contour_point) \ HB_FONT_FUNC_IMPLEMENT (glyph_name) \ HB_FONT_FUNC_IMPLEMENT (glyph_from_name) \ /* ^--- Add new callbacks here */ ! struct hb_font_funcs_t ! { hb_object_header_t header; struct { #define HB_FONT_FUNC_IMPLEMENT(name) void *name; HB_FONT_FUNCS_IMPLEMENT_CALLBACKS #undef HB_FONT_FUNC_IMPLEMENT
*** 85,109 **** } f; void (*array[0 #define HB_FONT_FUNC_IMPLEMENT(name) +1 HB_FONT_FUNCS_IMPLEMENT_CALLBACKS #undef HB_FONT_FUNC_IMPLEMENT ! ]) (void); } get; }; ! /* * hb_font_t */ ! struct hb_font_t { ! hb_object_header_t header; ! ASSERT_POD (); ! hb_bool_t immutable; hb_font_t *parent; hb_face_t *face; int x_scale; --- 84,110 ---- } f; void (*array[0 #define HB_FONT_FUNC_IMPLEMENT(name) +1 HB_FONT_FUNCS_IMPLEMENT_CALLBACKS #undef HB_FONT_FUNC_IMPLEMENT ! ]) (); } get; }; ! DECLARE_NULL_INSTANCE (hb_font_funcs_t); /* * hb_font_t */ ! #define HB_SHAPER_IMPLEMENT(shaper) HB_SHAPER_DATA_INSTANTIATE_SHAPERS(shaper, font); ! #include "hb-shaper-list.hh" ! #undef HB_SHAPER_IMPLEMENT ! struct hb_font_t ! { ! hb_object_header_t header; hb_font_t *parent; hb_face_t *face; int x_scale;
*** 120,304 **** hb_font_funcs_t *klass; void *user_data; hb_destroy_func_t destroy; ! struct hb_shaper_data_t shaper_data; /* Convert from font-space to user-space */ ! inline int dir_scale (hb_direction_t direction) { return HB_DIRECTION_IS_VERTICAL(direction) ? y_scale : x_scale; } ! inline hb_position_t em_scale_x (int16_t v) { return em_scale (v, x_scale); } ! inline hb_position_t em_scale_y (int16_t v) { return em_scale (v, y_scale); } ! inline hb_position_t em_scalef_x (float v) { return em_scalef (v, this->x_scale); } ! inline hb_position_t em_scalef_y (float v) { return em_scalef (v, this->y_scale); } ! inline float em_fscale_x (int16_t v) { return em_fscale (v, x_scale); } ! inline float em_fscale_y (int16_t v) { return em_fscale (v, y_scale); } ! inline hb_position_t em_scale_dir (int16_t v, hb_direction_t direction) { return em_scale (v, dir_scale (direction)); } /* Convert from parent-font user-space to our user-space */ ! inline hb_position_t parent_scale_x_distance (hb_position_t v) { if (unlikely (parent && parent->x_scale != x_scale)) return (hb_position_t) (v * (int64_t) this->x_scale / this->parent->x_scale); return v; } ! inline hb_position_t parent_scale_y_distance (hb_position_t v) { if (unlikely (parent && parent->y_scale != y_scale)) return (hb_position_t) (v * (int64_t) this->y_scale / this->parent->y_scale); return v; } ! inline hb_position_t parent_scale_x_position (hb_position_t v) { ! return parent_scale_x_distance (v); ! } ! inline hb_position_t parent_scale_y_position (hb_position_t v) { ! return parent_scale_y_distance (v); ! } ! inline void parent_scale_distance (hb_position_t *x, hb_position_t *y) { *x = parent_scale_x_distance (*x); *y = parent_scale_y_distance (*y); } ! inline void parent_scale_position (hb_position_t *x, hb_position_t *y) { *x = parent_scale_x_position (*x); *y = parent_scale_y_position (*y); } /* Public getters */ HB_INTERNAL bool has_func (unsigned int i); /* has_* ... */ #define HB_FONT_FUNC_IMPLEMENT(name) \ bool \ ! has_##name##_func (void) \ { \ hb_font_funcs_t *funcs = this->klass; \ unsigned int i = offsetof (hb_font_funcs_t::get_t::get_funcs_t, name) / sizeof (funcs->get.array[0]); \ return has_func (i); \ } HB_FONT_FUNCS_IMPLEMENT_CALLBACKS #undef HB_FONT_FUNC_IMPLEMENT ! inline hb_bool_t get_font_h_extents (hb_font_extents_t *extents) { memset (extents, 0, sizeof (*extents)); return klass->get.f.font_h_extents (this, user_data, extents, klass->user_data.font_h_extents); } ! inline hb_bool_t get_font_v_extents (hb_font_extents_t *extents) { memset (extents, 0, sizeof (*extents)); return klass->get.f.font_v_extents (this, user_data, extents, klass->user_data.font_v_extents); } ! inline bool has_glyph (hb_codepoint_t unicode) { hb_codepoint_t glyph; return get_nominal_glyph (unicode, &glyph); } ! inline hb_bool_t get_nominal_glyph (hb_codepoint_t unicode, hb_codepoint_t *glyph) { *glyph = 0; return klass->get.f.nominal_glyph (this, user_data, unicode, glyph, klass->user_data.nominal_glyph); } ! inline hb_bool_t get_variation_glyph (hb_codepoint_t unicode, hb_codepoint_t variation_selector, hb_codepoint_t *glyph) { *glyph = 0; return klass->get.f.variation_glyph (this, user_data, unicode, variation_selector, glyph, klass->user_data.variation_glyph); } ! inline hb_position_t get_glyph_h_advance (hb_codepoint_t glyph) { return klass->get.f.glyph_h_advance (this, user_data, glyph, klass->user_data.glyph_h_advance); } ! inline hb_position_t get_glyph_v_advance (hb_codepoint_t glyph) { return klass->get.f.glyph_v_advance (this, user_data, glyph, klass->user_data.glyph_v_advance); } ! inline hb_bool_t get_glyph_h_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { *x = *y = 0; return klass->get.f.glyph_h_origin (this, user_data, glyph, x, y, klass->user_data.glyph_h_origin); } ! inline hb_bool_t get_glyph_v_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { *x = *y = 0; return klass->get.f.glyph_v_origin (this, user_data, glyph, x, y, klass->user_data.glyph_v_origin); } ! inline hb_position_t get_glyph_h_kerning (hb_codepoint_t left_glyph, hb_codepoint_t right_glyph) { return klass->get.f.glyph_h_kerning (this, user_data, left_glyph, right_glyph, klass->user_data.glyph_h_kerning); } ! inline hb_position_t get_glyph_v_kerning (hb_codepoint_t top_glyph, hb_codepoint_t bottom_glyph) { return klass->get.f.glyph_v_kerning (this, user_data, top_glyph, bottom_glyph, klass->user_data.glyph_v_kerning); } ! inline hb_bool_t get_glyph_extents (hb_codepoint_t glyph, hb_glyph_extents_t *extents) { memset (extents, 0, sizeof (*extents)); return klass->get.f.glyph_extents (this, user_data, glyph, extents, klass->user_data.glyph_extents); } ! inline hb_bool_t get_glyph_contour_point (hb_codepoint_t glyph, unsigned int point_index, hb_position_t *x, hb_position_t *y) { *x = *y = 0; return klass->get.f.glyph_contour_point (this, user_data, glyph, point_index, x, y, klass->user_data.glyph_contour_point); } ! inline hb_bool_t get_glyph_name (hb_codepoint_t glyph, char *name, unsigned int size) { if (size) *name = '\0'; return klass->get.f.glyph_name (this, user_data, glyph, name, size, klass->user_data.glyph_name); } ! inline hb_bool_t get_glyph_from_name (const char *name, int len, /* -1 means nul-terminated */ hb_codepoint_t *glyph) { *glyph = 0; if (len == -1) len = strlen (name); return klass->get.f.glyph_from_name (this, user_data, --- 121,355 ---- hb_font_funcs_t *klass; void *user_data; hb_destroy_func_t destroy; ! hb_shaper_object_dataset_t<hb_font_t> data; /* Various shaper data. */ /* Convert from font-space to user-space */ ! int dir_scale (hb_direction_t direction) { return HB_DIRECTION_IS_VERTICAL(direction) ? y_scale : x_scale; } ! hb_position_t em_scale_x (int16_t v) { return em_scale (v, x_scale); } ! hb_position_t em_scale_y (int16_t v) { return em_scale (v, y_scale); } ! hb_position_t em_scalef_x (float v) { return em_scalef (v, this->x_scale); } ! hb_position_t em_scalef_y (float v) { return em_scalef (v, this->y_scale); } ! float em_fscale_x (int16_t v) { return em_fscale (v, x_scale); } ! float em_fscale_y (int16_t v) { return em_fscale (v, y_scale); } ! hb_position_t em_scale_dir (int16_t v, hb_direction_t direction) { return em_scale (v, dir_scale (direction)); } /* Convert from parent-font user-space to our user-space */ ! hb_position_t parent_scale_x_distance (hb_position_t v) ! { if (unlikely (parent && parent->x_scale != x_scale)) return (hb_position_t) (v * (int64_t) this->x_scale / this->parent->x_scale); return v; } ! hb_position_t parent_scale_y_distance (hb_position_t v) ! { if (unlikely (parent && parent->y_scale != y_scale)) return (hb_position_t) (v * (int64_t) this->y_scale / this->parent->y_scale); return v; } ! hb_position_t parent_scale_x_position (hb_position_t v) ! { return parent_scale_x_distance (v); } ! hb_position_t parent_scale_y_position (hb_position_t v) ! { return parent_scale_y_distance (v); } ! void parent_scale_distance (hb_position_t *x, hb_position_t *y) ! { *x = parent_scale_x_distance (*x); *y = parent_scale_y_distance (*y); } ! void parent_scale_position (hb_position_t *x, hb_position_t *y) ! { *x = parent_scale_x_position (*x); *y = parent_scale_y_position (*y); } /* Public getters */ HB_INTERNAL bool has_func (unsigned int i); + HB_INTERNAL bool has_func_set (unsigned int i); /* has_* ... */ #define HB_FONT_FUNC_IMPLEMENT(name) \ bool \ ! has_##name##_func () \ { \ hb_font_funcs_t *funcs = this->klass; \ unsigned int i = offsetof (hb_font_funcs_t::get_t::get_funcs_t, name) / sizeof (funcs->get.array[0]); \ return has_func (i); \ + } \ + bool \ + has_##name##_func_set () \ + { \ + hb_font_funcs_t *funcs = this->klass; \ + unsigned int i = offsetof (hb_font_funcs_t::get_t::get_funcs_t, name) / sizeof (funcs->get.array[0]); \ + return has_func_set (i); \ } HB_FONT_FUNCS_IMPLEMENT_CALLBACKS #undef HB_FONT_FUNC_IMPLEMENT ! hb_bool_t get_font_h_extents (hb_font_extents_t *extents) { memset (extents, 0, sizeof (*extents)); return klass->get.f.font_h_extents (this, user_data, extents, klass->user_data.font_h_extents); } ! hb_bool_t get_font_v_extents (hb_font_extents_t *extents) { memset (extents, 0, sizeof (*extents)); return klass->get.f.font_v_extents (this, user_data, extents, klass->user_data.font_v_extents); } ! bool has_glyph (hb_codepoint_t unicode) { hb_codepoint_t glyph; return get_nominal_glyph (unicode, &glyph); } ! hb_bool_t get_nominal_glyph (hb_codepoint_t unicode, hb_codepoint_t *glyph) { *glyph = 0; return klass->get.f.nominal_glyph (this, user_data, unicode, glyph, klass->user_data.nominal_glyph); } + unsigned int get_nominal_glyphs (unsigned int count, + const hb_codepoint_t *first_unicode, + unsigned int unicode_stride, + hb_codepoint_t *first_glyph, + unsigned int glyph_stride) + { + return klass->get.f.nominal_glyphs (this, user_data, + count, + first_unicode, unicode_stride, + first_glyph, glyph_stride, + klass->user_data.nominal_glyphs); + } ! hb_bool_t get_variation_glyph (hb_codepoint_t unicode, hb_codepoint_t variation_selector, hb_codepoint_t *glyph) { *glyph = 0; return klass->get.f.variation_glyph (this, user_data, unicode, variation_selector, glyph, klass->user_data.variation_glyph); } ! hb_position_t get_glyph_h_advance (hb_codepoint_t glyph) { return klass->get.f.glyph_h_advance (this, user_data, glyph, klass->user_data.glyph_h_advance); } ! hb_position_t get_glyph_v_advance (hb_codepoint_t glyph) { return klass->get.f.glyph_v_advance (this, user_data, glyph, klass->user_data.glyph_v_advance); } ! void get_glyph_h_advances (unsigned int count, ! const hb_codepoint_t *first_glyph, ! unsigned int glyph_stride, ! hb_position_t *first_advance, ! unsigned int advance_stride) ! { ! return klass->get.f.glyph_h_advances (this, user_data, ! count, ! first_glyph, glyph_stride, ! first_advance, advance_stride, ! klass->user_data.glyph_h_advances); ! } ! ! void get_glyph_v_advances (unsigned int count, ! const hb_codepoint_t *first_glyph, ! unsigned int glyph_stride, ! hb_position_t *first_advance, ! unsigned int advance_stride) ! { ! return klass->get.f.glyph_v_advances (this, user_data, ! count, ! first_glyph, glyph_stride, ! first_advance, advance_stride, ! klass->user_data.glyph_v_advances); ! } ! ! hb_bool_t get_glyph_h_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { *x = *y = 0; return klass->get.f.glyph_h_origin (this, user_data, glyph, x, y, klass->user_data.glyph_h_origin); } ! hb_bool_t get_glyph_v_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { *x = *y = 0; return klass->get.f.glyph_v_origin (this, user_data, glyph, x, y, klass->user_data.glyph_v_origin); } ! hb_position_t get_glyph_h_kerning (hb_codepoint_t left_glyph, ! hb_codepoint_t right_glyph) { return klass->get.f.glyph_h_kerning (this, user_data, left_glyph, right_glyph, klass->user_data.glyph_h_kerning); } ! hb_position_t get_glyph_v_kerning (hb_codepoint_t top_glyph, ! hb_codepoint_t bottom_glyph) { return klass->get.f.glyph_v_kerning (this, user_data, top_glyph, bottom_glyph, klass->user_data.glyph_v_kerning); } ! hb_bool_t get_glyph_extents (hb_codepoint_t glyph, hb_glyph_extents_t *extents) { memset (extents, 0, sizeof (*extents)); return klass->get.f.glyph_extents (this, user_data, glyph, extents, klass->user_data.glyph_extents); } ! hb_bool_t get_glyph_contour_point (hb_codepoint_t glyph, unsigned int point_index, hb_position_t *x, hb_position_t *y) { *x = *y = 0; return klass->get.f.glyph_contour_point (this, user_data, glyph, point_index, x, y, klass->user_data.glyph_contour_point); } ! hb_bool_t get_glyph_name (hb_codepoint_t glyph, char *name, unsigned int size) { if (size) *name = '\0'; return klass->get.f.glyph_name (this, user_data, glyph, name, size, klass->user_data.glyph_name); } ! hb_bool_t get_glyph_from_name (const char *name, int len, /* -1 means nul-terminated */ hb_codepoint_t *glyph) { *glyph = 0; if (len == -1) len = strlen (name); return klass->get.f.glyph_from_name (this, user_data,
*** 308,381 **** } /* A bit higher-level, and with fallback */ ! inline void get_h_extents_with_fallback (hb_font_extents_t *extents) { if (!get_font_h_extents (extents)) { extents->ascender = y_scale * .8; extents->descender = extents->ascender - y_scale; extents->line_gap = 0; } } ! inline void get_v_extents_with_fallback (hb_font_extents_t *extents) { if (!get_font_v_extents (extents)) { extents->ascender = x_scale / 2; extents->descender = extents->ascender - x_scale; extents->line_gap = 0; } } ! inline void get_extents_for_direction (hb_direction_t direction, hb_font_extents_t *extents) { if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) get_h_extents_with_fallback (extents); else get_v_extents_with_fallback (extents); } ! inline void get_glyph_advance_for_direction (hb_codepoint_t glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { ! if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) { *x = get_glyph_h_advance (glyph); ! *y = 0; ! } else { ! *x = 0; *y = get_glyph_v_advance (glyph); } } ! inline void guess_v_origin_minus_h_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { *x = get_glyph_h_advance (glyph) / 2; /* TODO cache this somehow?! */ hb_font_extents_t extents; get_h_extents_with_fallback (&extents); *y = extents.ascender; } ! inline void get_glyph_h_origin_with_fallback (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { if (!get_glyph_h_origin (glyph, x, y) && get_glyph_v_origin (glyph, x, y)) { hb_position_t dx, dy; guess_v_origin_minus_h_origin (glyph, &dx, &dy); *x -= dx; *y -= dy; } } ! inline void get_glyph_v_origin_with_fallback (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { if (!get_glyph_v_origin (glyph, x, y) && get_glyph_h_origin (glyph, x, y)) { --- 359,442 ---- } /* A bit higher-level, and with fallback */ ! void get_h_extents_with_fallback (hb_font_extents_t *extents) { if (!get_font_h_extents (extents)) { extents->ascender = y_scale * .8; extents->descender = extents->ascender - y_scale; extents->line_gap = 0; } } ! void get_v_extents_with_fallback (hb_font_extents_t *extents) { if (!get_font_v_extents (extents)) { extents->ascender = x_scale / 2; extents->descender = extents->ascender - x_scale; extents->line_gap = 0; } } ! void get_extents_for_direction (hb_direction_t direction, hb_font_extents_t *extents) { if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) get_h_extents_with_fallback (extents); else get_v_extents_with_fallback (extents); } ! void get_glyph_advance_for_direction (hb_codepoint_t glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { ! *x = *y = 0; ! if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) *x = get_glyph_h_advance (glyph); ! else *y = get_glyph_v_advance (glyph); } + void get_glyph_advances_for_direction (hb_direction_t direction, + unsigned int count, + const hb_codepoint_t *first_glyph, + unsigned glyph_stride, + hb_position_t *first_advance, + unsigned advance_stride) + { + if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) + get_glyph_h_advances (count, first_glyph, glyph_stride, first_advance, advance_stride); + else + get_glyph_v_advances (count, first_glyph, glyph_stride, first_advance, advance_stride); } ! void guess_v_origin_minus_h_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { *x = get_glyph_h_advance (glyph) / 2; /* TODO cache this somehow?! */ hb_font_extents_t extents; get_h_extents_with_fallback (&extents); *y = extents.ascender; } ! void get_glyph_h_origin_with_fallback (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { if (!get_glyph_h_origin (glyph, x, y) && get_glyph_v_origin (glyph, x, y)) { hb_position_t dx, dy; guess_v_origin_minus_h_origin (glyph, &dx, &dy); *x -= dx; *y -= dy; } } ! void get_glyph_v_origin_with_fallback (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { if (!get_glyph_v_origin (glyph, x, y) && get_glyph_h_origin (glyph, x, y)) {
*** 383,423 **** guess_v_origin_minus_h_origin (glyph, &dx, &dy); *x += dx; *y += dy; } } ! inline void get_glyph_origin_for_direction (hb_codepoint_t glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) get_glyph_h_origin_with_fallback (glyph, x, y); else get_glyph_v_origin_with_fallback (glyph, x, y); } ! inline void add_glyph_h_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; get_glyph_h_origin_with_fallback (glyph, &origin_x, &origin_y); *x += origin_x; *y += origin_y; } ! inline void add_glyph_v_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; get_glyph_v_origin_with_fallback (glyph, &origin_x, &origin_y); *x += origin_x; *y += origin_y; } ! inline void add_glyph_origin_for_direction (hb_codepoint_t glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; --- 444,484 ---- guess_v_origin_minus_h_origin (glyph, &dx, &dy); *x += dx; *y += dy; } } ! void get_glyph_origin_for_direction (hb_codepoint_t glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) get_glyph_h_origin_with_fallback (glyph, x, y); else get_glyph_v_origin_with_fallback (glyph, x, y); } ! void add_glyph_h_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; get_glyph_h_origin_with_fallback (glyph, &origin_x, &origin_y); *x += origin_x; *y += origin_y; } ! void add_glyph_v_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; get_glyph_v_origin_with_fallback (glyph, &origin_x, &origin_y); *x += origin_x; *y += origin_y; } ! void add_glyph_origin_for_direction (hb_codepoint_t glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y;
*** 425,455 **** *x += origin_x; *y += origin_y; } ! inline void subtract_glyph_h_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; get_glyph_h_origin_with_fallback (glyph, &origin_x, &origin_y); *x -= origin_x; *y -= origin_y; } ! inline void subtract_glyph_v_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; get_glyph_v_origin_with_fallback (glyph, &origin_x, &origin_y); *x -= origin_x; *y -= origin_y; } ! inline void subtract_glyph_origin_for_direction (hb_codepoint_t glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; --- 486,516 ---- *x += origin_x; *y += origin_y; } ! void subtract_glyph_h_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; get_glyph_h_origin_with_fallback (glyph, &origin_x, &origin_y); *x -= origin_x; *y -= origin_y; } ! void subtract_glyph_v_origin (hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y; get_glyph_v_origin_with_fallback (glyph, &origin_x, &origin_y); *x -= origin_x; *y -= origin_y; } ! void subtract_glyph_origin_for_direction (hb_codepoint_t glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { hb_position_t origin_x, origin_y;
*** 457,480 **** *x -= origin_x; *y -= origin_y; } ! inline void get_glyph_kerning_for_direction (hb_codepoint_t first_glyph, hb_codepoint_t second_glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) { - *x = get_glyph_h_kerning (first_glyph, second_glyph); *y = 0; } else { *x = 0; *y = get_glyph_v_kerning (first_glyph, second_glyph); } } ! inline hb_bool_t get_glyph_extents_for_origin (hb_codepoint_t glyph, hb_direction_t direction, hb_glyph_extents_t *extents) { hb_bool_t ret = get_glyph_extents (glyph, extents); --- 518,541 ---- *x -= origin_x; *y -= origin_y; } ! void get_glyph_kerning_for_direction (hb_codepoint_t first_glyph, hb_codepoint_t second_glyph, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { if (likely (HB_DIRECTION_IS_HORIZONTAL (direction))) { *y = 0; + *x = get_glyph_h_kerning (first_glyph, second_glyph); } else { *x = 0; *y = get_glyph_v_kerning (first_glyph, second_glyph); } } ! hb_bool_t get_glyph_extents_for_origin (hb_codepoint_t glyph, hb_direction_t direction, hb_glyph_extents_t *extents) { hb_bool_t ret = get_glyph_extents (glyph, extents);
*** 482,492 **** subtract_glyph_origin_for_direction (glyph, direction, &extents->x_bearing, &extents->y_bearing); return ret; } ! inline hb_bool_t get_glyph_contour_point_for_origin (hb_codepoint_t glyph, unsigned int point_index, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { hb_bool_t ret = get_glyph_contour_point (glyph, point_index, x, y); --- 543,553 ---- subtract_glyph_origin_for_direction (glyph, direction, &extents->x_bearing, &extents->y_bearing); return ret; } ! hb_bool_t get_glyph_contour_point_for_origin (hb_codepoint_t glyph, unsigned int point_index, hb_direction_t direction, hb_position_t *x, hb_position_t *y) { hb_bool_t ret = get_glyph_contour_point (glyph, point_index, x, y);
*** 495,516 **** return ret; } /* Generates gidDDD if glyph has no name. */ ! inline void glyph_to_string (hb_codepoint_t glyph, char *s, unsigned int size) { if (get_glyph_name (glyph, s, size)) return; if (size && snprintf (s, size, "gid%u", glyph) < 0) *s = '\0'; } /* Parses gidDDD and uniUUUU strings automatically. */ ! inline hb_bool_t glyph_from_string (const char *s, int len, /* -1 means nul-terminated */ hb_codepoint_t *glyph) { if (get_glyph_from_name (s, len, glyph)) return true; --- 556,577 ---- return ret; } /* Generates gidDDD if glyph has no name. */ ! void glyph_to_string (hb_codepoint_t glyph, char *s, unsigned int size) { if (get_glyph_name (glyph, s, size)) return; if (size && snprintf (s, size, "gid%u", glyph) < 0) *s = '\0'; } /* Parses gidDDD and uniUUUU strings automatically. */ ! hb_bool_t glyph_from_string (const char *s, int len, /* -1 means nul-terminated */ hb_codepoint_t *glyph) { if (get_glyph_from_name (s, len, glyph)) return true;
*** 536,565 **** } return false; } ! inline hb_position_t em_scale (int16_t v, int scale) { int upem = face->get_upem (); int64_t scaled = v * (int64_t) scale; scaled += scaled >= 0 ? upem/2 : -upem/2; /* Round. */ return (hb_position_t) (scaled / upem); } ! inline hb_position_t em_scalef (float v, int scale) ! { ! return (hb_position_t) round (v * scale / face->get_upem ()); ! } ! inline float em_fscale (int16_t v, int scale) ! { ! return (float) v * scale / face->get_upem (); ! } }; ! ! #define HB_SHAPER_DATA_CREATE_FUNC_EXTRA_ARGS ! #define HB_SHAPER_IMPLEMENT(shaper) HB_SHAPER_DATA_PROTOTYPE(shaper, font); ! #include "hb-shaper-list.hh" ! #undef HB_SHAPER_IMPLEMENT ! #undef HB_SHAPER_DATA_CREATE_FUNC_EXTRA_ARGS ! #endif /* HB_FONT_PRIVATE_HH */ --- 597,617 ---- } return false; } ! hb_position_t em_scale (int16_t v, int scale) { int upem = face->get_upem (); int64_t scaled = v * (int64_t) scale; scaled += scaled >= 0 ? upem/2 : -upem/2; /* Round. */ return (hb_position_t) (scaled / upem); } ! hb_position_t em_scalef (float v, int scale) ! { return (hb_position_t) round (v * scale / face->get_upem ()); } ! float em_fscale (int16_t v, int scale) ! { return (float) v * scale / face->get_upem (); } }; ! DECLARE_NULL_INSTANCE (hb_font_t); ! #endif /* HB_FONT_HH */
< prev index next >