harfbuzz/src/hb-font.h

259 lines
7.0 KiB
C
Raw Normal View History

/*
* Copyright (C) 2009 Red Hat, Inc.
*
2010-04-22 06:11:43 +02:00
* This is part of HarfBuzz, a text shaping library.
*
* Permission is hereby granted, without written agreement and without
* license or royalty fees, to use, copy, modify, and distribute this
* software and its documentation for any purpose, provided that the
* above copyright notice and the following two paragraphs appear in
* all copies of this software.
*
* IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
* DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
* ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
* IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*
* THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
* ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
* PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
*
* Red Hat Author(s): Behdad Esfahbod
*/
#ifndef HB_FONT_H
#define HB_FONT_H
#include "hb-common.h"
2009-08-02 03:38:39 +02:00
#include "hb-blob.h"
HB_BEGIN_DECLS
2010-07-23 21:11:18 +02:00
2009-08-19 00:37:36 +02:00
typedef struct _hb_face_t hb_face_t;
typedef struct _hb_font_t hb_font_t;
2009-08-02 03:38:39 +02:00
/*
2009-08-11 02:05:16 +02:00
* hb_face_t
*/
2009-08-11 02:05:16 +02:00
hb_face_t *
hb_face_create_for_data (hb_blob_t *blob,
unsigned int index);
2009-08-11 02:05:16 +02:00
typedef hb_blob_t * (*hb_get_table_func_t) (hb_tag_t tag, void *user_data);
2009-08-19 20:45:24 +02:00
/* calls destroy() when not needing user_data anymore */
2009-08-11 02:05:16 +02:00
hb_face_t *
hb_face_create_for_tables (hb_get_table_func_t get_table,
void *user_data,
hb_destroy_func_t destroy);
2009-08-11 02:05:16 +02:00
hb_face_t *
hb_face_reference (hb_face_t *face);
void
2009-08-11 02:05:16 +02:00
hb_face_destroy (hb_face_t *face);
2010-10-04 23:22:57 +02:00
/* XXX
*
* I have two major concerns about this API as it is right now:
*
* - Jonathan Kew convinced me to make it return NULL if table not found (280af1bd),
* however, that is WRONG IMO. The API should not differentiate between a non-existing
* table vs a zero-length table vs a very short table. It only leads to implementations
* that check for non-NULL and assume that they've got a usable table going on... This
* actually happened with Firefox.
*/
2009-08-11 02:05:16 +02:00
hb_blob_t *
hb_face_reference_table (hb_face_t *face,
hb_tag_t tag);
2010-10-05 00:18:48 +02:00
unsigned int
hb_face_get_upem (hb_face_t *face);
/*
2009-08-11 02:05:16 +02:00
* hb_font_funcs_t
*/
2009-08-11 02:05:16 +02:00
typedef struct _hb_font_funcs_t hb_font_funcs_t;
hb_font_funcs_t *
hb_font_funcs_create (void);
2009-08-11 02:05:16 +02:00
hb_font_funcs_t *
hb_font_funcs_reference (hb_font_funcs_t *ffuncs);
void
2009-08-11 02:05:16 +02:00
hb_font_funcs_destroy (hb_font_funcs_t *ffuncs);
2009-08-11 02:05:16 +02:00
hb_font_funcs_t *
hb_font_funcs_copy (hb_font_funcs_t *ffuncs);
void
hb_font_funcs_make_immutable (hb_font_funcs_t *ffuncs);
hb_bool_t
hb_font_funcs_is_immutable (hb_font_funcs_t *ffuncs);
2009-08-19 00:37:36 +02:00
/* funcs */
typedef struct _hb_glyph_extents_t
2009-10-29 08:08:42 +01:00
{
hb_position_t x_bearing;
hb_position_t y_bearing;
2009-10-29 08:08:42 +01:00
hb_position_t width;
hb_position_t height;
} hb_glyph_extents_t;
2009-08-19 00:37:36 +02:00
typedef hb_codepoint_t (*hb_font_get_glyph_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
2009-11-04 21:48:32 +01:00
hb_codepoint_t unicode, hb_codepoint_t variation_selector);
typedef void (*hb_font_get_glyph_advance_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
hb_codepoint_t glyph,
hb_position_t *x_advance, hb_position_t *y_advance);
typedef void (*hb_font_get_glyph_extents_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
hb_codepoint_t glyph,
hb_glyph_extents_t *extents);
2009-08-19 00:37:36 +02:00
typedef hb_bool_t (*hb_font_get_contour_point_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
unsigned int point_index, hb_codepoint_t glyph,
hb_position_t *x, hb_position_t *y);
2009-08-19 00:37:36 +02:00
typedef hb_position_t (*hb_font_get_kerning_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
hb_codepoint_t first_glyph, hb_codepoint_t second_glyph);
void
2009-08-11 02:05:16 +02:00
hb_font_funcs_set_glyph_func (hb_font_funcs_t *ffuncs,
hb_font_get_glyph_func_t glyph_func);
void
hb_font_funcs_set_glyph_advance_func (hb_font_funcs_t *ffuncs,
hb_font_get_glyph_advance_func_t glyph_advance_func);
void
hb_font_funcs_set_glyph_extents_func (hb_font_funcs_t *ffuncs,
hb_font_get_glyph_extents_func_t glyph_extents_func);
void
hb_font_funcs_set_contour_point_func (hb_font_funcs_t *ffuncs,
hb_font_get_contour_point_func_t contour_point_func);
void
2009-08-11 02:05:16 +02:00
hb_font_funcs_set_kerning_func (hb_font_funcs_t *ffuncs,
hb_font_get_kerning_func_t kerning_func);
/* These never return NULL. Return fallback defaults instead. */
hb_font_get_glyph_func_t
hb_font_funcs_get_glyph_func (hb_font_funcs_t *ffuncs);
hb_font_get_glyph_advance_func_t
hb_font_funcs_get_glyph_advance_func (hb_font_funcs_t *ffuncs);
hb_font_get_glyph_extents_func_t
hb_font_funcs_get_glyph_extents_func (hb_font_funcs_t *ffuncs);
hb_font_get_contour_point_func_t
hb_font_funcs_get_contour_point_func (hb_font_funcs_t *ffuncs);
hb_font_get_kerning_func_t
hb_font_funcs_get_kerning_func (hb_font_funcs_t *ffuncs);
2009-11-05 19:55:41 +01:00
hb_codepoint_t
hb_font_get_glyph (hb_font_t *font, hb_face_t *face,
hb_codepoint_t unicode, hb_codepoint_t variation_selector);
void
hb_font_get_glyph_advance (hb_font_t *font, hb_face_t *face,
hb_codepoint_t glyph,
hb_position_t *x_advance, hb_position_t *y_advance);
2009-11-05 19:55:41 +01:00
void
hb_font_get_glyph_extents (hb_font_t *font, hb_face_t *face,
hb_codepoint_t glyph,
hb_glyph_extents_t *extents);
hb_bool_t
hb_font_get_contour_point (hb_font_t *font, hb_face_t *face,
unsigned int point_index, hb_codepoint_t glyph,
hb_position_t *x, hb_position_t *y);
2009-11-05 19:55:41 +01:00
hb_position_t
hb_font_get_kerning (hb_font_t *font, hb_face_t *face,
hb_codepoint_t first_glyph, hb_codepoint_t second_glyph);
/*
* hb_font_t
*/
/* Fonts are very light-weight objects */
hb_font_t *
2009-08-11 02:05:16 +02:00
hb_font_create (void);
hb_font_t *
hb_font_reference (hb_font_t *font);
void
hb_font_destroy (hb_font_t *font);
2009-08-11 02:05:16 +02:00
void
2009-11-04 00:34:20 +01:00
hb_font_set_funcs (hb_font_t *font,
hb_font_funcs_t *klass,
void *user_data,
hb_destroy_func_t destroy);
2009-08-02 23:41:36 +02:00
/* Returns what was set and unsets it, but doesn't destroy(user_data).
* This is useful for wrapping / chaining font_funcs_t's.
*
* The client is responsible for:
*
2010-10-04 23:22:57 +02:00
* - Take ownership of the reference on the returned klass,
*
* - Calling "destroy(user_data)" exactly once if returned destroy func
* is not NULL and the returned info is not needed anymore.
*/
void
hb_font_unset_funcs (hb_font_t *font,
hb_font_funcs_t **klass,
void **user_data,
hb_destroy_func_t *destroy);
2009-11-03 21:15:07 +01:00
/*
* We should add support for full matrices.
*/
void
hb_font_set_scale (hb_font_t *font,
int x_scale,
int y_scale);
void
hb_font_get_scale (hb_font_t *font,
int *x_scale,
int *y_scale);
/*
* A zero value means "no hinting in that direction"
*/
void
hb_font_set_ppem (hb_font_t *font,
unsigned int x_ppem,
unsigned int y_ppem);
void
hb_font_get_ppem (hb_font_t *font,
unsigned int *x_ppem,
unsigned int *y_ppem);
HB_END_DECLS
#endif /* HB_FONT_H */