Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(377)

Side by Side Diff: third_party/harfbuzz-ng/src/hb-ft.h

Issue 935333002: Update from https://crrev.com/316786 (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « third_party/harfbuzz-ng/src/hb-coretext.cc ('k') | third_party/harfbuzz-ng/src/hb-ft.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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 */
OLDNEW
« no previous file with comments | « third_party/harfbuzz-ng/src/hb-coretext.cc ('k') | third_party/harfbuzz-ng/src/hb-ft.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698