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

📄 fterrors.h

📁 一个Xpdf应用的例子
💻 H
📖 第 1 页 / 共 2 页
字号:
/***************************************************************************//*                                                                         *//*  fterrors.h                                                             *//*                                                                         *//*    FreeType error codes (specification).                                *//*                                                                         *//*  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.                                        *//*                                                                         *//***************************************************************************/  /*************************************************************************/  /*                                                                       */  /* This special header file is used to define the FT2 enumeration        */  /* constants.  It can also be used to generate error message strings     */  /* with a small macro trick explained below.                             */  /*                                                                       */  /* I - Error Formats                                                     */  /* -----------------                                                     */  /*                                                                       */  /*   Since release 2.1, the error constants have changed.  The lower     */  /*   byte of the error value gives the "generic" error code, while the   */  /*   higher byte indicates in which module the error occured.            */  /*                                                                       */  /*   You can use the macro FT_ERROR_BASE(x) macro to extract the generic */  /*   error code from an FT_Error value.                                  */  /*                                                                       */  /*   The configuration macro FT_CONFIG_OPTION_USE_MODULE_ERRORS can be   */  /*   undefined in ftoption.h in order to make the higher byte always     */  /*   zero, in case you need to be compatible with previous versions of   */  /*   FreeType 2.                                                         */  /*                                                                       */  /*                                                                       */  /* II - Error Message strings                                            */  /* --------------------------                                            */  /*                                                                       */  /*   The error definitions below are made through special macros that    */  /*   allow client applications to build a table of error message strings */  /*   if they need it.  The strings are not included in a normal build of */  /*   FreeType 2 to save space (most client applications do not use       */  /*   them).                                                              */  /*                                                                       */  /*   To do so, you have to define the following macros before including  */  /*   this file:                                                          */  /*                                                                       */  /*   FT_ERROR_START_LIST ::                                              */  /*     This macro is called before anything else to define the start of  */  /*     the error list.  It is followed by several FT_ERROR_DEF calls     */  /*     (see below).                                                      */  /*                                                                       */  /*   FT_ERROR_DEF( e, v, s ) ::                                          */  /*     This macro is called to define one single error.                  */  /*     `e' is the error code identifier (e.g. FT_Err_Invalid_Argument).  */  /*     `v' is the error numerical value.                                 */  /*     `s' is the corresponding error string.                            */  /*                                                                       */  /*   FT_ERROR_END_LIST ::                                                */  /*     This macro ends the list.                                         */  /*                                                                       */  /*   Additionally, you have to undefine __FTERRORS_H__ before #including */  /*   this file.                                                          */  /*                                                                       */  /*   Here is a simple example:                                           */  /*                                                                       */  /*     {                                                                 */  /*       #undef __FTERRORS_H__                                           */  /*       #define FT_ERRORDEF( e, v, s )   { e, s },                      */  /*       #define FT_ERROR_START_LIST      {                              */  /*       #define FT_ERROR_END_LIST        { 0, 0 } };                    */  /*                                                                       */  /*       const struct                                                    */  /*       {                                                               */  /*         int          err_code;                                        */  /*         const char*  err_msg                                          */  /*       } ft_errors[] =                                                 */  /*                                                                       */  /*       #include FT_ERRORS_H                                            */  /*     }                                                                 */  /*                                                                       */  /*************************************************************************/#ifndef __FTERRORS_H__#define __FTERRORS_H__  /* include module base error codes */#include FT_MODULE_ERRORS_H  /*******************************************************************/  /*******************************************************************/  /*****                                                         *****/  /*****                       SETUP MACROS                      *****/  /*****                                                         *****/  /*******************************************************************/  /*******************************************************************/#undef  FT_NEED_EXTERN_C#undef  FT_ERR_XCAT#define FT_ERR_XCAT( x, y )  x ## y#undef  FT_ERR_CAT#define FT_ERR_CAT( x, y )   FT_ERR_XCAT( x, y )  /* FT_ERR_PREFIX is used as a prefix for error identifiers. */  /* By default, we use `FT_Err_'.                            */  /*                                                          */#ifndef FT_ERR_PREFIX#define FT_ERR_PREFIX  FT_Err_#endif  /* FT_ERR_BASE is used as the base for module-specific errors. */  /*                                                             */#ifdef FT_CONFIG_OPTION_USE_MODULE_ERRORS#ifndef FT_ERR_BASE#define FT_ERR_BASE  FT_Mod_Err_Base#endif#else#undef FT_ERR_BASE#define FT_ERR_BASE  0#endif /* FT_CONFIG_OPTION_USE_MODULE_ERRORS */  /* If FT_ERRORDEF is not defined, we need to define a simple */  /* enumeration type.                                         */  /*                                                           */#ifndef FT_ERRORDEF#define FT_ERRORDEF( e, v, s )  e = v,#define FT_ERROR_START_LIST     enum {#define FT_ERROR_END_LIST       FT_ERR_CAT( FT_ERR_PREFIX, Max ) };#ifdef __cplusplus#define FT_NEED_EXTERN_C  extern "C" {#endif#endif /* !FT_ERRORDEF */  /* this macro is used to define an error */#define FT_ERRORDEF_( e, v, s )   \          FT_ERRORDEF( FT_ERR_CAT( FT_ERR_PREFIX, e ), v + FT_ERR_BASE, s )  /* this is only used for FT_Err_Ok, which must be 0! */#define FT_NOERRORDEF_( e, v, s ) \          FT_ERRORDEF( FT_ERR_CAT( FT_ERR_PREFIX, e ), v, s )  /*******************************************************************/  /*******************************************************************/  /*****                                                         *****/  /*****                LIST OF ERROR CODES/MESSAGES             *****/  /*****                                                         *****/  /*******************************************************************/  /*******************************************************************/#ifdef FT_ERROR_START_LIST  FT_ERROR_START_LIST#endif  /* generic errors */  FT_NOERRORDEF_( Ok,                                        0x00, \                  "no error" )  FT_ERRORDEF_( Cannot_Open_Resource,                        0x01, \               "cannot open resource" )  FT_ERRORDEF_( Unknown_File_Format,                         0x02, \               "unknown file format" )  FT_ERRORDEF_( Invalid_File_Format,                         0x03, \               "broken file" )  FT_ERRORDEF_( Invalid_Version,                             0x04, \               "invalid FreeType version" )  FT_ERRORDEF_( Lower_Module_Version,                        0x05, \               "module version is too low" )

⌨️ 快捷键说明

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