hb-ot-name.h 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  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_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 integral type representing an OpenType 'name' table name identifier.
  63. * There are predefined name IDs, as well as name IDs return from other
  64. * API. These can be used to fetch name strings from a font face.
  65. *
  66. * For more information on these fields, see the
  67. * [OpenType spec](https://docs.microsoft.com/en-us/typography/opentype/spec/name#name-ids).
  68. *
  69. * Since: 2.0.0
  70. **/
  71. enum
  72. {
  73. HB_OT_NAME_ID_COPYRIGHT = 0,
  74. HB_OT_NAME_ID_FONT_FAMILY = 1,
  75. HB_OT_NAME_ID_FONT_SUBFAMILY = 2,
  76. HB_OT_NAME_ID_UNIQUE_ID = 3,
  77. HB_OT_NAME_ID_FULL_NAME = 4,
  78. HB_OT_NAME_ID_VERSION_STRING = 5,
  79. HB_OT_NAME_ID_POSTSCRIPT_NAME = 6,
  80. HB_OT_NAME_ID_TRADEMARK = 7,
  81. HB_OT_NAME_ID_MANUFACTURER = 8,
  82. HB_OT_NAME_ID_DESIGNER = 9,
  83. HB_OT_NAME_ID_DESCRIPTION = 10,
  84. HB_OT_NAME_ID_VENDOR_URL = 11,
  85. HB_OT_NAME_ID_DESIGNER_URL = 12,
  86. HB_OT_NAME_ID_LICENSE = 13,
  87. HB_OT_NAME_ID_LICENSE_URL = 14,
  88. /*HB_OT_NAME_ID_RESERVED = 15,*/
  89. HB_OT_NAME_ID_TYPOGRAPHIC_FAMILY = 16,
  90. HB_OT_NAME_ID_TYPOGRAPHIC_SUBFAMILY = 17,
  91. HB_OT_NAME_ID_MAC_FULL_NAME = 18,
  92. HB_OT_NAME_ID_SAMPLE_TEXT = 19,
  93. HB_OT_NAME_ID_CID_FINDFONT_NAME = 20,
  94. HB_OT_NAME_ID_WWS_FAMILY = 21,
  95. HB_OT_NAME_ID_WWS_SUBFAMILY = 22,
  96. HB_OT_NAME_ID_LIGHT_BACKGROUND = 23,
  97. HB_OT_NAME_ID_DARK_BACKGROUND = 24,
  98. HB_OT_NAME_ID_VARIATIONS_PS_PREFIX = 25,
  99. HB_OT_NAME_ID_INVALID = 0xFFFF
  100. };
  101. typedef unsigned int hb_ot_name_id_t;
  102. /**
  103. * hb_ot_name_entry_t:
  104. * @name_id: name ID
  105. * @language: language
  106. *
  107. * Structure representing a name ID in a particular language.
  108. *
  109. * Since: 2.1.0
  110. **/
  111. typedef struct hb_ot_name_entry_t {
  112. hb_ot_name_id_t name_id;
  113. /*< private >*/
  114. hb_var_int_t var;
  115. /*< public >*/
  116. hb_language_t language;
  117. } hb_ot_name_entry_t;
  118. HB_EXTERN const hb_ot_name_entry_t *
  119. hb_ot_name_list_names (hb_face_t *face,
  120. unsigned int *num_entries /* OUT */);
  121. HB_EXTERN unsigned int
  122. hb_ot_name_get_utf8 (hb_face_t *face,
  123. hb_ot_name_id_t name_id,
  124. hb_language_t language,
  125. unsigned int *text_size /* IN/OUT */,
  126. char *text /* OUT */);
  127. HB_EXTERN unsigned int
  128. hb_ot_name_get_utf16 (hb_face_t *face,
  129. hb_ot_name_id_t name_id,
  130. hb_language_t language,
  131. unsigned int *text_size /* IN/OUT */,
  132. uint16_t *text /* OUT */);
  133. HB_EXTERN unsigned int
  134. hb_ot_name_get_utf32 (hb_face_t *face,
  135. hb_ot_name_id_t name_id,
  136. hb_language_t language,
  137. unsigned int *text_size /* IN/OUT */,
  138. uint32_t *text /* OUT */);
  139. HB_END_DECLS
  140. #endif /* HB_OT_NAME_H */