OLD | NEW |
1 /* | 1 /* |
2 * Copyright © 2009 Red Hat, Inc. | 2 * Copyright © 2009 Red Hat, Inc. |
3 * | 3 * |
4 * This is part of HarfBuzz, a text shaping library. | 4 * This is part of HarfBuzz, a text shaping library. |
5 * | 5 * |
6 * Permission is hereby granted, without written agreement and without | 6 * Permission is hereby granted, without written agreement and without |
7 * license or royalty fees, to use, copy, modify, and distribute this | 7 * license or royalty fees, to use, copy, modify, and distribute this |
8 * software and its documentation for any purpose, provided that the | 8 * software and its documentation for any purpose, provided that the |
9 * above copyright notice and the following two paragraphs appear in | 9 * above copyright notice and the following two paragraphs appear in |
10 * all copies of this software. | 10 * all copies of this software. |
(...skipping 16 matching lines...) Expand all Loading... |
27 #ifndef HB_FT_H | 27 #ifndef HB_FT_H |
28 #define HB_FT_H | 28 #define HB_FT_H |
29 | 29 |
30 #include "hb.h" | 30 #include "hb.h" |
31 | 31 |
32 #include <ft2build.h> | 32 #include <ft2build.h> |
33 #include FT_FREETYPE_H | 33 #include FT_FREETYPE_H |
34 | 34 |
35 HB_BEGIN_DECLS | 35 HB_BEGIN_DECLS |
36 | 36 |
37 /* Note: FreeType is not thread-safe. Hence, these functions are not either. */ | 37 /* |
| 38 * Note: FreeType is not thread-safe. |
| 39 * Hence, these functions are not either. |
| 40 */ |
38 | 41 |
| 42 /* |
| 43 * hb-face from ft-face. |
| 44 */ |
| 45 |
| 46 /* This one creates a new hb-face for given ft-face. |
| 47 * When the returned hb-face is destroyed, the destroy |
| 48 * callback is called (if not NULL), with the ft-face passed |
| 49 * to it. |
| 50 * |
| 51 * The client is responsible to make sure that ft-face is |
| 52 * destroyed after hb-face is destroyed. |
| 53 * |
| 54 * Most often you don't want this function. You should use either |
| 55 * hb_ft_face_create_cached(), or hb_ft_face_create_referenced(). |
| 56 * In particular, if you are going to pass NULL as destroy, you |
| 57 * probably should use (the more recent) hb_ft_face_create_referenced() |
| 58 * instead. |
| 59 */ |
39 hb_face_t * | 60 hb_face_t * |
40 hb_ft_face_create (FT_Face ft_face, | 61 hb_ft_face_create (FT_Face ft_face, |
41 hb_destroy_func_t destroy); | 62 hb_destroy_func_t destroy); |
42 | 63 |
| 64 /* This version is like hb_ft_face_create(), except that it caches |
| 65 * the hb-face using the generic pointer of the ft-face. This means |
| 66 * that subsequent calls to this function with the same ft-face will |
| 67 * return the same hb-face (correctly referenced). |
| 68 * |
| 69 * Client is still responsible for making sure that ft-face is destroyed |
| 70 * after hb-face is. |
| 71 */ |
43 hb_face_t * | 72 hb_face_t * |
44 hb_ft_face_create_cached (FT_Face ft_face); | 73 hb_ft_face_create_cached (FT_Face ft_face); |
45 | 74 |
| 75 /* This version is like hb_ft_face_create(), except that it calls |
| 76 * FT_Reference_Face() on ft-face, as such keeping ft-face alive |
| 77 * as long as the hb-face is. |
| 78 * |
| 79 * This is the most convenient version to use. Use it unless you have |
| 80 * very good reasons not to. |
| 81 */ |
| 82 hb_face_t * |
| 83 hb_ft_face_create_referenced (FT_Face ft_face); |
| 84 |
| 85 |
| 86 /* |
| 87 * hb-font from ft-face. |
| 88 */ |
| 89 |
| 90 /* |
| 91 * Note: |
| 92 * |
| 93 * Set face size on ft-face before creating hb-font from it. |
| 94 * Otherwise hb-ft would NOT pick up the font size correctly. |
| 95 */ |
| 96 |
| 97 /* See notes on hb_ft_face_create(). Same issues re lifecycle-management |
| 98 * apply here. Use hb_ft_font_create_referenced() if you can. */ |
46 hb_font_t * | 99 hb_font_t * |
47 hb_ft_font_create (FT_Face ft_face, | 100 hb_ft_font_create (FT_Face ft_face, |
48 hb_destroy_func_t destroy); | 101 hb_destroy_func_t destroy); |
49 | 102 |
| 103 /* See notes on hb_ft_face_create_referenced() re lifecycle-management |
| 104 * issues. */ |
| 105 hb_font_t * |
| 106 hb_ft_font_create_referenced (FT_Face ft_face); |
50 | 107 |
51 | 108 |
52 /* Makes an hb_font_t use FreeType internally to implement font functions. */ | 109 /* Makes an hb_font_t use FreeType internally to implement font functions. */ |
53 void | 110 void |
54 hb_ft_font_set_funcs (hb_font_t *font); | 111 hb_ft_font_set_funcs (hb_font_t *font); |
55 | 112 |
56 FT_Face | 113 FT_Face |
57 hb_ft_font_get_face (hb_font_t *font); | 114 hb_ft_font_get_face (hb_font_t *font); |
58 | 115 |
59 | 116 |
60 HB_END_DECLS | 117 HB_END_DECLS |
61 | 118 |
62 #endif /* HB_FT_H */ | 119 #endif /* HB_FT_H */ |
OLD | NEW |