2009-08-02 01:54:49 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2009 Red Hat, Inc.
|
|
|
|
*
|
2010-04-22 06:11:43 +02:00
|
|
|
* This is part of HarfBuzz, a text shaping library.
|
2009-08-02 01:54:49 +02:00
|
|
|
*
|
|
|
|
* 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"
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
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-02 01:54:49 +02:00
|
|
|
/*
|
2009-08-11 02:05:16 +02:00
|
|
|
* hb_face_t
|
2009-08-02 01:54:49 +02:00
|
|
|
*/
|
|
|
|
|
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-02 01:54:49 +02:00
|
|
|
|
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-02 01:54:49 +02:00
|
|
|
|
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,
|
|
|
|
hb_destroy_func_t destroy,
|
|
|
|
void *user_data);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_face_t *
|
|
|
|
hb_face_reference (hb_face_t *face);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
2009-08-11 02:05:16 +02:00
|
|
|
unsigned int
|
|
|
|
hb_face_get_reference_count (hb_face_t *face);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
void
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_face_destroy (hb_face_t *face);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
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.
|
|
|
|
*
|
|
|
|
* - It has to be renamed to reference_table() since unlike any other _get_ API, a reference
|
|
|
|
* ownership transfer happens and the user is responsible to destroy the result.
|
|
|
|
*/
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_blob_t *
|
|
|
|
hb_face_get_table (hb_face_t *face,
|
|
|
|
hb_tag_t tag);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
2010-10-05 00:18:48 +02:00
|
|
|
unsigned int
|
|
|
|
hb_face_get_upem (hb_face_t *face);
|
|
|
|
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
/*
|
2009-08-11 02:05:16 +02:00
|
|
|
* hb_font_funcs_t
|
2009-08-02 01:54:49 +02:00
|
|
|
*/
|
|
|
|
|
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-02 01:54:49 +02:00
|
|
|
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_font_funcs_t *
|
|
|
|
hb_font_funcs_reference (hb_font_funcs_t *ffuncs);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
2009-08-02 03:36:15 +02:00
|
|
|
unsigned int
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_font_funcs_get_reference_count (hb_font_funcs_t *ffuncs);
|
2009-08-02 03:36:15 +02:00
|
|
|
|
2009-08-02 01:54:49 +02:00
|
|
|
void
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_font_funcs_destroy (hb_font_funcs_t *ffuncs);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_font_funcs_t *
|
|
|
|
hb_font_funcs_copy (hb_font_funcs_t *ffuncs);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
2009-08-11 05:50:51 +02:00
|
|
|
void
|
|
|
|
hb_font_funcs_make_immutable (hb_font_funcs_t *ffuncs);
|
|
|
|
|
2010-10-04 23:01:01 +02:00
|
|
|
hb_bool_t
|
|
|
|
hb_font_funcs_is_immutable (hb_font_funcs_t *ffuncs);
|
2009-08-19 00:37:36 +02:00
|
|
|
|
|
|
|
/* funcs */
|
|
|
|
|
2009-11-04 02:27:05 +01:00
|
|
|
typedef struct _hb_glyph_metrics_t
|
2009-10-29 08:08:42 +01:00
|
|
|
{
|
|
|
|
hb_position_t x_advance;
|
|
|
|
hb_position_t y_advance;
|
2009-11-05 18:20:11 +01:00
|
|
|
hb_position_t x_offset;
|
|
|
|
hb_position_t y_offset;
|
2009-10-29 08:08:42 +01:00
|
|
|
hb_position_t width;
|
|
|
|
hb_position_t height;
|
2009-11-04 02:27:05 +01:00
|
|
|
} hb_glyph_metrics_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);
|
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,
|
2009-10-29 08:05:18 +01:00
|
|
|
unsigned int point_index,
|
2009-08-19 00:37:36 +02:00
|
|
|
hb_codepoint_t glyph, hb_position_t *x, hb_position_t *y);
|
|
|
|
typedef void (*hb_font_get_glyph_metrics_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
|
|
|
|
hb_codepoint_t glyph, hb_glyph_metrics_t *metrics);
|
|
|
|
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);
|
|
|
|
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
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);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
void
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_font_funcs_set_contour_point_func (hb_font_funcs_t *ffuncs,
|
|
|
|
hb_font_get_contour_point_func_t contour_point_func);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
void
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_font_funcs_set_glyph_metrics_func (hb_font_funcs_t *ffuncs,
|
|
|
|
hb_font_get_glyph_metrics_func_t glyph_metrics_func);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
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);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
|
2010-10-04 22:45:21 +02:00
|
|
|
/* 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_contour_point_func_t
|
|
|
|
hb_font_funcs_get_contour_point_func (hb_font_funcs_t *ffuncs);
|
|
|
|
|
|
|
|
hb_font_get_glyph_metrics_func_t
|
|
|
|
hb_font_funcs_get_glyph_metrics_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);
|
|
|
|
|
|
|
|
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);
|
|
|
|
|
|
|
|
void
|
|
|
|
hb_font_get_glyph_metrics (hb_font_t *font, hb_face_t *face,
|
|
|
|
hb_codepoint_t glyph, hb_glyph_metrics_t *metrics);
|
|
|
|
|
|
|
|
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);
|
|
|
|
|
|
|
|
|
2009-08-02 01:54:49 +02:00
|
|
|
/*
|
|
|
|
* hb_font_t
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Fonts are very light-weight objects */
|
|
|
|
|
|
|
|
hb_font_t *
|
2009-08-11 02:05:16 +02:00
|
|
|
hb_font_create (void);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
hb_font_t *
|
|
|
|
hb_font_reference (hb_font_t *font);
|
|
|
|
|
2009-08-02 03:36:15 +02:00
|
|
|
unsigned int
|
|
|
|
hb_font_get_reference_count (hb_font_t *font);
|
|
|
|
|
2009-08-02 01:54:49 +02:00
|
|
|
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,
|
|
|
|
hb_destroy_func_t destroy,
|
|
|
|
void *user_data);
|
2009-08-02 23:41:36 +02:00
|
|
|
|
2010-10-04 22:45:21 +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,
|
|
|
|
*
|
2010-10-04 22:45:21 +02:00
|
|
|
* - 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,
|
|
|
|
hb_destroy_func_t *destroy,
|
|
|
|
void **user_data);
|
|
|
|
|
2009-11-03 21:15:07 +01:00
|
|
|
|
2009-08-02 01:54:49 +02:00
|
|
|
/*
|
2010-05-19 21:45:06 +02:00
|
|
|
* We should add support for full matrices.
|
2009-08-02 01:54:49 +02:00
|
|
|
*/
|
|
|
|
void
|
|
|
|
hb_font_set_scale (hb_font_t *font,
|
2010-05-19 21:45:06 +02:00
|
|
|
unsigned int x_scale,
|
|
|
|
unsigned int y_scale);
|
2009-08-02 01:54:49 +02:00
|
|
|
|
2010-10-04 22:45:21 +02:00
|
|
|
void
|
|
|
|
hb_font_get_scale (hb_font_t *font,
|
|
|
|
unsigned int *x_scale,
|
|
|
|
unsigned int *y_scale);
|
|
|
|
|
2009-08-02 01:54:49 +02:00
|
|
|
/*
|
|
|
|
* 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);
|
|
|
|
|
2010-10-04 22:45:21 +02:00
|
|
|
void
|
|
|
|
hb_font_get_ppem (hb_font_t *font,
|
|
|
|
unsigned int *x_ppem,
|
|
|
|
unsigned int *y_ppem);
|
|
|
|
|
2009-08-02 01:54:49 +02:00
|
|
|
|
|
|
|
HB_END_DECLS
|
|
|
|
|
|
|
|
#endif /* HB_FONT_H */
|