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