harfbuzz (8.3.0)

(root)/
include/
harfbuzz/
hb-ot-name.h
       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 */