hb-ot-name.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  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. #if !defined(HB_OT_H_IN) && !defined(HB_NO_SINGLE_HEADER_ERROR)
  25. #error "Include <hb-ot.h> instead."
  26. #endif
  27. #ifndef HB_OT_NAME_H
  28. #define HB_OT_NAME_H
  29. #include "hb.h"
  30. HB_BEGIN_DECLS
  31. /**
  32. * hb_ot_name_id_predefined_t:
  33. * @HB_OT_NAME_ID_COPYRIGHT: Copyright notice
  34. * @HB_OT_NAME_ID_FONT_FAMILY: Font Family name
  35. * @HB_OT_NAME_ID_FONT_SUBFAMILY: Font Subfamily name
  36. * @HB_OT_NAME_ID_UNIQUE_ID: Unique font identifier
  37. * @HB_OT_NAME_ID_FULL_NAME: Full font name that reflects
  38. * all family and relevant subfamily descriptors
  39. * @HB_OT_NAME_ID_VERSION_STRING: Version string
  40. * @HB_OT_NAME_ID_POSTSCRIPT_NAME: PostScript name for the font
  41. * @HB_OT_NAME_ID_TRADEMARK: Trademark
  42. * @HB_OT_NAME_ID_MANUFACTURER: Manufacturer Name
  43. * @HB_OT_NAME_ID_DESIGNER: Designer
  44. * @HB_OT_NAME_ID_DESCRIPTION: Description
  45. * @HB_OT_NAME_ID_VENDOR_URL: URL of font vendor
  46. * @HB_OT_NAME_ID_DESIGNER_URL: URL of typeface designer
  47. * @HB_OT_NAME_ID_LICENSE: License Description
  48. * @HB_OT_NAME_ID_LICENSE_URL: URL where additional licensing
  49. * information can be found
  50. * @HB_OT_NAME_ID_TYPOGRAPHIC_FAMILY: Typographic Family name
  51. * @HB_OT_NAME_ID_TYPOGRAPHIC_SUBFAMILY: Typographic Subfamily name
  52. * @HB_OT_NAME_ID_MAC_FULL_NAME: Compatible Full Name for MacOS
  53. * @HB_OT_NAME_ID_SAMPLE_TEXT: Sample text
  54. * @HB_OT_NAME_ID_CID_FINDFONT_NAME: PostScript CID findfont name
  55. * @HB_OT_NAME_ID_WWS_FAMILY: WWS Family Name
  56. * @HB_OT_NAME_ID_WWS_SUBFAMILY: WWS Subfamily Name
  57. * @HB_OT_NAME_ID_LIGHT_BACKGROUND: Light Background Palette
  58. * @HB_OT_NAME_ID_DARK_BACKGROUND: Dark Background Palette
  59. * @HB_OT_NAME_ID_VARIATIONS_PS_PREFIX: Variations PostScript Name Prefix
  60. * @HB_OT_NAME_ID_INVALID: Value to represent a nonexistent name ID.
  61. *
  62. * An enum type representing the pre-defined name IDs.
  63. *
  64. * For more information on these fields, see the
  65. * [OpenType spec](https://docs.microsoft.com/en-us/typography/opentype/spec/name#name-ids).
  66. *
  67. * Since: 7.0.0
  68. **/
  69. typedef enum
  70. {
  71. HB_OT_NAME_ID_COPYRIGHT = 0,
  72. HB_OT_NAME_ID_FONT_FAMILY = 1,
  73. HB_OT_NAME_ID_FONT_SUBFAMILY = 2,
  74. HB_OT_NAME_ID_UNIQUE_ID = 3,
  75. HB_OT_NAME_ID_FULL_NAME = 4,
  76. HB_OT_NAME_ID_VERSION_STRING = 5,
  77. HB_OT_NAME_ID_POSTSCRIPT_NAME = 6,
  78. HB_OT_NAME_ID_TRADEMARK = 7,
  79. HB_OT_NAME_ID_MANUFACTURER = 8,
  80. HB_OT_NAME_ID_DESIGNER = 9,
  81. HB_OT_NAME_ID_DESCRIPTION = 10,
  82. HB_OT_NAME_ID_VENDOR_URL = 11,
  83. HB_OT_NAME_ID_DESIGNER_URL = 12,
  84. HB_OT_NAME_ID_LICENSE = 13,
  85. HB_OT_NAME_ID_LICENSE_URL = 14,
  86. /*HB_OT_NAME_ID_RESERVED = 15,*/
  87. HB_OT_NAME_ID_TYPOGRAPHIC_FAMILY = 16,
  88. HB_OT_NAME_ID_TYPOGRAPHIC_SUBFAMILY = 17,
  89. HB_OT_NAME_ID_MAC_FULL_NAME = 18,
  90. HB_OT_NAME_ID_SAMPLE_TEXT = 19,
  91. HB_OT_NAME_ID_CID_FINDFONT_NAME = 20,
  92. HB_OT_NAME_ID_WWS_FAMILY = 21,
  93. HB_OT_NAME_ID_WWS_SUBFAMILY = 22,
  94. HB_OT_NAME_ID_LIGHT_BACKGROUND = 23,
  95. HB_OT_NAME_ID_DARK_BACKGROUND = 24,
  96. HB_OT_NAME_ID_VARIATIONS_PS_PREFIX = 25,
  97. HB_OT_NAME_ID_INVALID = 0xFFFF
  98. } hb_ot_name_id_predefined_t;
  99. /**
  100. * hb_ot_name_id_t:
  101. *
  102. * An integral type representing an OpenType 'name' table name identifier.
  103. * There are predefined name IDs, as well as name IDs return from other
  104. * API. These can be used to fetch name strings from a font face.
  105. *
  106. * Since: 2.0.0
  107. **/
  108. typedef unsigned int hb_ot_name_id_t;
  109. /**
  110. * hb_ot_name_entry_t:
  111. * @name_id: name ID
  112. * @language: language
  113. *
  114. * Structure representing a name ID in a particular language.
  115. *
  116. * Since: 2.1.0
  117. **/
  118. typedef struct hb_ot_name_entry_t {
  119. hb_ot_name_id_t name_id;
  120. /*< private >*/
  121. hb_var_int_t var;
  122. /*< public >*/
  123. hb_language_t language;
  124. } hb_ot_name_entry_t;
  125. HB_EXTERN const hb_ot_name_entry_t *
  126. hb_ot_name_list_names (hb_face_t *face,
  127. unsigned int *num_entries /* OUT */);
  128. HB_EXTERN unsigned int
  129. hb_ot_name_get_utf8 (hb_face_t *face,
  130. hb_ot_name_id_t name_id,
  131. hb_language_t language,
  132. unsigned int *text_size /* IN/OUT */,
  133. char *text /* OUT */);
  134. HB_EXTERN unsigned int
  135. hb_ot_name_get_utf16 (hb_face_t *face,
  136. hb_ot_name_id_t name_id,
  137. hb_language_t language,
  138. unsigned int *text_size /* IN/OUT */,
  139. uint16_t *text /* OUT */);
  140. HB_EXTERN unsigned int
  141. hb_ot_name_get_utf32 (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. uint32_t *text /* OUT */);
  146. HB_END_DECLS
  147. #endif /* HB_OT_NAME_H */