亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? ftxgpos.c

?? 字體縮放顯示
?? C
?? 第 1 頁(yè) / 共 5 頁(yè)
字號(hào):
/******************************************************************* * *  ftxgpos.c * *    TrueType Open GPOS table support. * *  Copyright 1996-2001 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. * ******************************************************************//* XXX There is *a lot* of duplicated code (cf. formats 7 and 8), but       I don't care currently.  I believe that it would be possible to       save about 50% of TTO code by carefully designing the structures,       sharing as much as possible with extensive use of macros.  This       is something for a volunteer :-)                                  */#include "tttypes.h"#include "tttags.h"#include "ttload.h"#include "ttextend.h"#include "ttmemory.h"#include "ttfile.h"#include "ftxopen.h"#include "ftxopenf.h"  struct  GPOS_Instance_  {    TTO_GPOSHeader*  gpos;    TT_Instance      instance;    TT_Glyph         glyph;    UShort           load_flags;  /* how the glyph should be loaded */    TT_Bool          r2l;    UShort           first;       /* the first glyph in a chain of                                     cursive connections           */    UShort           last;        /* the last valid glyph -- used                                     with cursive positioning     */    TT_Pos           anchor_x;    /* the coordinates of the anchor point */    TT_Pos           anchor_y;    /* of the last valid glyph             */  };  typedef struct GPOS_Instance_  GPOS_Instance;  static TT_Error  Do_Glyph_Lookup( GPOS_Instance*    gpi,                                    UShort            lookup_index,                                    TTO_GSUB_String*  in,                                    TTO_GPOS_Data*    out,                                    UShort            context_length,                                    int               nesting_level );  /**********************   * Extension Functions   **********************/  /* the client application must replace this with something more     meaningful if multiple master fonts are to be supported.     */  static TT_Error  default_mmfunc( TT_Instance  instance,                                   TT_UShort    metric_id,                                   TT_Pos*      metric_value,                                   void*        data )  {    return TTO_Err_No_MM_Interpreter;  }  static TT_Error  GPOS_Create( void*  ext,                                PFace  face )  {    DEFINE_LOAD_LOCALS( face->stream );    TTO_GPOSHeader*  gpos = (TTO_GPOSHeader*)ext;    Long             table;    /* by convention */    if ( !gpos )      return TT_Err_Ok;    /* a null offset indicates that there is no GPOS table */    gpos->offset = 0;    /* we store the start offset and the size of the subtable */    table = TT_LookUp_Table( face, TTAG_GPOS );    if ( table < 0 )      return TT_Err_Ok;             /* The table is optional */    if ( FILE_Seek( face->dirTables[table].Offset ) ||         ACCESS_Frame( 4L ) )      return error;    gpos->offset  = FILE_Pos() - 4L;    /* undo ACCESS_Frame() */    gpos->Version = GET_ULong();    FORGET_Frame();    /* a default mmfunc() handler which just returns an error */    gpos->mmfunc = default_mmfunc;    /* the default glyph function is TT_Load_Glyph() */    gpos->gfunc = TT_Load_Glyph;    gpos->loaded = FALSE;    return TT_Err_Ok;  }  static TT_Error  GPOS_Destroy( void*  ext,                                 PFace  face )  {    TTO_GPOSHeader*  gpos = (TTO_GPOSHeader*)ext;    /* by convention */    if ( !gpos )      return TT_Err_Ok;    if ( gpos->loaded )    {      Free_LookupList( &gpos->LookupList, GPOS );      Free_FeatureList( &gpos->FeatureList );      Free_ScriptList( &gpos->ScriptList );    }    return TT_Err_Ok;  }  FT_EXPORT_FUNC( TT_Error )  TT_Init_GPOS_Extension( TT_Engine  engine )  {    PEngine_Instance  _engine = HANDLE_Engine( engine );    if ( !_engine )      return TT_Err_Invalid_Engine;    return  TT_Register_Extension( _engine,                                   GPOS_ID,                                   sizeof ( TTO_GPOSHeader ),                                   GPOS_Create,                                   GPOS_Destroy );  }  FT_EXPORT_FUNC( TT_Error )  TT_Load_GPOS_Table( TT_Face          face,                      TTO_GPOSHeader*  retptr,                      TTO_GDEFHeader*  gdef )  {    ULong            cur_offset, new_offset, base_offset;    UShort           i, num_lookups;    TTO_GPOSHeader*  gpos;    TTO_GDEFHeader*  gdef_reg;    TTO_Lookup*      lo;    PFace  faze = HANDLE_Face( face );    DEFINE_ALL_LOCALS;    if ( !retptr )      return TT_Err_Invalid_Argument;    if ( !faze )      return TT_Err_Invalid_Face_Handle;    error = TT_Extension_Get( faze, GPOS_ID, (void**)&gpos );    if ( error )      return error;    if ( gpos->offset == 0 )      return TT_Err_Table_Missing;      /* no GPOS table; nothing to do */    /* now access stream */    if ( USE_Stream( faze->stream, stream ) )      return error;    base_offset = gpos->offset;    /* skip version */    if ( FILE_Seek( base_offset + 4L ) ||         ACCESS_Frame( 2L ) )      return error;    new_offset = GET_UShort() + base_offset;    FORGET_Frame();    cur_offset = FILE_Pos();    if ( FILE_Seek( new_offset ) ||         ( error = Load_ScriptList( &gpos->ScriptList,                                    faze ) ) != TT_Err_Ok )      return error;    (void)FILE_Seek( cur_offset );    if ( ACCESS_Frame( 2L ) )      goto Fail3;    new_offset = GET_UShort() + base_offset;    FORGET_Frame();    cur_offset = FILE_Pos();    if ( FILE_Seek( new_offset ) ||         ( error = Load_FeatureList( &gpos->FeatureList,                                     faze ) ) != TT_Err_Ok )      goto Fail3;    (void)FILE_Seek( cur_offset );    if ( ACCESS_Frame( 2L ) )      goto Fail2;    new_offset = GET_UShort() + base_offset;    FORGET_Frame();    cur_offset = FILE_Pos();    if ( FILE_Seek( new_offset ) ||         ( error = Load_LookupList( &gpos->LookupList,                                    faze, GPOS ) ) != TT_Err_Ok )      goto Fail2;    gpos->gdef = gdef;      /* can be NULL */    /* We now check the LookupFlags for values larger than 0xFF to find       out whether we need to load the `MarkAttachClassDef' field of the       GDEF table -- this hack is necessary for OpenType 1.2 tables since       the version field of the GDEF table hasn't been incremented.       For constructed GDEF tables, we only load it if       `MarkAttachClassDef_offset' is not zero (nevertheless, a build of       a constructed mark attach table is not supported currently).       */    if ( gdef &&         gdef->MarkAttachClassDef_offset && !gdef->MarkAttachClassDef.loaded )    {      lo          = gpos->LookupList.Lookup;      num_lookups = gpos->LookupList.LookupCount;      for ( i = 0; i < num_lookups; i++ )      {        if ( lo[i].LookupFlag & IGNORE_SPECIAL_MARKS )        {          if ( FILE_Seek( gdef->MarkAttachClassDef_offset ) ||               ACCESS_Frame( 2L ) )            goto Fail1;          new_offset = GET_UShort();          FORGET_Frame();          if ( !new_offset )            return TTO_Err_Invalid_GDEF_SubTable;          new_offset += gdef->offset;          if ( FILE_Seek( new_offset ) ||               ( error = Load_ClassDefinition( &gdef->MarkAttachClassDef,                                               256, faze ) ) != TT_Err_Ok )            goto Fail1;          /* copy the class definition pointer into the extension structure */          error = TT_Extension_Get( faze, GDEF_ID, (void**)&gdef_reg );          if ( error )            return error;          *gdef_reg = *gdef;          break;        }      }    }    gpos->loaded = TRUE;    *retptr = *gpos;    DONE_Stream( stream );    return TT_Err_Ok;  Fail1:    Free_LookupList( &gpos->LookupList, GPOS );  Fail2:    Free_FeatureList( &gpos->FeatureList );  Fail3:    Free_ScriptList( &gpos->ScriptList );    /* release stream */    DONE_Stream( stream );    return error;  }  /*****************************   * SubTable related functions   *****************************/  /* shared tables */  /* ValueRecord */  /* There is a subtle difference in the specs between a `table' and a     `record' -- offsets for device tables in ValueRecords are taken from     the parent table and not the parent record.                          */  static TT_Error  Load_ValueRecord( TTO_ValueRecord*  vr,                                     UShort            format,                                     ULong             base_offset,                                     PFace             input )  {    DEFINE_LOAD_LOCALS( input->stream );    ULong    cur_offset, new_offset;    if ( format & HAVE_X_PLACEMENT )    {      if ( ACCESS_Frame( 2L ) )        return error;      vr->XPlacement = GET_Short();      FORGET_Frame();    }    else      vr->XPlacement = 0;    if ( format & HAVE_Y_PLACEMENT )    {      if ( ACCESS_Frame( 2L ) )        return error;      vr->YPlacement = GET_Short();      FORGET_Frame();    }    else      vr->YPlacement = 0;    if ( format & HAVE_X_ADVANCE )    {      if ( ACCESS_Frame( 2L ) )        return error;      vr->XAdvance = GET_Short();      FORGET_Frame();    }    else      vr->XAdvance = 0;    if ( format & HAVE_Y_ADVANCE )    {      if ( ACCESS_Frame( 2L ) )        return error;      vr->YAdvance = GET_Short();      FORGET_Frame();    }    else      vr->YAdvance = 0;    if ( format & HAVE_X_PLACEMENT_DEVICE )    {      if ( ACCESS_Frame( 2L ) )        return error;      new_offset = GET_UShort();      FORGET_Frame();      if ( new_offset )      {        new_offset += base_offset;        cur_offset = FILE_Pos();        if ( FILE_Seek( new_offset ) ||             ( error = Load_Device( &vr->XPlacementDevice,                                    input ) ) != TT_Err_Ok )          return error;        (void)FILE_Seek( cur_offset );      }      else        goto empty1;    }    else    {    empty1:      vr->XPlacementDevice.StartSize  = 0;      vr->XPlacementDevice.EndSize    = 0;      vr->XPlacementDevice.DeltaValue = NULL;    }    if ( format & HAVE_Y_PLACEMENT_DEVICE )    {      if ( ACCESS_Frame( 2L ) )        goto Fail3;      new_offset = GET_UShort();      FORGET_Frame();      if ( new_offset )      {        new_offset += base_offset;        cur_offset = FILE_Pos();        if ( FILE_Seek( new_offset ) ||             ( error = Load_Device( &vr->YPlacementDevice,                                    input ) ) != TT_Err_Ok )          goto Fail3;        (void)FILE_Seek( cur_offset );      }      else        goto empty2;    }    else    {    empty2:      vr->YPlacementDevice.StartSize  = 0;      vr->YPlacementDevice.EndSize    = 0;      vr->YPlacementDevice.DeltaValue = NULL;    }    if ( format & HAVE_X_ADVANCE_DEVICE )    {      if ( ACCESS_Frame( 2L ) )        goto Fail2;      new_offset = GET_UShort();      FORGET_Frame();      if ( new_offset )      {        new_offset += base_offset;        cur_offset = FILE_Pos();        if ( FILE_Seek( new_offset ) ||             ( error = Load_Device( &vr->XAdvanceDevice,                                    input ) ) != TT_Err_Ok )          goto Fail2;        (void)FILE_Seek( cur_offset );      }      else        goto empty3;    }    else    {    empty3:      vr->XAdvanceDevice.StartSize  = 0;      vr->XAdvanceDevice.EndSize    = 0;      vr->XAdvanceDevice.DeltaValue = NULL;    }    if ( format & HAVE_Y_ADVANCE_DEVICE )    {      if ( ACCESS_Frame( 2L ) )        goto Fail1;      new_offset = GET_UShort();      FORGET_Frame();      if ( new_offset )      {        new_offset += base_offset;        cur_offset = FILE_Pos();        if ( FILE_Seek( new_offset ) ||             ( error = Load_Device( &vr->YAdvanceDevice,                                    input ) ) != TT_Err_Ok )          goto Fail1;        (void)FILE_Seek( cur_offset );      }      else        goto empty4;    }    else    {    empty4:      vr->YAdvanceDevice.StartSize  = 0;      vr->YAdvanceDevice.EndSize    = 0;      vr->YAdvanceDevice.DeltaValue = NULL;    }    if ( format & HAVE_X_ID_PLACEMENT )    {      if ( ACCESS_Frame( 2L ) )        goto Fail1;      vr->XIdPlacement = GET_UShort();      FORGET_Frame();    }    else      vr->XIdPlacement = 0;    if ( format & HAVE_Y_ID_PLACEMENT )    {      if ( ACCESS_Frame( 2L ) )        goto Fail1;      vr->YIdPlacement = GET_UShort();      FORGET_Frame();    }    else      vr->YIdPlacement = 0;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
高清国产一区二区| 欧美成人vps| 一本大道久久a久久精二百| 成人av综合一区| 成人小视频在线观看| 成人中文字幕在线| www.66久久| 99在线热播精品免费| av电影在线观看完整版一区二区| 成人精品在线视频观看| 国产成人精品影院| 成人免费精品视频| 91亚洲午夜精品久久久久久| 91福利在线导航| 欧美日韩国产影片| 日韩美一区二区三区| 久久久蜜桃精品| 国产精品理论片| 亚洲美女偷拍久久| 亚洲国产成人91porn| 免费看日韩精品| 精品在线一区二区| 成人午夜激情影院| 一本久久综合亚洲鲁鲁五月天 | 色综合久久久久综合99| 色综合天天综合网天天狠天天| 欧美亚洲国产一区二区三区va | 欧美日韩1234| 日韩精品一区二区三区视频| 国产三级精品三级| 亚洲精品视频一区二区| 日韩电影在线免费看| 国产ts人妖一区二区| 色天使色偷偷av一区二区| 884aa四虎影成人精品一区| 久久午夜免费电影| 亚洲日本丝袜连裤袜办公室| 午夜精品久久久久久久蜜桃app| 麻豆中文一区二区| 不卡一区中文字幕| 777色狠狠一区二区三区| 久久精品欧美一区二区三区不卡| 亚洲视频一区在线观看| 日韩av电影天堂| 成人免费va视频| 91精品国产综合久久精品app| 久久久久88色偷偷免费| 一区二区三区国产精华| 韩国av一区二区三区在线观看| 99国产精品一区| 日韩亚洲欧美在线| 亚洲美女少妇撒尿| 国产一区日韩二区欧美三区| 91免费观看在线| 91精品国产欧美一区二区成人| 国产精品久久久久久久岛一牛影视 | 肉色丝袜一区二区| 福利视频网站一区二区三区| 337p亚洲精品色噜噜噜| 中文一区二区完整视频在线观看| 视频一区二区不卡| 91小视频免费看| 久久精品这里都是精品| 天天综合日日夜夜精品| 91热门视频在线观看| 精品黑人一区二区三区久久| 一区二区久久久| 成人做爰69片免费看网站| 日韩一区二区三区四区| 一区二区视频免费在线观看| 国产经典欧美精品| 欧美一区二区性放荡片| 一区二区三区视频在线观看| 成人黄色综合网站| 久久蜜桃av一区二区天堂 | 成人激情图片网| 日韩欧美成人一区| 偷拍自拍另类欧美| 色婷婷亚洲精品| 国产精品大尺度| 国产91清纯白嫩初高中在线观看| 日韩欧美亚洲一区二区| 视频一区二区中文字幕| 欧美影院一区二区| 亚洲理论在线观看| 99精品1区2区| 国产精品视频一区二区三区不卡| 狠狠色狠狠色合久久伊人| 日韩一区二区三区精品视频| 亚洲国产另类精品专区| 色婷婷一区二区三区四区| 综合久久国产九一剧情麻豆| 国产sm精品调教视频网站| 久久综合狠狠综合久久综合88| 久久精品国产免费看久久精品| 欧美女孩性生活视频| 亚洲成人激情综合网| 在线观看日韩精品| 亚洲一区二区三区免费视频| 欧美伊人久久久久久午夜久久久久| 亚洲美女视频在线观看| 色婷婷av久久久久久久| 一区二区三区欧美日韩| 在线影视一区二区三区| 亚洲综合精品自拍| 欧美日韩精品一区二区三区蜜桃| 亚洲国产sm捆绑调教视频| 欧美色欧美亚洲另类二区| 亚洲国产精品久久久男人的天堂| 在线视频综合导航| 亚洲va欧美va天堂v国产综合| 欧美日韩国产影片| 男女激情视频一区| 久久久午夜精品理论片中文字幕| 国产成人自拍网| 一区在线观看视频| 色女孩综合影院| 午夜不卡av免费| 欧美一区二区大片| 国产综合色精品一区二区三区| 国产欧美一区在线| 色综合一个色综合| 视频在线在亚洲| 精品久久一区二区三区| 国产成人免费视频网站 | fc2成人免费人成在线观看播放| 国产精品久久久久久妇女6080| 91激情在线视频| 日韩av电影天堂| 国产欧美日韩三级| 欧美亚洲综合网| 九九精品一区二区| 亚洲欧洲日产国产综合网| 欧美日韩一区二区在线视频| 另类小说视频一区二区| 国产精品你懂的| 欧美日韩免费一区二区三区视频| 久久国产精品露脸对白| 最新欧美精品一区二区三区| 欧美精品色综合| 国产精一区二区三区| 亚洲精品日韩一| 日韩精品一区二区三区四区| 成人精品一区二区三区中文字幕 | 欧洲亚洲国产日韩| 久热成人在线视频| 中文字幕中文字幕一区二区| 91精选在线观看| av成人老司机| 日韩av电影免费观看高清完整版 | 午夜激情一区二区三区| 国产亚洲欧美日韩俺去了| 91麻豆swag| 久久精品国产澳门| 亚洲精品午夜久久久| 精品久久久久久久一区二区蜜臀| 色综合中文字幕国产| 久久av中文字幕片| 亚洲精品亚洲人成人网在线播放| 欧美精品一区二区久久婷婷 | 亚洲狼人国产精品| www成人在线观看| 欧美性xxxxxxxx| 国产v综合v亚洲欧| 美女久久久精品| 一区二区三区高清在线| 久久网站最新地址| 91.xcao| 在线一区二区三区做爰视频网站| 国产乱人伦偷精品视频不卡 | 91一区二区在线| 韩国精品一区二区| 日韩av一区二区在线影视| 亚洲欧洲韩国日本视频| 久久在线观看免费| 欧美一级夜夜爽| 欧美日韩大陆在线| 色狠狠av一区二区三区| 不卡区在线中文字幕| 国产一区福利在线| 天堂在线亚洲视频| 亚洲精品视频在线| 国产精品国产三级国产aⅴ无密码| 久久综合狠狠综合久久综合88 | 综合自拍亚洲综合图不卡区| 精品91自产拍在线观看一区| 欧美精品乱码久久久久久| 91啪九色porn原创视频在线观看| 国产成人在线影院| 国产精品综合网| 激情欧美一区二区| 另类中文字幕网| 美女任你摸久久| 蜜臀久久99精品久久久久宅男 | 国产黄人亚洲片| 精品中文av资源站在线观看| 欧美a一区二区| 日本网站在线观看一区二区三区| 午夜久久久久久久久久一区二区| 一区二区三区久久久|