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