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

📄 ttload.c

📁 qt-embedded-2.3.8.tar.gz源码
💻 C
📖 第 1 页 / 共 5 页
字号:
    {      error = face->goto_table( face, TTAG_hmtx, stream, &table_len );      if ( error )      {        FT_ERROR(( " no horizontal metrics in file!\n" ));        error = TT_Err_Hmtx_Table_Missing;        goto Exit;      }      num_longs = face->horizontal.number_Of_HMetrics;      longs     = (TT_LongMetrics**)&face->horizontal.long_metrics;      shorts    = (TT_ShortMetrics**)&face->horizontal.short_metrics;    }    /* never trust derived values */    num_shorts         = face->max_profile.numGlyphs - num_longs;    num_shorts_checked = ( table_len - num_longs * 4L ) / 2;    if ( num_shorts < 0 )    {      FT_ERROR(( "TT_Load_%s_Metrics: more metrics than glyphs!\n",                 vertical ? "Vertical"                          : "Horizontal" ));      error = vertical ? TT_Err_Invalid_Vert_Metrics                       : TT_Err_Invalid_Horiz_Metrics;      goto Exit;    }    if ( ALLOC_ARRAY( *longs,  num_longs,  TT_LongMetrics )  ||         ALLOC_ARRAY( *shorts, num_shorts, TT_ShortMetrics ) )      goto Exit;    if ( ACCESS_Frame( table_len ) )      goto Exit;    {      TT_LongMetrics*  cur   = *longs;      TT_LongMetrics*  limit = cur + num_longs;      for ( ; cur < limit; cur++ )      {        cur->advance = GET_UShort();        cur->bearing = GET_Short();      }    }    /* do we have an inconsistent number of metric values? */    {      TT_ShortMetrics*  cur   = *shorts;      TT_ShortMetrics*  limit = cur + MIN( num_shorts, num_shorts_checked );      for ( ; cur < limit; cur++ )        *cur = GET_Short();      /* we fill up the missing left side bearings with the     */      /* last valid value.  Since this will occur for buggy CJK */      /* fonts usually only, nothing serious will happen        */      if ( num_shorts > num_shorts_checked && num_shorts_checked > 0 )      {        FT_Short  val = *(shorts)[num_shorts_checked - 1];        limit = *shorts + num_shorts;        for ( ; cur < limit; cur++ )          *cur = val;      }    }    FORGET_Frame();    FT_TRACE2(( "loaded\n" ));  Exit:    return error;  }  /*************************************************************************/  /*                                                                       */  /* <Function>                                                            */  /*    TT_Load_Metrics_Header                                             */  /*                                                                       */  /* <Description>                                                         */  /*    Loads the horizontal or vertical header in a face object.          */  /*                                                                       */  /* <Input>                                                               */  /*    face     :: A handle to the target face object.                    */  /*    stream   :: The input stream.                                      */  /*    vertical :: A boolean flag.  If set, load vertical metrics.        */  /*                                                                       */  /* <Return>                                                              */  /*    FreeType error code.  0 means success.                             */  /*                                                                       */  FT_LOCAL_DEF  FT_Error  TT_Load_Metrics_Header( TT_Face    face,                                    FT_Stream  stream,                                    FT_Bool    vertical )  {    FT_Error        error;    TT_HoriHeader*  header;    const FT_Frame_Field  metrics_header_fields[] =    {#undef  FT_STRUCTURE#define FT_STRUCTURE  TT_HoriHeader      FT_FRAME_START( 36 ),        FT_FRAME_ULONG ( Version ),        FT_FRAME_SHORT ( Ascender ),        FT_FRAME_SHORT ( Descender ),        FT_FRAME_SHORT ( Line_Gap ),        FT_FRAME_USHORT( advance_Width_Max ),        FT_FRAME_SHORT ( min_Left_Side_Bearing ),        FT_FRAME_SHORT ( min_Right_Side_Bearing ),        FT_FRAME_SHORT ( xMax_Extent ),        FT_FRAME_SHORT ( caret_Slope_Rise ),        FT_FRAME_SHORT ( caret_Slope_Run ),        FT_FRAME_SHORT ( Reserved[0] ),        FT_FRAME_SHORT ( Reserved[1] ),        FT_FRAME_SHORT ( Reserved[2] ),        FT_FRAME_SHORT ( Reserved[3] ),        FT_FRAME_SHORT ( Reserved[4] ),        FT_FRAME_SHORT ( metric_Data_Format ),        FT_FRAME_USHORT( number_Of_HMetrics ),      FT_FRAME_END    };    FT_TRACE2(( vertical ? "Vertical header " : "Horizontal header " ));    if ( vertical )    {      face->vertical_info = 0;      /* The vertical header table is optional, so return quietly if */      /* we don't find it.                                           */      error = face->goto_table( face, TTAG_vhea, stream, 0 );      if ( error )      {        error = TT_Err_Ok;        goto Exit;      }      face->vertical_info = 1;      header = (TT_HoriHeader*)&face->vertical;    }    else    {      /* The horizontal header is mandatory; return an error if we */      /* don't find it.                                            */      error = face->goto_table( face, TTAG_hhea, stream, 0 );      if ( error )      {        error = TT_Err_Horiz_Header_Missing;        goto Exit;      }      header = &face->horizontal;    }    if ( READ_Fields( metrics_header_fields, header ) )      goto Exit;    header->long_metrics  = NULL;    header->short_metrics = NULL;    FT_TRACE2(( "loaded\n" ));    /* Now try to load the corresponding metrics */    error = TT_Load_Metrics( face, stream, vertical );  Exit:    return error;  }  /*************************************************************************/  /*                                                                       */  /* <Function>                                                            */  /*    TT_Load_Names                                                      */  /*                                                                       */  /* <Description>                                                         */  /*    Loads the name records.                                            */  /*                                                                       */  /* <Input>                                                               */  /*    face   :: A handle to the target face object.                      */  /*    stream :: The input stream.                                        */  /*                                                                       */  /* <Return>                                                              */  /*    FreeType error code.  0 means success.                             */  /*                                                                       */  FT_LOCAL_DEF  FT_Error  TT_Load_Names( TT_Face    face,                           FT_Stream  stream )  {    FT_Error   error;    FT_Memory  memory = stream->memory;    FT_ULong   table_pos, table_len;    FT_ULong   storageSize;    TT_NameTable*  names;    const FT_Frame_Field  name_table_fields[] =    {#undef  FT_STRUCTURE#define FT_STRUCTURE  TT_NameTable      FT_FRAME_START( 6 ),        FT_FRAME_USHORT( format ),        FT_FRAME_USHORT( numNameRecords ),        FT_FRAME_USHORT( storageOffset ),      FT_FRAME_END    };    const FT_Frame_Field  name_record_fields[] =    {#undef  FT_STRUCTURE#define FT_STRUCTURE  TT_NameRec      /* no FT_FRAME_START */        FT_FRAME_USHORT( platformID ),        FT_FRAME_USHORT( encodingID ),        FT_FRAME_USHORT( languageID ),        FT_FRAME_USHORT( nameID ),        FT_FRAME_USHORT( stringLength ),        FT_FRAME_USHORT( stringOffset ),      FT_FRAME_END    };    FT_TRACE2(( "Names " ));    error = face->goto_table( face, TTAG_name, stream, &table_len );    if ( error )    {      /* The name table is required so indicate failure. */      FT_TRACE2(( "is missing!\n" ));      error = TT_Err_Name_Table_Missing;      goto Exit;    }    table_pos = FILE_Pos();    names = &face->name_table;    if ( READ_Fields( name_table_fields, names ) )      goto Exit;    /* Allocate the array of name records. */    if ( ALLOC_ARRAY( names->names,                      names->numNameRecords,                      TT_NameRec )                   ||         ACCESS_Frame( names->numNameRecords * 12L ) )      goto Exit;    /* Load the name records and determine how much storage is needed */    /* to hold the strings themselves.                                */    {      TT_NameRec*  cur   = names->names;      TT_NameRec*  limit = cur + names->numNameRecords;      storageSize = 0;      for ( ; cur < limit; cur ++ )      {        FT_ULong  upper;        if ( READ_Fields( name_record_fields, cur ) )          break;        upper = (FT_ULong)( cur->stringOffset + cur->stringLength );        if ( upper > storageSize )          storageSize = upper;      }    }    FORGET_Frame();    if ( storageSize > 0 )    {      /* allocate the name storage area in memory, then read it */      if ( ALLOC( names->storage, storageSize )               ||           FILE_Read_At( table_pos + names->storageOffset,                         names->storage, storageSize ) )        goto Exit;      /* Go through and assign the string pointers to the name records. */      {        TT_NameRec*  cur   = names->names;        TT_NameRec*  limit = cur + names->numNameRecords;        for ( ; cur < limit; cur++ )          cur->string = names->storage + cur->stringOffset;      }#ifdef FT_DEBUG_LEVEL_TRACE      /* Print Name Record Table in case of debugging */      {        TT_NameRec*  cur   = names->names;        TT_NameRec*  limit = cur + names->numNameRecords;        for ( ; cur < limit; cur++ )        {          FT_UInt  j;          FT_TRACE3(( "%d %d %x %d\n  ",                       cur->platformID,                       cur->encodingID,                       cur->languageID,                       cur->nameID ));          /* I know that M$ encoded strings are Unicode,            */          /* but this works reasonable well for debugging purposes. */          if ( cur->string )            for ( j = 0; j < cur->stringLength; j++ )            {              FT_Char  c = *( cur->string + j );              if ( (FT_Byte)c < 128 )                FT_TRACE3(( "%c", c ));            }        }      }      FT_TRACE3(( "\n" ));#endif /* FT_DEBUG_LEVEL_TRACE */    }    FT_TRACE2(( "loaded\n" ));    /* everything went well, update face->num_names */    face->num_names = names->numNameRecords;  Exit:    return error;  }

⌨️ 快捷键说明

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