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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ftmemory.h

?? a very goog book
?? H
字號:
/***************************************************************************//*                                                                         *//*  ftmemory.h                                                             *//*                                                                         *//*    The FreeType memory management macros (specification).               *//*                                                                         *//*  Copyright 1996-2001, 2002 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 __FTMEMORY_H__#define __FTMEMORY_H__#include <ft2build.h>#include FT_CONFIG_CONFIG_H#include FT_TYPES_HFT_BEGIN_HEADER  /*************************************************************************/  /*                                                                       */  /* <Macro>                                                               */  /*    FT_SET_ERROR                                                       */  /*                                                                       */  /* <Description>                                                         */  /*    This macro is used to set an implicit `error' variable to a given  */  /*    expression's value (usually a function call), and convert it to a  */  /*    boolean which is set whenever the value is != 0.                   */  /*                                                                       */#undef  FT_SET_ERROR#define FT_SET_ERROR( expression ) \          ( ( error = (expression) ) != 0 )  /*************************************************************************/  /*************************************************************************/  /*************************************************************************/  /****                                                                 ****/  /****                                                                 ****/  /****                           M E M O R Y                           ****/  /****                                                                 ****/  /****                                                                 ****/  /*************************************************************************/  /*************************************************************************/  /*************************************************************************/#ifdef FT_DEBUG_MEMORY  FT_BASE( FT_Error )  FT_Alloc_Debug( FT_Memory    memory,                  FT_Long      size,                  void*       *P,                  const char*  file_name,                  FT_Long      line_no );  FT_BASE( FT_Error )  FT_Realloc_Debug( FT_Memory    memory,                    FT_Long      current,                    FT_Long      size,                    void*       *P,                    const char*  file_name,                    FT_Long      line_no );  FT_BASE( void )  FT_Free_Debug( FT_Memory    memory,                 FT_Pointer   block,                 const char*  file_name,                 FT_Long      line_no );#endif  /*************************************************************************/  /*                                                                       */  /* <Function>                                                            */  /*    FT_Alloc                                                           */  /*                                                                       */  /* <Description>                                                         */  /*    Allocates a new block of memory.  The returned area is always      */  /*    zero-filled; this is a strong convention in many FreeType parts.   */  /*                                                                       */  /* <Input>                                                               */  /*    memory :: A handle to a given `memory object' which handles        */  /*              allocation.                                              */  /*                                                                       */  /*    size   :: The size in bytes of the block to allocate.              */  /*                                                                       */  /* <Output>                                                              */  /*    P      :: A pointer to the fresh new block.  It should be set to   */  /*              NULL if `size' is 0, or in case of error.                */  /*                                                                       */  /* <Return>                                                              */  /*    FreeType error code.  0 means success.                             */  /*                                                                       */  FT_BASE( FT_Error )  FT_Alloc( FT_Memory  memory,            FT_Long    size,            void*     *P );  /*************************************************************************/  /*                                                                       */  /* <Function>                                                            */  /*    FT_Realloc                                                         */  /*                                                                       */  /* <Description>                                                         */  /*    Reallocates a block of memory pointed to by `*P' to `Size' bytes   */  /*    from the heap, possibly changing `*P'.                             */  /*                                                                       */  /* <Input>                                                               */  /*    memory  :: A handle to a given `memory object' which handles       */  /*               reallocation.                                           */  /*                                                                       */  /*    current :: The current block size in bytes.                        */  /*                                                                       */  /*    size    :: The new block size in bytes.                            */  /*                                                                       */  /* <InOut>                                                               */  /*    P       :: A pointer to the fresh new block.  It should be set to  */  /*               NULL if `size' is 0, or in case of error.               */  /*                                                                       */  /* <Return>                                                              */  /*    FreeType error code.  0 means success.                             */  /*                                                                       */  /* <Note>                                                                */  /*    All callers of FT_Realloc() _must_ provide the current block size  */  /*    as well as the new one.                                            */  /*                                                                       */  FT_BASE( FT_Error )  FT_Realloc( FT_Memory  memory,              FT_Long    current,              FT_Long    size,              void**     P );  /*************************************************************************/  /*                                                                       */  /* <Function>                                                            */  /*    FT_Free                                                            */  /*                                                                       */  /* <Description>                                                         */  /*    Releases a given block of memory allocated through FT_Alloc().     */  /*                                                                       */  /* <Input>                                                               */  /*    memory :: A handle to a given `memory object' which handles        */  /*              memory deallocation                                      */  /*                                                                       */  /*    P      :: This is the _address_ of a _pointer_ which points to the */  /*              allocated block.  It is always set to NULL on exit.      */  /*                                                                       */  /* <Return>                                                              */  /*    FreeType error code.  0 means success.                             */  /*                                                                       */  /* <Note>                                                                */  /*    If P or *P are NULL, this function should return successfully.     */  /*    This is a strong convention within all of FreeType and its         */  /*    drivers.                                                           */  /*                                                                       */  FT_BASE( void )  FT_Free( FT_Memory  memory,           void**     P );#define FT_MEM_SET( dest, byte, count )     ft_memset( dest, byte, count )#define FT_MEM_COPY( dest, source, count )  ft_memcpy( dest, source, count )#define FT_MEM_MOVE( dest, source, count )  ft_memmove( dest, source, count )#define FT_MEM_ZERO( dest, count )  FT_MEM_SET( dest, 0, count )#define FT_ZERO( p )                FT_MEM_ZERO( p, sizeof ( *(p) ) )  /*************************************************************************/  /*                                                                       */  /* We first define FT_MEM_ALLOC, FT_MEM_REALLOC, and FT_MEM_FREE.  All   */  /* macros use an _implicit_ `memory' parameter to access the current     */  /* memory allocator.                                                     */  /*                                                                       */#ifdef FT_DEBUG_MEMORY#define FT_MEM_ALLOC( _pointer_, _size_ )                            \          FT_Alloc_Debug( memory, _size_,                            \                          (void**)&(_pointer_), __FILE__, __LINE__ )#define FT_MEM_REALLOC( _pointer_, _current_, _size_ )                 \          FT_Realloc_Debug( memory, _current_, _size_,                 \                            (void**)&(_pointer_), __FILE__, __LINE__ )#define FT_MEM_FREE( _pointer_ )                                            \          FT_Free_Debug( memory, (void**)&(_pointer_), __FILE__, __LINE__ )#else  /* !FT_DEBUG_MEMORY */#define FT_MEM_ALLOC( _pointer_, _size_ )                  \          FT_Alloc( memory, _size_, (void**)&(_pointer_) )#define FT_MEM_FREE( _pointer_ )                  \          FT_Free( memory, (void**)&(_pointer_) )#define FT_MEM_REALLOC( _pointer_, _current_, _size_ )                  \          FT_Realloc( memory, _current_, _size_, (void**)&(_pointer_) )#endif /* !FT_DEBUG_MEMORY */  /*************************************************************************/  /*                                                                       */  /* The following functions macros expect that their pointer argument is  */  /* _typed_ in order to automatically compute array element sizes.        */  /*                                                                       */#define FT_MEM_NEW( _pointer_ )                               \          FT_MEM_ALLOC( _pointer_, sizeof ( *(_pointer_) ) )#define FT_MEM_NEW_ARRAY( _pointer_, _count_ )                           \          FT_MEM_ALLOC( _pointer_, (_count_) * sizeof ( *(_pointer_) ) )#define FT_MEM_RENEW_ARRAY( _pointer_, _old_, _new_ )                    \          FT_MEM_REALLOC( _pointer_, (_old_) * sizeof ( *(_pointer_) ),  \                                     (_new_) * sizeof ( *(_pointer_) ) )  /*************************************************************************/  /*                                                                       */  /* the following macros are obsolete but kept for compatibility reasons  */  /*                                                                       */#define FT_MEM_ALLOC_ARRAY( _pointer_, _count_, _type_ )           \          FT_MEM_ALLOC( _pointer_, (_count_) * sizeof ( _type_ ) )#define FT_MEM_REALLOC_ARRAY( _pointer_, _old_, _new_, _type_ )    \          FT_MEM_REALLOC( _pointer_, (_old_) * sizeof ( _type ),   \                                     (_new_) * sizeof ( _type_ ) )  /*************************************************************************/  /*                                                                       */  /* The following macros are variants of their FT_MEM_XXXX equivalents;   */  /* they are used to set an _implicit_ `error' variable and return TRUE   */  /* if an error occured (i.e. if 'error != 0').                           */  /*                                                                       */#define FT_ALLOC( _pointer_, _size_ )                       \          FT_SET_ERROR( FT_MEM_ALLOC( _pointer_, _size_ ) )#define FT_REALLOC( _pointer_, _current_, _size_ )                       \          FT_SET_ERROR( FT_MEM_REALLOC( _pointer_, _current_, _size_ ) )#define FT_FREE( _pointer_ )       \          FT_MEM_FREE( _pointer_ )#define FT_NEW( _pointer_ )  \          FT_SET_ERROR( FT_MEM_NEW( _pointer_ ) )#define FT_NEW_ARRAY( _pointer_, _count_ )  \          FT_SET_ERROR( FT_MEM_NEW_ARRAY( _pointer_, _count_ ) )#define FT_RENEW_ARRAY( _pointer_, _old_, _new_ )   \          FT_SET_ERROR( FT_MEM_RENEW_ARRAY( _pointer_, _old_, _new_ ) )#define FT_ALLOC_ARRAY( _pointer_, _count_, _type_ )                    \          FT_SET_ERROR( FT_MEM_ALLOC( _pointer_,                        \                                      (_count_) * sizeof ( _type_ ) ) )#define FT_REALLOC_ARRAY( _pointer_, _old_, _new_, _type_ )             \          FT_SET_ERROR( FT_MEM_REALLOC( _pointer_,                      \                                        (_old_) * sizeof ( _type_ ),    \                                        (_new_) * sizeof ( _type_ ) ) ) /* */FT_END_HEADER#endif /* __FTMEMORY_H__ *//* END */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品粉嫩aⅴ一区二区三区四区| 豆国产96在线|亚洲| 久久99久久精品欧美| 国产成人av电影免费在线观看| www.色精品| 欧美男同性恋视频网站| 久久综合久久综合九色| 综合久久久久综合| 丝袜诱惑制服诱惑色一区在线观看| 裸体在线国模精品偷拍| jiyouzz国产精品久久| 91精品国产综合久久国产大片| 久久午夜羞羞影院免费观看| 亚洲欧美韩国综合色| 老司机午夜精品99久久| 99精品在线免费| 欧美一区二区视频在线观看2020| 国产三级精品三级在线专区| 亚洲国产日韩a在线播放| 国产在线视频一区二区| 在线欧美小视频| 久久蜜桃一区二区| 亚洲成人av中文| 成人精品一区二区三区四区| 欧美人动与zoxxxx乱| 国产精品乱人伦中文| 奇米777欧美一区二区| 91一区二区三区在线观看| 欧美成人精精品一区二区频| 亚洲综合久久久久| 成人午夜激情在线| 欧美精品一区二区三| 亚洲第一二三四区| 成人高清视频在线| 欧美精品一区二区三区在线| 午夜国产精品一区| 91丨国产丨九色丨pron| 国产日韩欧美精品综合| 免费三级欧美电影| 欧美伊人精品成人久久综合97| 日本一区二区三区在线不卡| 蜜桃在线一区二区三区| 欧美性做爰猛烈叫床潮| 亚洲欧美一区二区三区久本道91 | 91麻豆高清视频| www欧美成人18+| 青青草精品视频| 欧美日韩一区二区三区免费看 | 色综合天天综合网天天看片| 久久精品夜夜夜夜久久| 精品影院一区二区久久久| 欧美午夜电影在线播放| 亚洲精品成人少妇| 99视频热这里只有精品免费| 国产日韩精品一区二区三区| 精品一区二区在线看| 7878成人国产在线观看| 亚洲va在线va天堂| 欧美亚男人的天堂| 一区二区三区日韩精品视频| 99久久婷婷国产综合精品电影| 久久天堂av综合合色蜜桃网| 久久99精品久久只有精品| 日韩精品一区二区三区在线| 免费成人在线视频观看| 欧美一级二级三级乱码| 日韩电影免费一区| 欧美一级黄色片| 美女视频黄久久| 欧美一二三区在线| 美国十次了思思久久精品导航| 4hu四虎永久在线影院成人| 午夜久久久久久久久| 在线观看成人小视频| 亚洲一区二区三区精品在线| 欧美性一区二区| 调教+趴+乳夹+国产+精品| 制服.丝袜.亚洲.中文.综合| 日本亚洲一区二区| 日韩精品一区二区在线| 狠狠v欧美v日韩v亚洲ⅴ| 26uuu精品一区二区| 国产乱码精品一区二区三区五月婷| 久久影院午夜片一区| 国产精品66部| 亚洲特级片在线| 欧美综合色免费| 日本不卡一区二区三区高清视频| 日韩精品中午字幕| 国产99一区视频免费| 亚洲天堂免费看| 欧美区视频在线观看| 久久99精品视频| 中国色在线观看另类| 色综合久久综合| 亚洲第一精品在线| 欧美精品一区视频| 99国产精品国产精品久久| 一区二区国产盗摄色噜噜| 欧美日韩不卡一区| 国产剧情一区二区| 亚洲日本中文字幕区| 欧美高清视频不卡网| 精品一区二区三区免费| 国产精品日韩精品欧美在线| 在线亚洲+欧美+日本专区| 日韩avvvv在线播放| 国产欧美精品日韩区二区麻豆天美| 99久久亚洲一区二区三区青草| 亚洲一级电影视频| 337p日本欧洲亚洲大胆精品| 91原创在线视频| 日本va欧美va瓶| 国产精品美女久久久久av爽李琼| 欧美亚洲高清一区| 国产精品一二一区| 亚洲一区免费在线观看| 久久久久久久综合色一本| 色婷婷综合在线| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲精品免费一二三区| 亚洲精品一区二区三区精华液| 色欧美乱欧美15图片| 国产一区二区三区香蕉| 一区二区三区鲁丝不卡| 久久亚洲欧美国产精品乐播| 欧美性欧美巨大黑白大战| 国产精品538一区二区在线| 亚洲一级在线观看| 国产欧美日韩久久| 3atv一区二区三区| 色网站国产精品| 国产精品亚洲视频| 亚州成人在线电影| 国产精品家庭影院| 精品美女在线播放| 欧美在线观看一区二区| 成人一区二区三区视频| 青青青伊人色综合久久| 一区二区三区在线观看国产| 久久精品在线免费观看| 欧美精品久久99久久在免费线| eeuss国产一区二区三区| 久久精品国产精品亚洲红杏| 亚洲伊人色欲综合网| 国产精品青草综合久久久久99| 欧美一区二区国产| 欧美日韩视频在线一区二区| 不卡的av电影在线观看| 国产一区二区三区久久久| 婷婷激情综合网| 一区二区三区四区五区视频在线观看 | 国产精品久久久久久久久久久免费看 | 一区二区三区在线播| 国产女同性恋一区二区| 欧美大片在线观看一区二区| 欧美午夜片在线观看| 色综合欧美在线| 国产成人aaa| 国产黄色精品网站| 国精品**一区二区三区在线蜜桃 | 欧美精品一区二区不卡| 欧美丰满嫩嫩电影| 欧美丝袜丝交足nylons| 91成人免费电影| 91美女视频网站| www.欧美亚洲| 成人免费毛片aaaaa**| 国产一区二区伦理| 韩国一区二区三区| 韩国成人精品a∨在线观看| 久99久精品视频免费观看| 日韩精品91亚洲二区在线观看| 亚洲777理论| 亚洲国产精品一区二区久久| 亚洲免费av网站| 亚洲激情中文1区| 一区二区在线观看视频| 一区二区三区丝袜| 亚洲国产精品久久不卡毛片| 亚洲综合自拍偷拍| 亚洲综合在线观看视频| 亚洲国产精品久久一线不卡| 亚洲国产成人高清精品| 视频一区在线播放| 调教+趴+乳夹+国产+精品| 欧美aaa在线| 久久99国内精品| 国产乱妇无码大片在线观看| 国产电影精品久久禁18| 成人免费视频一区| 91蝌蚪porny| 在线观看成人小视频| 4438x成人网最大色成网站| 日韩欧美一卡二卡| 国产日产亚洲精品系列| 国产精品久久久久久久久图文区 | 91麻豆精品91久久久久同性| 日韩三级电影网址| 国产欧美日韩视频在线观看|