+++ /dev/null
-/***************************************************************************/
-/* */
-/* afblue.h */
-/* */
-/* Auto-fitter data for blue strings (specification). */
-/* */
-/* Copyright 2013-2016 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 have 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_CJK_TOP ( 1U << 0 ) /* must have value 1 */
-#define AF_BLUE_PROPERTY_CJK_HORIZ ( 1U << 1 ) /* must have 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 */