xref: /aosp_15_r20/external/harfbuzz_ng/src/hb-ot-name.h (revision 2d1272b857b1f7575e6e246373e1cb218663db8a)
1*2d1272b8SAndroid Build Coastguard Worker /*
2*2d1272b8SAndroid Build Coastguard Worker  * Copyright © 2018  Ebrahim Byagowi.
3*2d1272b8SAndroid Build Coastguard Worker  *
4*2d1272b8SAndroid Build Coastguard Worker  *  This is part of HarfBuzz, a text shaping library.
5*2d1272b8SAndroid Build Coastguard Worker  *
6*2d1272b8SAndroid Build Coastguard Worker  * Permission is hereby granted, without written agreement and without
7*2d1272b8SAndroid Build Coastguard Worker  * license or royalty fees, to use, copy, modify, and distribute this
8*2d1272b8SAndroid Build Coastguard Worker  * software and its documentation for any purpose, provided that the
9*2d1272b8SAndroid Build Coastguard Worker  * above copyright notice and the following two paragraphs appear in
10*2d1272b8SAndroid Build Coastguard Worker  * all copies of this software.
11*2d1272b8SAndroid Build Coastguard Worker  *
12*2d1272b8SAndroid Build Coastguard Worker  * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
13*2d1272b8SAndroid Build Coastguard Worker  * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
14*2d1272b8SAndroid Build Coastguard Worker  * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
15*2d1272b8SAndroid Build Coastguard Worker  * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
16*2d1272b8SAndroid Build Coastguard Worker  * DAMAGE.
17*2d1272b8SAndroid Build Coastguard Worker  *
18*2d1272b8SAndroid Build Coastguard Worker  * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
19*2d1272b8SAndroid Build Coastguard Worker  * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
20*2d1272b8SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
21*2d1272b8SAndroid Build Coastguard Worker  * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
22*2d1272b8SAndroid Build Coastguard Worker  * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
23*2d1272b8SAndroid Build Coastguard Worker  */
24*2d1272b8SAndroid Build Coastguard Worker 
25*2d1272b8SAndroid Build Coastguard Worker #if !defined(HB_OT_H_IN) && !defined(HB_NO_SINGLE_HEADER_ERROR)
26*2d1272b8SAndroid Build Coastguard Worker #error "Include <hb-ot.h> instead."
27*2d1272b8SAndroid Build Coastguard Worker #endif
28*2d1272b8SAndroid Build Coastguard Worker 
29*2d1272b8SAndroid Build Coastguard Worker #ifndef HB_OT_NAME_H
30*2d1272b8SAndroid Build Coastguard Worker #define HB_OT_NAME_H
31*2d1272b8SAndroid Build Coastguard Worker 
32*2d1272b8SAndroid Build Coastguard Worker #include "hb.h"
33*2d1272b8SAndroid Build Coastguard Worker 
34*2d1272b8SAndroid Build Coastguard Worker HB_BEGIN_DECLS
35*2d1272b8SAndroid Build Coastguard Worker 
36*2d1272b8SAndroid Build Coastguard Worker /**
37*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_name_id_predefined_t:
38*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_COPYRIGHT: Copyright notice
39*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_FONT_FAMILY: Font Family name
40*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_FONT_SUBFAMILY: Font Subfamily name
41*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_UNIQUE_ID: Unique font identifier
42*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_FULL_NAME: Full font name that reflects
43*2d1272b8SAndroid Build Coastguard Worker  * all family and relevant subfamily descriptors
44*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_VERSION_STRING: Version string
45*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_POSTSCRIPT_NAME: PostScript name for the font
46*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_TRADEMARK: Trademark
47*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_MANUFACTURER: Manufacturer Name
48*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_DESIGNER: Designer
49*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_DESCRIPTION: Description
50*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_VENDOR_URL: URL of font vendor
51*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_DESIGNER_URL: URL of typeface designer
52*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_LICENSE: License Description
53*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_LICENSE_URL: URL where additional licensing
54*2d1272b8SAndroid Build Coastguard Worker  * information can be found
55*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_TYPOGRAPHIC_FAMILY: Typographic Family name
56*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_TYPOGRAPHIC_SUBFAMILY: Typographic Subfamily name
57*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_MAC_FULL_NAME: Compatible Full Name for MacOS
58*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_SAMPLE_TEXT: Sample text
59*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_CID_FINDFONT_NAME: PostScript CID findfont name
60*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_WWS_FAMILY: WWS Family Name
61*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_WWS_SUBFAMILY: WWS Subfamily Name
62*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_LIGHT_BACKGROUND: Light Background Palette
63*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_DARK_BACKGROUND: Dark Background Palette
64*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_VARIATIONS_PS_PREFIX: Variations PostScript Name Prefix
65*2d1272b8SAndroid Build Coastguard Worker  * @HB_OT_NAME_ID_INVALID: Value to represent a nonexistent name ID.
66*2d1272b8SAndroid Build Coastguard Worker  *
67*2d1272b8SAndroid Build Coastguard Worker  * An enum type representing the pre-defined name IDs.
68*2d1272b8SAndroid Build Coastguard Worker  *
69*2d1272b8SAndroid Build Coastguard Worker  * For more information on these fields, see the
70*2d1272b8SAndroid Build Coastguard Worker  * [OpenType spec](https://docs.microsoft.com/en-us/typography/opentype/spec/name#name-ids).
71*2d1272b8SAndroid Build Coastguard Worker  *
72*2d1272b8SAndroid Build Coastguard Worker  * Since: 7.0.0
73*2d1272b8SAndroid Build Coastguard Worker  **/
74*2d1272b8SAndroid Build Coastguard Worker typedef enum
75*2d1272b8SAndroid Build Coastguard Worker {
76*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_COPYRIGHT		= 0,
77*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_FONT_FAMILY		= 1,
78*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_FONT_SUBFAMILY		= 2,
79*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_UNIQUE_ID		= 3,
80*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_FULL_NAME		= 4,
81*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_VERSION_STRING		= 5,
82*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_POSTSCRIPT_NAME		= 6,
83*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_TRADEMARK		= 7,
84*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_MANUFACTURER		= 8,
85*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_DESIGNER		= 9,
86*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_DESCRIPTION		= 10,
87*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_VENDOR_URL		= 11,
88*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_DESIGNER_URL		= 12,
89*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_LICENSE			= 13,
90*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_LICENSE_URL		= 14,
91*2d1272b8SAndroid Build Coastguard Worker /*HB_OT_NAME_ID_RESERVED		= 15,*/
92*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_TYPOGRAPHIC_FAMILY	= 16,
93*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_TYPOGRAPHIC_SUBFAMILY	= 17,
94*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_MAC_FULL_NAME		= 18,
95*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_SAMPLE_TEXT		= 19,
96*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_CID_FINDFONT_NAME	= 20,
97*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_WWS_FAMILY		= 21,
98*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_WWS_SUBFAMILY		= 22,
99*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_LIGHT_BACKGROUND	= 23,
100*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_DARK_BACKGROUND		= 24,
101*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_VARIATIONS_PS_PREFIX	= 25,
102*2d1272b8SAndroid Build Coastguard Worker 
103*2d1272b8SAndroid Build Coastguard Worker   HB_OT_NAME_ID_INVALID			= 0xFFFF
104*2d1272b8SAndroid Build Coastguard Worker } hb_ot_name_id_predefined_t;
105*2d1272b8SAndroid Build Coastguard Worker 
106*2d1272b8SAndroid Build Coastguard Worker /**
107*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_name_id_t:
108*2d1272b8SAndroid Build Coastguard Worker  *
109*2d1272b8SAndroid Build Coastguard Worker  * An integral type representing an OpenType 'name' table name identifier.
110*2d1272b8SAndroid Build Coastguard Worker  * There are predefined name IDs, as well as name IDs return from other
111*2d1272b8SAndroid Build Coastguard Worker  * API.  These can be used to fetch name strings from a font face.
112*2d1272b8SAndroid Build Coastguard Worker  *
113*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.0.0
114*2d1272b8SAndroid Build Coastguard Worker  **/
115*2d1272b8SAndroid Build Coastguard Worker typedef unsigned int hb_ot_name_id_t;
116*2d1272b8SAndroid Build Coastguard Worker 
117*2d1272b8SAndroid Build Coastguard Worker 
118*2d1272b8SAndroid Build Coastguard Worker /**
119*2d1272b8SAndroid Build Coastguard Worker  * hb_ot_name_entry_t:
120*2d1272b8SAndroid Build Coastguard Worker  * @name_id: name ID
121*2d1272b8SAndroid Build Coastguard Worker  * @language: language
122*2d1272b8SAndroid Build Coastguard Worker  *
123*2d1272b8SAndroid Build Coastguard Worker  * Structure representing a name ID in a particular language.
124*2d1272b8SAndroid Build Coastguard Worker  *
125*2d1272b8SAndroid Build Coastguard Worker  * Since: 2.1.0
126*2d1272b8SAndroid Build Coastguard Worker  **/
127*2d1272b8SAndroid Build Coastguard Worker typedef struct hb_ot_name_entry_t {
128*2d1272b8SAndroid Build Coastguard Worker   hb_ot_name_id_t name_id;
129*2d1272b8SAndroid Build Coastguard Worker   /*< private >*/
130*2d1272b8SAndroid Build Coastguard Worker   hb_var_int_t    var;
131*2d1272b8SAndroid Build Coastguard Worker   /*< public >*/
132*2d1272b8SAndroid Build Coastguard Worker   hb_language_t   language;
133*2d1272b8SAndroid Build Coastguard Worker } hb_ot_name_entry_t;
134*2d1272b8SAndroid Build Coastguard Worker 
135*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN const hb_ot_name_entry_t *
136*2d1272b8SAndroid Build Coastguard Worker hb_ot_name_list_names (hb_face_t    *face,
137*2d1272b8SAndroid Build Coastguard Worker 		       unsigned int *num_entries /* OUT */);
138*2d1272b8SAndroid Build Coastguard Worker 
139*2d1272b8SAndroid Build Coastguard Worker 
140*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN unsigned int
141*2d1272b8SAndroid Build Coastguard Worker hb_ot_name_get_utf8 (hb_face_t       *face,
142*2d1272b8SAndroid Build Coastguard Worker 		     hb_ot_name_id_t  name_id,
143*2d1272b8SAndroid Build Coastguard Worker 		     hb_language_t    language,
144*2d1272b8SAndroid Build Coastguard Worker 		     unsigned int    *text_size /* IN/OUT */,
145*2d1272b8SAndroid Build Coastguard Worker 		     char            *text      /* OUT */);
146*2d1272b8SAndroid Build Coastguard Worker 
147*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN unsigned int
148*2d1272b8SAndroid Build Coastguard Worker hb_ot_name_get_utf16 (hb_face_t       *face,
149*2d1272b8SAndroid Build Coastguard Worker 		      hb_ot_name_id_t  name_id,
150*2d1272b8SAndroid Build Coastguard Worker 		      hb_language_t    language,
151*2d1272b8SAndroid Build Coastguard Worker 		      unsigned int    *text_size /* IN/OUT */,
152*2d1272b8SAndroid Build Coastguard Worker 		      uint16_t        *text      /* OUT */);
153*2d1272b8SAndroid Build Coastguard Worker 
154*2d1272b8SAndroid Build Coastguard Worker HB_EXTERN unsigned int
155*2d1272b8SAndroid Build Coastguard Worker hb_ot_name_get_utf32 (hb_face_t       *face,
156*2d1272b8SAndroid Build Coastguard Worker 		      hb_ot_name_id_t  name_id,
157*2d1272b8SAndroid Build Coastguard Worker 		      hb_language_t    language,
158*2d1272b8SAndroid Build Coastguard Worker 		      unsigned int    *text_size /* IN/OUT */,
159*2d1272b8SAndroid Build Coastguard Worker 		      uint32_t        *text      /* OUT */);
160*2d1272b8SAndroid Build Coastguard Worker 
161*2d1272b8SAndroid Build Coastguard Worker 
162*2d1272b8SAndroid Build Coastguard Worker HB_END_DECLS
163*2d1272b8SAndroid Build Coastguard Worker 
164*2d1272b8SAndroid Build Coastguard Worker #endif /* HB_OT_NAME_H */
165