hb-buffer.h 10.6 KB
Newer Older
1
/*
B
Behdad Esfahbod 已提交
2 3
 * Copyright © 1998-2004  David Turner and Werner Lemberg
 * Copyright © 2004,2007,2009  Red Hat, Inc.
4
 * Copyright © 2011,2012  Google, Inc.
5
 *
6
 *  This is part of HarfBuzz, a text shaping library.
7
 *
8 9 10 11 12
 * 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.
13
 *
14 15 16 17 18 19 20 21 22 23 24 25 26
 * 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): Owen Taylor, Behdad Esfahbod
27
 * Google Author(s): Behdad Esfahbod
28
 */
29

30 31 32 33
#ifndef HB_H_IN
#error "Include <hb.h> instead."
#endif

34 35
#ifndef HB_BUFFER_H
#define HB_BUFFER_H
36

37
#include "hb-common.h"
B
Behdad Esfahbod 已提交
38
#include "hb-unicode.h"
39
#include "hb-font.h"
40

B
Behdad Esfahbod 已提交
41
HB_BEGIN_DECLS
42

B
Behdad Esfahbod 已提交
43

44
typedef struct hb_glyph_info_t {
45
  hb_codepoint_t codepoint;
46
  hb_mask_t      mask;
47
  uint32_t       cluster;
48 49

  /*< private >*/
B
Behdad Esfahbod 已提交
50 51
  hb_var_int_t   var1;
  hb_var_int_t   var2;
B
Behdad Esfahbod 已提交
52
} hb_glyph_info_t;
53

54
typedef struct hb_glyph_position_t {
55 56
  hb_position_t  x_advance;
  hb_position_t  y_advance;
57 58
  hb_position_t  x_offset;
  hb_position_t  y_offset;
59 60

  /*< private >*/
61
  hb_var_int_t   var;
B
Behdad Esfahbod 已提交
62
} hb_glyph_position_t;
63 64


65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
typedef struct hb_segment_properties_t {
  hb_direction_t  direction;
  hb_script_t     script;
  hb_language_t   language;
  /*< private >*/
  void           *reserved1;
  void           *reserved2;
} hb_segment_properties_t;

#define HB_SEGMENT_PROPERTIES_DEFAULT {HB_DIRECTION_INVALID, \
				       HB_SCRIPT_INVALID, \
				       HB_LANGUAGE_INVALID, \
				       NULL, \
				       NULL}

80
HB_EXTERN hb_bool_t
81 82 83
hb_segment_properties_equal (const hb_segment_properties_t *a,
			     const hb_segment_properties_t *b);

84
HB_EXTERN unsigned int
85 86 87 88 89 90 91 92 93 94
hb_segment_properties_hash (const hb_segment_properties_t *p);



/*
 * hb_buffer_t
 */

typedef struct hb_buffer_t hb_buffer_t;

95
HB_EXTERN hb_buffer_t *
96
hb_buffer_create (void);
97

98
HB_EXTERN hb_buffer_t *
99 100
hb_buffer_get_empty (void);

101
HB_EXTERN hb_buffer_t *
102
hb_buffer_reference (hb_buffer_t *buffer);
103

104
HB_EXTERN void
105
hb_buffer_destroy (hb_buffer_t *buffer);
106

107
HB_EXTERN hb_bool_t
108 109 110
hb_buffer_set_user_data (hb_buffer_t        *buffer,
			 hb_user_data_key_t *key,
			 void *              data,
111 112
			 hb_destroy_func_t   destroy,
			 hb_bool_t           replace);
113

114
HB_EXTERN void *
115 116 117
hb_buffer_get_user_data (hb_buffer_t        *buffer,
			 hb_user_data_key_t *key);

118

B
Minor  
Behdad Esfahbod 已提交
119 120 121 122 123 124
typedef enum {
  HB_BUFFER_CONTENT_TYPE_INVALID = 0,
  HB_BUFFER_CONTENT_TYPE_UNICODE,
  HB_BUFFER_CONTENT_TYPE_GLYPHS
} hb_buffer_content_type_t;

125
HB_EXTERN void
126 127 128
hb_buffer_set_content_type (hb_buffer_t              *buffer,
			    hb_buffer_content_type_t  content_type);

129
HB_EXTERN hb_buffer_content_type_t
130 131 132
hb_buffer_get_content_type (hb_buffer_t *buffer);


133
HB_EXTERN void
B
Behdad Esfahbod 已提交
134 135 136
hb_buffer_set_unicode_funcs (hb_buffer_t        *buffer,
			     hb_unicode_funcs_t *unicode_funcs);

137
HB_EXTERN hb_unicode_funcs_t *
B
Behdad Esfahbod 已提交
138 139
hb_buffer_get_unicode_funcs (hb_buffer_t        *buffer);

140
HB_EXTERN void
141 142 143
hb_buffer_set_direction (hb_buffer_t    *buffer,
			 hb_direction_t  direction);

144
HB_EXTERN hb_direction_t
145 146
hb_buffer_get_direction (hb_buffer_t *buffer);

147
HB_EXTERN void
148 149 150
hb_buffer_set_script (hb_buffer_t *buffer,
		      hb_script_t  script);

151
HB_EXTERN hb_script_t
152 153
hb_buffer_get_script (hb_buffer_t *buffer);

154
HB_EXTERN void
155 156 157
hb_buffer_set_language (hb_buffer_t   *buffer,
			hb_language_t  language);

158

159
HB_EXTERN hb_language_t
160
hb_buffer_get_language (hb_buffer_t *buffer);
161

162
HB_EXTERN void
163 164 165
hb_buffer_set_segment_properties (hb_buffer_t *buffer,
				  const hb_segment_properties_t *props);

166
HB_EXTERN void
167 168 169
hb_buffer_get_segment_properties (hb_buffer_t *buffer,
				  hb_segment_properties_t *props);

170
HB_EXTERN void
171
hb_buffer_guess_segment_properties (hb_buffer_t *buffer);
172

B
Minor  
Behdad Esfahbod 已提交
173

B
Behdad Esfahbod 已提交
174 175 176
/*
 * Since: 0.9.20
 */
177
typedef enum { /*< flags >*/
178 179 180 181
  HB_BUFFER_FLAG_DEFAULT			= 0x00000000u,
  HB_BUFFER_FLAG_BOT				= 0x00000001u, /* Beginning-of-text */
  HB_BUFFER_FLAG_EOT				= 0x00000002u, /* End-of-text */
  HB_BUFFER_FLAG_PRESERVE_DEFAULT_IGNORABLES	= 0x00000004u
B
Minor  
Behdad Esfahbod 已提交
182 183
} hb_buffer_flags_t;

184
HB_EXTERN void
B
Behdad Esfahbod 已提交
185 186 187
hb_buffer_set_flags (hb_buffer_t       *buffer,
		     hb_buffer_flags_t  flags);

188
HB_EXTERN hb_buffer_flags_t
B
Behdad Esfahbod 已提交
189 190
hb_buffer_get_flags (hb_buffer_t *buffer);

B
Behdad Esfahbod 已提交
191 192 193
/*
 * Since: 0.9.42
 */
194 195 196 197 198 199 200
typedef enum {
  HB_BUFFER_CLUSTER_LEVEL_MONOTONE_GRAPHEMES	= 0,
  HB_BUFFER_CLUSTER_LEVEL_MONOTONE_CHARACTERS	= 1,
  HB_BUFFER_CLUSTER_LEVEL_CHARACTERS		= 2,
  HB_BUFFER_CLUSTER_LEVEL_DEFAULT = HB_BUFFER_CLUSTER_LEVEL_MONOTONE_GRAPHEMES
} hb_buffer_cluster_level_t;

201
HB_EXTERN void
202 203
hb_buffer_set_cluster_level (hb_buffer_t               *buffer,
			     hb_buffer_cluster_level_t  cluster_level);
B
Behdad Esfahbod 已提交
204

205
HB_EXTERN hb_buffer_cluster_level_t
206
hb_buffer_get_cluster_level (hb_buffer_t *buffer);
207 208 209 210 211

#define HB_BUFFER_REPLACEMENT_CODEPOINT_DEFAULT 0xFFFDu

/* Sets codepoint used to replace invalid UTF-8/16/32 entries.
 * Default is 0xFFFDu. */
212
HB_EXTERN void
213 214 215
hb_buffer_set_replacement_codepoint (hb_buffer_t    *buffer,
				     hb_codepoint_t  replacement);

216
HB_EXTERN hb_codepoint_t
217 218 219
hb_buffer_get_replacement_codepoint (hb_buffer_t    *buffer);


220 221
/* Resets the buffer.  Afterwards it's as if it was just created,
 * except that it has a larger buffer allocated perhaps... */
222
HB_EXTERN void
223 224
hb_buffer_reset (hb_buffer_t *buffer);

225
/* Like reset, but does NOT clear unicode_funcs and replacement_codepoint. */
226
HB_EXTERN void
227
hb_buffer_clear_contents (hb_buffer_t *buffer);
B
Behdad Esfahbod 已提交
228

229
/* Returns false if allocation failed */
230
HB_EXTERN hb_bool_t
231 232
hb_buffer_pre_allocate (hb_buffer_t  *buffer,
		        unsigned int  size);
B
Behdad Esfahbod 已提交
233

234

235
/* Returns false if allocation has failed before */
236
HB_EXTERN hb_bool_t
237 238
hb_buffer_allocation_successful (hb_buffer_t  *buffer);

239
HB_EXTERN void
B
Behdad Esfahbod 已提交
240 241
hb_buffer_reverse (hb_buffer_t *buffer);

242
HB_EXTERN void
243 244 245
hb_buffer_reverse_range (hb_buffer_t *buffer,
			 unsigned int start, unsigned int end);

246
HB_EXTERN void
247 248
hb_buffer_reverse_clusters (hb_buffer_t *buffer);

B
Behdad Esfahbod 已提交
249 250

/* Filling the buffer in */
251

252
HB_EXTERN void
253 254 255
hb_buffer_add (hb_buffer_t    *buffer,
	       hb_codepoint_t  codepoint,
	       unsigned int    cluster);
256

257
HB_EXTERN void
B
Behdad Esfahbod 已提交
258 259
hb_buffer_add_utf8 (hb_buffer_t  *buffer,
		    const char   *text,
260
		    int           text_length,
B
Behdad Esfahbod 已提交
261
		    unsigned int  item_offset,
262
		    int           item_length);
B
Behdad Esfahbod 已提交
263

264
HB_EXTERN void
B
Behdad Esfahbod 已提交
265 266
hb_buffer_add_utf16 (hb_buffer_t    *buffer,
		     const uint16_t *text,
267
		     int             text_length,
B
Behdad Esfahbod 已提交
268
		     unsigned int    item_offset,
269
		     int             item_length);
B
Behdad Esfahbod 已提交
270

271
HB_EXTERN void
B
Behdad Esfahbod 已提交
272 273
hb_buffer_add_utf32 (hb_buffer_t    *buffer,
		     const uint32_t *text,
274
		     int             text_length,
B
Behdad Esfahbod 已提交
275
		     unsigned int    item_offset,
276
		     int             item_length);
B
Behdad Esfahbod 已提交
277

278
/* Allows only access to first 256 Unicode codepoints. */
279
HB_EXTERN void
280 281 282 283 284 285
hb_buffer_add_latin1 (hb_buffer_t   *buffer,
		      const uint8_t *text,
		      int            text_length,
		      unsigned int   item_offset,
		      int            item_length);

286
/* Like add_utf32 but does NOT check for invalid Unicode codepoints. */
287
HB_EXTERN void
288 289 290 291 292 293
hb_buffer_add_codepoints (hb_buffer_t          *buffer,
			  const hb_codepoint_t *text,
			  int                   text_length,
			  unsigned int          item_offset,
			  int                   item_length);

294

295
/* Clears any new items added at the end */
296
HB_EXTERN hb_bool_t
297 298
hb_buffer_set_length (hb_buffer_t  *buffer,
		      unsigned int  length);
B
Behdad Esfahbod 已提交
299

300
/* Return value valid as long as buffer not modified */
301
HB_EXTERN unsigned int
302
hb_buffer_get_length (hb_buffer_t *buffer);
303

304 305
/* Getting glyphs out of the buffer */

306
/* Return value valid as long as buffer not modified */
307
HB_EXTERN hb_glyph_info_t *
308 309
hb_buffer_get_glyph_infos (hb_buffer_t  *buffer,
                           unsigned int *length);
310 311

/* Return value valid as long as buffer not modified */
312
HB_EXTERN hb_glyph_position_t *
313 314
hb_buffer_get_glyph_positions (hb_buffer_t  *buffer,
                               unsigned int *length);
B
Behdad Esfahbod 已提交
315 316


317 318 319
/* Reorders a glyph buffer to have canonical in-cluster glyph order / position.
 * The resulting clusters should behave identical to pre-reordering clusters.
 * NOTE: This has nothing to do with Unicode normalization. */
320
HB_EXTERN void
321 322 323
hb_buffer_normalize_glyphs (hb_buffer_t *buffer);


B
Minor  
Behdad Esfahbod 已提交
324 325 326
/*
 * Serialize
 */
327

B
Behdad Esfahbod 已提交
328 329 330
/*
 * Since: 0.9.20
 */
331
typedef enum { /*< flags >*/
332 333 334
  HB_BUFFER_SERIALIZE_FLAG_DEFAULT		= 0x00000000u,
  HB_BUFFER_SERIALIZE_FLAG_NO_CLUSTERS		= 0x00000001u,
  HB_BUFFER_SERIALIZE_FLAG_NO_POSITIONS		= 0x00000002u,
335 336
  HB_BUFFER_SERIALIZE_FLAG_NO_GLYPH_NAMES	= 0x00000004u,
  HB_BUFFER_SERIALIZE_FLAG_GLYPH_EXTENTS	= 0x00000008u
337 338 339 340 341 342 343 344 345
} hb_buffer_serialize_flags_t;

typedef enum {
  HB_BUFFER_SERIALIZE_FORMAT_TEXT	= HB_TAG('T','E','X','T'),
  HB_BUFFER_SERIALIZE_FORMAT_JSON	= HB_TAG('J','S','O','N'),
  HB_BUFFER_SERIALIZE_FORMAT_INVALID	= HB_TAG_NONE
} hb_buffer_serialize_format_t;

/* len=-1 means str is NUL-terminated. */
346
HB_EXTERN hb_buffer_serialize_format_t
347 348
hb_buffer_serialize_format_from_string (const char *str, int len);

349
HB_EXTERN const char *
350 351
hb_buffer_serialize_format_to_string (hb_buffer_serialize_format_t format);

352
HB_EXTERN const char **
353 354
hb_buffer_serialize_list_formats (void);

355
/* Returns number of items, starting at start, that were serialized. */
356
HB_EXTERN unsigned int
357 358 359 360 361
hb_buffer_serialize_glyphs (hb_buffer_t *buffer,
			    unsigned int start,
			    unsigned int end,
			    char *buf,
			    unsigned int buf_size,
B
Behdad Esfahbod 已提交
362
			    unsigned int *buf_consumed, /* May be NULL */
363 364 365 366
			    hb_font_t *font, /* May be NULL */
			    hb_buffer_serialize_format_t format,
			    hb_buffer_serialize_flags_t flags);

367
HB_EXTERN hb_bool_t
368 369
hb_buffer_deserialize_glyphs (hb_buffer_t *buffer,
			      const char *buf,
370
			      int buf_len, /* -1 means nul-terminated */
371
			      const char **end_ptr, /* May be NULL */
372 373 374 375
			      hb_font_t *font, /* May be NULL */
			      hb_buffer_serialize_format_t format);


376 377 378 379 380 381 382 383 384 385 386 387 388 389 390
/*
 * Debugging.
 */

typedef hb_bool_t	(*hb_buffer_message_func_t)	(hb_buffer_t *buffer,
							 hb_font_t   *font,
							 const char  *message,
							 void        *user_data);

HB_EXTERN void
hb_buffer_set_message_func (hb_buffer_t *buffer,
			    hb_buffer_message_func_t func,
			    void *user_data, hb_destroy_func_t destroy);


B
Behdad Esfahbod 已提交
391
HB_END_DECLS
392

393
#endif /* HB_BUFFER_H */