1 /***************************************************************************/
2 /*                                                                         */
3 /*  ftmm.c                                                                 */
4 /*                                                                         */
5 /*    Multiple Master font support (body).                                 */
6 /*                                                                         */
7 /*  Copyright 1996-2001, 2003, 2004, 2009, 2013 by                         */
8 /*  David Turner, Robert Wilhelm, and Werner Lemberg.                      */
9 /*                                                                         */
10 /*  This file is part of the FreeType project, and may only be used,       */
11 /*  modified, and distributed under the terms of the FreeType project      */
12 /*  license, LICENSE.TXT.  By continuing to use, modify, or distribute     */
13 /*  this file you indicate that you have read the license and              */
14 /*  understand and accept it fully.                                        */
15 /*                                                                         */
16 /***************************************************************************/
17 
18 
19 #include <ft2build.h>
20 #include FT_INTERNAL_DEBUG_H
21 
22 #include FT_MULTIPLE_MASTERS_H
23 #include FT_INTERNAL_OBJECTS_H
24 #include FT_SERVICE_MULTIPLE_MASTERS_H
25 
26 
27   /*************************************************************************/
28   /*                                                                       */
29   /* The macro FT_COMPONENT is used in trace mode.  It is an implicit      */
30   /* parameter of the FT_TRACE() and FT_ERROR() macros, used to print/log  */
31   /* messages during execution.                                            */
32   /*                                                                       */
33 #undef  FT_COMPONENT
34 #define FT_COMPONENT  trace_mm
35 
36 
37   static FT_Error
ft_face_get_mm_service(FT_Face face,FT_Service_MultiMasters * aservice)38   ft_face_get_mm_service( FT_Face                   face,
39                           FT_Service_MultiMasters  *aservice )
40   {
41     FT_Error  error;
42 
43 
44     *aservice = NULL;
45 
46     if ( !face )
47       return FT_THROW( Invalid_Face_Handle );
48 
49     error = FT_ERR( Invalid_Argument );
50 
51     if ( FT_HAS_MULTIPLE_MASTERS( face ) )
52     {
53       FT_FACE_LOOKUP_SERVICE( face,
54                               *aservice,
55                               MULTI_MASTERS );
56 
57       if ( *aservice )
58         error = FT_Err_Ok;
59     }
60 
61     return error;
62   }
63 
64 
65   /* documentation is in ftmm.h */
66 
67   FT_EXPORT_DEF( FT_Error )
FT_Get_Multi_Master(FT_Face face,FT_Multi_Master * amaster)68   FT_Get_Multi_Master( FT_Face           face,
69                        FT_Multi_Master  *amaster )
70   {
71     FT_Error                 error;
72     FT_Service_MultiMasters  service;
73 
74 
75     error = ft_face_get_mm_service( face, &service );
76     if ( !error )
77     {
78       error = FT_ERR( Invalid_Argument );
79       if ( service->get_mm )
80         error = service->get_mm( face, amaster );
81     }
82 
83     return error;
84   }
85 
86 
87   /* documentation is in ftmm.h */
88 
89   FT_EXPORT_DEF( FT_Error )
FT_Get_MM_Var(FT_Face face,FT_MM_Var ** amaster)90   FT_Get_MM_Var( FT_Face      face,
91                  FT_MM_Var*  *amaster )
92   {
93     FT_Error                 error;
94     FT_Service_MultiMasters  service;
95 
96 
97     error = ft_face_get_mm_service( face, &service );
98     if ( !error )
99     {
100       error = FT_ERR( Invalid_Argument );
101       if ( service->get_mm_var )
102         error = service->get_mm_var( face, amaster );
103     }
104 
105     return error;
106   }
107 
108 
109   /* documentation is in ftmm.h */
110 
111   FT_EXPORT_DEF( FT_Error )
FT_Set_MM_Design_Coordinates(FT_Face face,FT_UInt num_coords,FT_Long * coords)112   FT_Set_MM_Design_Coordinates( FT_Face   face,
113                                 FT_UInt   num_coords,
114                                 FT_Long*  coords )
115   {
116     FT_Error                 error;
117     FT_Service_MultiMasters  service;
118 
119 
120     error = ft_face_get_mm_service( face, &service );
121     if ( !error )
122     {
123       error = FT_ERR( Invalid_Argument );
124       if ( service->set_mm_design )
125         error = service->set_mm_design( face, num_coords, coords );
126     }
127 
128     return error;
129   }
130 
131 
132   /* documentation is in ftmm.h */
133 
134   FT_EXPORT_DEF( FT_Error )
FT_Set_Var_Design_Coordinates(FT_Face face,FT_UInt num_coords,FT_Fixed * coords)135   FT_Set_Var_Design_Coordinates( FT_Face    face,
136                                  FT_UInt    num_coords,
137                                  FT_Fixed*  coords )
138   {
139     FT_Error                 error;
140     FT_Service_MultiMasters  service;
141 
142 
143     error = ft_face_get_mm_service( face, &service );
144     if ( !error )
145     {
146       error = FT_ERR( Invalid_Argument );
147       if ( service->set_var_design )
148         error = service->set_var_design( face, num_coords, coords );
149     }
150 
151     return error;
152   }
153 
154 
155   /* documentation is in ftmm.h */
156 
157   FT_EXPORT_DEF( FT_Error )
FT_Set_MM_Blend_Coordinates(FT_Face face,FT_UInt num_coords,FT_Fixed * coords)158   FT_Set_MM_Blend_Coordinates( FT_Face    face,
159                                FT_UInt    num_coords,
160                                FT_Fixed*  coords )
161   {
162     FT_Error                 error;
163     FT_Service_MultiMasters  service;
164 
165 
166     error = ft_face_get_mm_service( face, &service );
167     if ( !error )
168     {
169       error = FT_ERR( Invalid_Argument );
170       if ( service->set_mm_blend )
171          error = service->set_mm_blend( face, num_coords, coords );
172     }
173 
174     return error;
175   }
176 
177 
178   /* documentation is in ftmm.h */
179 
180   /* This is exactly the same as the previous function.  It exists for */
181   /* orthogonality.                                                    */
182 
183   FT_EXPORT_DEF( FT_Error )
FT_Set_Var_Blend_Coordinates(FT_Face face,FT_UInt num_coords,FT_Fixed * coords)184   FT_Set_Var_Blend_Coordinates( FT_Face    face,
185                                 FT_UInt    num_coords,
186                                 FT_Fixed*  coords )
187   {
188     FT_Error                 error;
189     FT_Service_MultiMasters  service;
190 
191 
192     error = ft_face_get_mm_service( face, &service );
193     if ( !error )
194     {
195       error = FT_ERR( Invalid_Argument );
196       if ( service->set_mm_blend )
197          error = service->set_mm_blend( face, num_coords, coords );
198     }
199 
200     return error;
201   }
202 
203 
204 /* END */
205