Edit

kc3-lang/freetype/src/autofit/afblue.hin

Branch :

  • Show log

    Commit

  • Author : Werner Lemberg
    Date : 2025-05-01 06:19:25
    Hash : a37e11c3
    Message : [autofit] Better handling of characters with attached diacritics. (1/3) Introduce blue zone properties that will be used to make the auto-hinter ignore diacritics attached on the top or the bottom of a base character. * src/autofit/afblue.hin (AF_BLUE_PROPERTY_LATIN_CAPITAL_BOTTOM, AF_BLUE_PROPERTY_LATIN_SMALL_BOTTOM): New properties. * src/autofit/afblue.dat: Use them. * src/autofit/afblue.c, src/autofit/afblue.h: Rengenerated. * src/autofit/aflatin.h (AF_LATIN_IS_CAPITAL_BOTTOM_BLUE, AF_LATIN_IS_SMALL_BOTTOM_BLUE, AF_LATIN_BLUE_BOTTOM, AF_LATIN_BLUE_BOTTOM_SMALL): New macros. * src/autofit/aflatin.c (af_latin_metrics_init_blues)[FT_DEBUG_LEVEL_TRACE]: Updated.

  • src/autofit/afblue.hin
  • /****************************************************************************
     *
     * afblue.h
     *
     *   Auto-fitter data for blue strings (specification).
     *
     * Copyright (C) 2013-2024 by
     * David Turner, Robert Wilhelm, and Werner Lemberg.
     *
     * This file is part of the FreeType project, and may only be used,
     * modified, and distributed under the terms of the FreeType project
     * license, LICENSE.TXT.  By continuing to use, modify, or distribute
     * this file you indicate that you have read the license and
     * understand and accept it fully.
     *
     */
    
    
    #ifndef AFBLUE_H_
    #define AFBLUE_H_
    
    
    FT_BEGIN_HEADER
    
    
      /* an auxiliary macro to decode a UTF-8 character -- since we only use */
      /* hard-coded, self-converted data, no error checking is performed     */
    #define GET_UTF8_CHAR( ch, p )                      \
              do                                        \
              {                                         \
                ch = (unsigned char)*p++;               \
                if ( ch >= 0x80 )                       \
                {                                       \
                  FT_UInt  len_;                        \
                                                        \
                                                        \
                  if ( ch < 0xE0 )                      \
                  {                                     \
                    len_ = 1;                           \
                    ch  &= 0x1F;                        \
                  }                                     \
                  else if ( ch < 0xF0 )                 \
                  {                                     \
                    len_ = 2;                           \
                    ch  &= 0x0F;                        \
                  }                                     \
                  else                                  \
                  {                                     \
                    len_ = 3;                           \
                    ch  &= 0x07;                        \
                  }                                     \
                                                        \
                  for ( ; len_ > 0; len_-- )            \
                    ch = ( ch << 6 ) | ( *p++ & 0x3F ); \
                }                                       \
              } while ( 0 )
    
    
      /*************************************************************************/
      /*************************************************************************/
      /*****                                                               *****/
      /*****                    B L U E   S T R I N G S                    *****/
      /*****                                                               *****/
      /*************************************************************************/
      /*************************************************************************/
    
      /* At the bottommost level, we define strings for finding blue zones. */
    
    
    #define AF_BLUE_STRING_MAX_LEN  @AF_BLUE_STRING_MAX_LEN@
    
      /* The AF_Blue_String enumeration values are offsets into the */
      /* `af_blue_strings' array.                                   */
    
      typedef enum  AF_Blue_String_
      {
    @AF_BLUE_STRING_ENUM@
    
        AF_BLUE_STRING_MAX   /* do not remove */
    
      } AF_Blue_String;
    
    
      FT_LOCAL_ARRAY( char )
      af_blue_strings[];
    
    
      /*************************************************************************/
      /*************************************************************************/
      /*****                                                               *****/
      /*****                 B L U E   S T R I N G S E T S                 *****/
      /*****                                                               *****/
      /*************************************************************************/
      /*************************************************************************/
    
      /* The next level is to group blue strings into style-specific sets. */
    
    
      /* Properties are specific to a writing system.  We assume that a given  */
      /* blue string can't be used in more than a single writing system, which */
      /* is a safe bet.                                                        */
    #define AF_BLUE_PROPERTY_LATIN_TOP       ( 1U << 0 )    /* must be value 1 */
    #define AF_BLUE_PROPERTY_LATIN_SUB_TOP   ( 1U << 1 )
    #define AF_BLUE_PROPERTY_LATIN_NEUTRAL   ( 1U << 2 )
    #define AF_BLUE_PROPERTY_LATIN_X_HEIGHT  ( 1U << 3 )
    #define AF_BLUE_PROPERTY_LATIN_LONG      ( 1U << 4 )
    
    #define AF_BLUE_PROPERTY_LATIN_CAPITAL_BOTTOM  ( 1U << 5 )
    #define AF_BLUE_PROPERTY_LATIN_SMALL_BOTTOM    ( 1U << 6 )
    
    #define AF_BLUE_PROPERTY_CJK_TOP    ( 1U << 0 )         /* must be value 1 */
    #define AF_BLUE_PROPERTY_CJK_HORIZ  ( 1U << 1 )         /* must be value 2 */
    #define AF_BLUE_PROPERTY_CJK_RIGHT  AF_BLUE_PROPERTY_CJK_TOP
    
    
    #define AF_BLUE_STRINGSET_MAX_LEN  @AF_BLUE_STRINGSET_MAX_LEN@
    
      /* The AF_Blue_Stringset enumeration values are offsets into the */
      /* `af_blue_stringsets' array.                                   */
    
      typedef enum  AF_Blue_Stringset_
      {
    @AF_BLUE_STRINGSET_ENUM@
    
        AF_BLUE_STRINGSET_MAX   /* do not remove */
    
      } AF_Blue_Stringset;
    
    
      typedef struct  AF_Blue_StringRec_
      {
        AF_Blue_String  string;
        FT_UShort       properties;
    
      } AF_Blue_StringRec;
    
    
      FT_LOCAL_ARRAY( AF_Blue_StringRec )
      af_blue_stringsets[];
    
    /* */
    
    FT_END_HEADER
    
    
    #endif /* AFBLUE_H_ */
    
    
    /* END */