⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sfobjs.c

📁 奇趣公司比较新的qt/emd版本
💻 C
📖 第 1 页 / 共 3 页
字号:
/***************************************************************************//*                                                                         *//*  sfobjs.c                                                               *//*                                                                         *//*    SFNT object management (base).                                       *//*                                                                         *//*  Copyright 1996-2001, 2002, 2003, 2004, 2005, 2006, 2007 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.                                        *//*                                                                         *//***************************************************************************/#include <ft2build.h>#include "sfobjs.h"#include "ttload.h"#include "ttcmap.h"#include "ttkern.h"#include FT_INTERNAL_SFNT_H#include FT_INTERNAL_DEBUG_H#include FT_TRUETYPE_IDS_H#include FT_TRUETYPE_TAGS_H#include FT_SERVICE_POSTSCRIPT_CMAPS_H#include "sferrors.h"#ifdef TT_CONFIG_OPTION_BDF#include "ttbdf.h"#endif  /*************************************************************************/  /*                                                                       */  /* The macro FT_COMPONENT is used in trace mode.  It is an implicit      */  /* parameter of the FT_TRACE() and FT_ERROR() macros, used to print/log  */  /* messages during execution.                                            */  /*                                                                       */#undef  FT_COMPONENT#define FT_COMPONENT  trace_sfobjs  /* convert a UTF-16 name entry to ASCII */  static FT_String*  tt_name_entry_ascii_from_utf16( TT_NameEntry  entry,                                  FT_Memory     memory )  {    FT_String*  string;    FT_UInt     len, code, n;    FT_Byte*    read = (FT_Byte*)entry->string;    FT_Error    error;    len = (FT_UInt)entry->stringLength / 2;    if ( FT_NEW_ARRAY( string, len + 1 ) )      return NULL;    for ( n = 0; n < len; n++ )    {      code = FT_NEXT_USHORT( read );      if ( code < 32 || code > 127 )        code = '?';      string[n] = (char)code;    }    string[len] = 0;    return string;  }  /* convert an Apple Roman or symbol name entry to ASCII */  static FT_String*  tt_name_entry_ascii_from_other( TT_NameEntry  entry,                                  FT_Memory     memory )  {    FT_String*  string;    FT_UInt     len, code, n;    FT_Byte*    read = (FT_Byte*)entry->string;    FT_Error    error;    len = (FT_UInt)entry->stringLength;    if ( FT_NEW_ARRAY( string, len + 1 ) )      return NULL;    for ( n = 0; n < len; n++ )    {      code = *read++;      if ( code < 32 || code > 127 )        code = '?';      string[n] = (char)code;    }    string[len] = 0;    return string;  }  typedef FT_String*  (*TT_NameEntry_ConvertFunc)( TT_NameEntry  entry,                                                   FT_Memory     memory );  /*************************************************************************/  /*                                                                       */  /* <Function>                                                            */  /*    tt_face_get_name                                                   */  /*                                                                       */  /* <Description>                                                         */  /*    Returns a given ENGLISH name record in ASCII.                      */  /*                                                                       */  /* <Input>                                                               */  /*    face   :: A handle to the source face object.                      */  /*                                                                       */  /*    nameid :: The name id of the name record to return.                */  /*                                                                       */  /* <Return>                                                              */  /*    Character string.  NULL if no name is present.                     */  /*                                                                       */  static FT_String*  tt_face_get_name( TT_Face    face,                    FT_UShort  nameid )  {    FT_Memory         memory = face->root.memory;    FT_String*        result = NULL;    FT_UShort         n;    TT_NameEntryRec*  rec;    FT_Int            found_apple         = -1;    FT_Int            found_apple_roman   = -1;    FT_Int            found_apple_english = -1;    FT_Int            found_win           = -1;    FT_Int            found_unicode       = -1;    FT_Bool           is_english = 0;    TT_NameEntry_ConvertFunc  convert;    rec = face->name_table.names;    for ( n = 0; n < face->num_names; n++, rec++ )    {      /* According to the OpenType 1.3 specification, only Microsoft or  */      /* Apple platform IDs might be used in the `name' table.  The      */      /* `Unicode' platform is reserved for the `cmap' table, and the    */      /* `Iso' one is deprecated.                                        */      /*                                                                 */      /* However, the Apple TrueType specification doesn't say the same  */      /* thing and goes to suggest that all Unicode `name' table entries */      /* should be coded in UTF-16 (in big-endian format I suppose).     */      /*                                                                 */      if ( rec->nameID == nameid && rec->stringLength > 0 )      {        switch ( rec->platformID )        {        case TT_PLATFORM_APPLE_UNICODE:        case TT_PLATFORM_ISO:          /* there is `languageID' to check there.  We should use this */          /* field only as a last solution when nothing else is        */          /* available.                                                */          /*                                                           */          found_unicode = n;          break;        case TT_PLATFORM_MACINTOSH:          /* This is a bit special because some fonts will use either    */          /* an English language id, or a Roman encoding id, to indicate */          /* the English version of its font name.                       */          /*                                                             */          if ( rec->languageID == TT_MAC_LANGID_ENGLISH )            found_apple_english = n;          else if ( rec->encodingID == TT_MAC_ID_ROMAN )            found_apple_roman = n;          break;        case TT_PLATFORM_MICROSOFT:          /* we only take a non-English name when there is nothing */          /* else available in the font                            */          /*                                                       */          if ( found_win == -1 || ( rec->languageID & 0x3FF ) == 0x009 )          {            switch ( rec->encodingID )            {            case TT_MS_ID_SYMBOL_CS:            case TT_MS_ID_UNICODE_CS:            case TT_MS_ID_UCS_4:              is_english = FT_BOOL( ( rec->languageID & 0x3FF ) == 0x009 );              found_win  = n;              break;            default:              ;            }          }          break;        default:          ;        }      }    }    found_apple = found_apple_roman;    if ( found_apple_english >= 0 )      found_apple = found_apple_english;    /* some fonts contain invalid Unicode or Macintosh formatted entries; */    /* we will thus favor names encoded in Windows formats if available   */    /* (provided it is an English name)                                   */    /*                                                                    */    convert = NULL;    if ( found_win >= 0 && !( found_apple >= 0 && !is_english ) )    {      rec = face->name_table.names + found_win;      switch ( rec->encodingID )      {        /* all Unicode strings are encoded using UTF-16BE */      case TT_MS_ID_UNICODE_CS:      case TT_MS_ID_SYMBOL_CS:        convert = tt_name_entry_ascii_from_utf16;        break;      case TT_MS_ID_UCS_4:        /* Apparently, if this value is found in a name table entry, it is */        /* documented as `full Unicode repertoire'.  Experience with the   */        /* MsGothic font shipped with Windows Vista shows that this really */        /* means UTF-16 encoded names (UCS-4 values are only used within   */        /* charmaps).                                                      */        convert = tt_name_entry_ascii_from_utf16;        break;      default:        ;      }    }    else if ( found_apple >= 0 )    {      rec     = face->name_table.names + found_apple;      convert = tt_name_entry_ascii_from_other;    }    else if ( found_unicode >= 0 )    {      rec     = face->name_table.names + found_unicode;      convert = tt_name_entry_ascii_from_utf16;    }    if ( rec && convert )    {      if ( rec->string == NULL )      {        FT_Error   error  = SFNT_Err_Ok;        FT_Stream  stream = face->name_table.stream;        FT_UNUSED( error );        if ( FT_QNEW_ARRAY ( rec->string, rec->stringLength ) ||             FT_STREAM_SEEK( rec->stringOffset )              ||             FT_STREAM_READ( rec->string, rec->stringLength ) )        {          FT_FREE( rec->string );          rec->stringLength = 0;          result            = NULL;          goto Exit;        }      }      result = convert( rec, memory );    }  Exit:    return result;  }  static FT_Encoding  sfnt_find_encoding( int  platform_id,                      int  encoding_id )  {    typedef struct  TEncoding    {      int          platform_id;      int          encoding_id;      FT_Encoding  encoding;    } TEncoding;    static    const TEncoding  tt_encodings[] =    {      { TT_PLATFORM_ISO,           -1,                  FT_ENCODING_UNICODE },      { TT_PLATFORM_APPLE_UNICODE, -1,                  FT_ENCODING_UNICODE },      { TT_PLATFORM_MACINTOSH,     TT_MAC_ID_ROMAN,     FT_ENCODING_APPLE_ROMAN },      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_SYMBOL_CS,  FT_ENCODING_MS_SYMBOL },      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_UCS_4,      FT_ENCODING_UNICODE },      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_UNICODE_CS, FT_ENCODING_UNICODE },      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_SJIS,       FT_ENCODING_SJIS },      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_GB2312,     FT_ENCODING_GB2312 },      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_BIG_5,      FT_ENCODING_BIG5 },      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_WANSUNG,    FT_ENCODING_WANSUNG },      { TT_PLATFORM_MICROSOFT,     TT_MS_ID_JOHAB,      FT_ENCODING_JOHAB }    };    const TEncoding  *cur, *limit;    cur   = tt_encodings;    limit = cur + sizeof ( tt_encodings ) / sizeof ( tt_encodings[0] );    for ( ; cur < limit; cur++ )    {      if ( cur->platform_id == platform_id )      {        if ( cur->encoding_id == encoding_id ||             cur->encoding_id == -1          )          return cur->encoding;      }    }    return FT_ENCODING_NONE;  }  /* Fill in face->ttc_header.  If the font is not a TTC, it is */  /* synthesized into a TTC with one offset table.              */  static FT_Error  sfnt_open_font( FT_Stream  stream,                  TT_Face    face )  {    FT_Memory  memory = stream->memory;    FT_Error   error;    FT_ULong   tag, offset;    static const FT_Frame_Field  ttc_header_fields[] =    {#undef  FT_STRUCTURE#define FT_STRUCTURE  TTC_HeaderRec      FT_FRAME_START( 8 ),        FT_FRAME_LONG( version ),        FT_FRAME_LONG( count   ),

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -