| Index: src/sfnt/sfntpic.c
|
| diff --git a/src/sfnt/sfntpic.c b/src/sfnt/sfntpic.c
|
| index 53aca17b519121e2adc2ead03dd23eb488c92797..1372376db2cfcdc078e99b72f3a180b4c463af79 100644
|
| --- a/src/sfnt/sfntpic.c
|
| +++ b/src/sfnt/sfntpic.c
|
| @@ -20,36 +20,73 @@
|
| #include FT_FREETYPE_H
|
| #include FT_INTERNAL_OBJECTS_H
|
| #include "sfntpic.h"
|
| +#include "sferrors.h"
|
|
|
| #ifdef FT_CONFIG_OPTION_PIC
|
|
|
| /* forward declaration of PIC init functions from sfdriver.c */
|
| - FT_Error FT_Create_Class_sfnt_services( FT_Library, FT_ServiceDescRec**);
|
| - void FT_Destroy_Class_sfnt_services( FT_Library, FT_ServiceDescRec*);
|
| - void FT_Init_Class_sfnt_service_bdf( FT_Service_BDFRec*);
|
| - void FT_Init_Class_sfnt_interface( FT_Library, SFNT_Interface*);
|
| - void FT_Init_Class_sfnt_service_glyph_dict( FT_Library, FT_Service_GlyphDictRec*);
|
| - void FT_Init_Class_sfnt_service_ps_name( FT_Library, FT_Service_PsFontNameRec*);
|
| - void FT_Init_Class_tt_service_get_cmap_info( FT_Library, FT_Service_TTCMapsRec*);
|
| - void FT_Init_Class_sfnt_service_sfnt_table( FT_Service_SFNT_TableRec*);
|
| + FT_Error
|
| + FT_Create_Class_sfnt_services( FT_Library library,
|
| + FT_ServiceDescRec** ouput_class );
|
| +
|
| + void
|
| + FT_Destroy_Class_sfnt_services( FT_Library library,
|
| + FT_ServiceDescRec* clazz );
|
| +
|
| + void
|
| + FT_Init_Class_sfnt_service_bdf( FT_Service_BDFRec* clazz );
|
| +
|
| + void
|
| + FT_Init_Class_sfnt_interface( FT_Library library,
|
| + SFNT_Interface* clazz );
|
| +
|
| + void
|
| + FT_Init_Class_sfnt_service_glyph_dict(
|
| + FT_Library library,
|
| + FT_Service_GlyphDictRec* clazz );
|
| +
|
| + void
|
| + FT_Init_Class_sfnt_service_ps_name(
|
| + FT_Library library,
|
| + FT_Service_PsFontNameRec* clazz );
|
| +
|
| + void
|
| + FT_Init_Class_tt_service_get_cmap_info(
|
| + FT_Library library,
|
| + FT_Service_TTCMapsRec* clazz );
|
| +
|
| + void
|
| + FT_Init_Class_sfnt_service_sfnt_table(
|
| + FT_Service_SFNT_TableRec* clazz );
|
|
|
| /* forward declaration of PIC init functions from ttcmap.c */
|
| - FT_Error FT_Create_Class_tt_cmap_classes( FT_Library, TT_CMap_Class**);
|
| - void FT_Destroy_Class_tt_cmap_classes( FT_Library, TT_CMap_Class*);
|
| + FT_Error
|
| + FT_Create_Class_tt_cmap_classes( FT_Library library,
|
| + TT_CMap_Class** output_class );
|
| +
|
| + void
|
| + FT_Destroy_Class_tt_cmap_classes( FT_Library library,
|
| + TT_CMap_Class* clazz );
|
|
|
| void
|
| - sfnt_module_class_pic_free( FT_Library library )
|
| + sfnt_module_class_pic_free( FT_Library library )
|
| {
|
| - FT_PIC_Container* pic_container = &library->pic_container;
|
| - FT_Memory memory = library->memory;
|
| + FT_PIC_Container* pic_container = &library->pic_container;
|
| + FT_Memory memory = library->memory;
|
| +
|
| +
|
| if ( pic_container->sfnt )
|
| {
|
| - sfntModulePIC* container = (sfntModulePIC*)pic_container->sfnt;
|
| - if(container->sfnt_services)
|
| - FT_Destroy_Class_sfnt_services(library, container->sfnt_services);
|
| + sfntModulePIC* container = (sfntModulePIC*)pic_container->sfnt;
|
| +
|
| +
|
| + if ( container->sfnt_services )
|
| + FT_Destroy_Class_sfnt_services( library,
|
| + container->sfnt_services );
|
| container->sfnt_services = NULL;
|
| - if(container->tt_cmap_classes)
|
| - FT_Destroy_Class_tt_cmap_classes(library, container->tt_cmap_classes);
|
| + if ( container->tt_cmap_classes )
|
| + FT_Destroy_Class_tt_cmap_classes( library,
|
| + container->tt_cmap_classes );
|
| container->tt_cmap_classes = NULL;
|
| FT_FREE( container );
|
| pic_container->sfnt = NULL;
|
| @@ -73,24 +110,31 @@
|
| pic_container->sfnt = container;
|
|
|
| /* initialize pointer table - this is how the module usually expects this data */
|
| - error = FT_Create_Class_sfnt_services(library, &container->sfnt_services);
|
| - if(error)
|
| + error = FT_Create_Class_sfnt_services( library,
|
| + &container->sfnt_services );
|
| + if ( error )
|
| goto Exit;
|
| - error = FT_Create_Class_tt_cmap_classes(library, &container->tt_cmap_classes);
|
| - if(error)
|
| + error = FT_Create_Class_tt_cmap_classes( library,
|
| + &container->tt_cmap_classes );
|
| + if ( error )
|
| goto Exit;
|
| - FT_Init_Class_sfnt_service_glyph_dict(library, &container->sfnt_service_glyph_dict);
|
| - FT_Init_Class_sfnt_service_ps_name(library, &container->sfnt_service_ps_name);
|
| - FT_Init_Class_tt_service_get_cmap_info(library, &container->tt_service_get_cmap_info);
|
| - FT_Init_Class_sfnt_service_sfnt_table(&container->sfnt_service_sfnt_table);
|
| +
|
| + FT_Init_Class_sfnt_service_glyph_dict(
|
| + library, &container->sfnt_service_glyph_dict );
|
| + FT_Init_Class_sfnt_service_ps_name(
|
| + library, &container->sfnt_service_ps_name );
|
| + FT_Init_Class_tt_service_get_cmap_info(
|
| + library, &container->tt_service_get_cmap_info );
|
| + FT_Init_Class_sfnt_service_sfnt_table(
|
| + &container->sfnt_service_sfnt_table );
|
| #ifdef TT_CONFIG_OPTION_BDF
|
| - FT_Init_Class_sfnt_service_bdf(&container->sfnt_service_bdf);
|
| + FT_Init_Class_sfnt_service_bdf( &container->sfnt_service_bdf );
|
| #endif
|
| - FT_Init_Class_sfnt_interface(library, &container->sfnt_interface);
|
| + FT_Init_Class_sfnt_interface( library, &container->sfnt_interface );
|
|
|
| Exit:
|
| - if(error)
|
| - sfnt_module_class_pic_free(library);
|
| + if ( error )
|
| + sfnt_module_class_pic_free( library );
|
| return error;
|
| }
|
|
|
|
|