1 /**************************************************************************** 2 * 3 * psglue.h 4 * 5 * Adobe's code for shared stuff (specification only). 6 * 7 * Copyright 2007-2013 Adobe Systems Incorporated. 8 * 9 * This software, and all works of authorship, whether in source or 10 * object code form as indicated by the copyright notice(s) included 11 * herein (collectively, the "Work") is made available, and may only be 12 * used, modified, and distributed under the FreeType Project License, 13 * LICENSE.TXT. Additionally, subject to the terms and conditions of the 14 * FreeType Project License, each contributor to the Work hereby grants 15 * to any individual or legal entity exercising permissions granted by 16 * the FreeType Project License and this section (hereafter, "You" or 17 * "Your") a perpetual, worldwide, non-exclusive, no-charge, 18 * royalty-free, irrevocable (except as stated in this section) patent 19 * license to make, have made, use, offer to sell, sell, import, and 20 * otherwise transfer the Work, where such license applies only to those 21 * patent claims licensable by such contributor that are necessarily 22 * infringed by their contribution(s) alone or by combination of their 23 * contribution(s) with the Work to which such contribution(s) was 24 * submitted. If You institute patent litigation against any entity 25 * (including a cross-claim or counterclaim in a lawsuit) alleging that 26 * the Work or a contribution incorporated within the Work constitutes 27 * direct or contributory patent infringement, then any patent licenses 28 * granted to You under this License for that Work shall terminate as of 29 * the date such litigation is filed. 30 * 31 * By using, modifying, or distributing the Work you indicate that you 32 * have read and understood the terms and conditions of the 33 * FreeType Project License as well as those provided in this section, 34 * and you accept them fully. 35 * 36 */ 37 38 39 #ifndef PSGLUE_H_ 40 #define PSGLUE_H_ 41 42 43 /* common includes for other modules */ 44 #include "pserror.h" 45 #include "psfixed.h" 46 #include "psarrst.h" 47 #include "psread.h" 48 49 50 FT_BEGIN_HEADER 51 52 53 /* rendering parameters */ 54 55 /* apply hints to rendered glyphs */ 56 #define CF2_FlagsHinted 1 57 /* for testing */ 58 #define CF2_FlagsDarkened 2 59 60 /* type for holding the flags */ 61 typedef CF2_Int CF2_RenderingFlags; 62 63 64 /* elements of a glyph outline */ 65 typedef enum CF2_PathOp_ 66 { 67 CF2_PathOpMoveTo = 1, /* change the current point */ 68 CF2_PathOpLineTo = 2, /* line */ 69 CF2_PathOpQuadTo = 3, /* quadratic curve */ 70 CF2_PathOpCubeTo = 4 /* cubic curve */ 71 72 } CF2_PathOp; 73 74 75 /* a matrix of fixed point values */ 76 typedef struct CF2_Matrix_ 77 { 78 CF2_F16Dot16 a; 79 CF2_F16Dot16 b; 80 CF2_F16Dot16 c; 81 CF2_F16Dot16 d; 82 CF2_F16Dot16 tx; 83 CF2_F16Dot16 ty; 84 85 } CF2_Matrix; 86 87 88 /* these typedefs are needed by more than one header file */ 89 /* and gcc compiler doesn't allow redefinition */ 90 typedef struct CF2_FontRec_ CF2_FontRec, *CF2_Font; 91 typedef struct CF2_HintRec_ CF2_HintRec, *CF2_Hint; 92 93 94 /* A common structure for all callback parameters. */ 95 /* */ 96 /* Some members may be unused. For example, `pt0' is not used for */ 97 /* `moveTo' and `pt3' is not used for `quadTo'. The initial point `pt0' */ 98 /* is included for each path element for generality; curve conversions */ 99 /* need it. The `op' parameter allows one function to handle multiple */ 100 /* element types. */ 101 102 typedef struct CF2_CallbackParamsRec_ 103 { 104 FT_Vector pt0; 105 FT_Vector pt1; 106 FT_Vector pt2; 107 FT_Vector pt3; 108 109 CF2_Int op; 110 111 } CF2_CallbackParamsRec, *CF2_CallbackParams; 112 113 114 /* forward reference */ 115 typedef struct CF2_OutlineCallbacksRec_ CF2_OutlineCallbacksRec, 116 *CF2_OutlineCallbacks; 117 118 /* callback function pointers */ 119 typedef void 120 (*CF2_Callback_Type)( CF2_OutlineCallbacks callbacks, 121 const CF2_CallbackParams params ); 122 123 124 struct CF2_OutlineCallbacksRec_ 125 { 126 CF2_Callback_Type moveTo; 127 CF2_Callback_Type lineTo; 128 CF2_Callback_Type quadTo; 129 CF2_Callback_Type cubeTo; 130 131 CF2_Int windingMomentum; /* for winding order detection */ 132 133 FT_Memory memory; 134 FT_Error* error; 135 }; 136 137 138 FT_END_HEADER 139 140 141 #endif /* PSGLUE_H_ */ 142 143 144 /* END */ 145