forked from minhngoc25a/freetype2
Use `FT_Property_Set' to set the hooks. One less API function.
This commit is contained in:
parent
b6f2303338
commit
1541091e76
|
@ -121,78 +121,6 @@ FT_BEGIN_HEADER
|
||||||
(*SVG_Lib_Get_Buffer_Size_Func)( FT_GlyphSlot slot,
|
(*SVG_Lib_Get_Buffer_Size_Func)( FT_GlyphSlot slot,
|
||||||
FT_BBox bbox );
|
FT_BBox bbox );
|
||||||
|
|
||||||
|
|
||||||
/**************************************************************************
|
|
||||||
*
|
|
||||||
* @functype:
|
|
||||||
* SVG_Set_Hooks_Func
|
|
||||||
*
|
|
||||||
* @description:
|
|
||||||
* A function that is used set SVG Hooks. Part of the SVG Renderer
|
|
||||||
* Interface.
|
|
||||||
*
|
|
||||||
* @input:
|
|
||||||
* module ::
|
|
||||||
* `FT_Module` instance.
|
|
||||||
*
|
|
||||||
* init_svg ::
|
|
||||||
* A function pointer of the type `SVG_Lib_Init_Func`. Read the
|
|
||||||
* documentation of `SVG_Lib_Init_Func`.
|
|
||||||
*
|
|
||||||
* free_svg ::
|
|
||||||
* A function pointer of the type `SVG_Lib_Free_Func`. Read the
|
|
||||||
* documentation of `SVG_Lib_Free_Func`.
|
|
||||||
*
|
|
||||||
* render_svg ::
|
|
||||||
* A function pointer of the type `SVG_Lib_Render_Func`. Read the
|
|
||||||
* documentation of `SVG_Lib_Render_Func`.
|
|
||||||
*
|
|
||||||
* get_buffer_size ::
|
|
||||||
* A function pointer of the type `SVG_Lib_Get_Buffer_Size_Func`.
|
|
||||||
* Read the documentation of `SVG_Lib_Get_Buffer_Size_Func`.
|
|
||||||
*
|
|
||||||
* @return:
|
|
||||||
* FreeType error code. 0 means success.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef FT_Error
|
|
||||||
(*SVG_Set_Hooks_Func)( FT_Module module,
|
|
||||||
SVG_Lib_Init_Func init_svg,
|
|
||||||
SVG_Lib_Free_Func free_svg,
|
|
||||||
SVG_Lib_Render_Func render_svg,
|
|
||||||
SVG_Lib_Get_Buffer_Size_Func get_buffer_size );
|
|
||||||
|
|
||||||
/**************************************************************************
|
|
||||||
*
|
|
||||||
* @struct:
|
|
||||||
* SVG_Renderer_Interface
|
|
||||||
*
|
|
||||||
* @description:
|
|
||||||
* An interface structure that function needed to inject external SVG
|
|
||||||
* rendering library hooks.
|
|
||||||
*
|
|
||||||
* @fields:
|
|
||||||
* set_hooks ::
|
|
||||||
* A function that can be called to set the hooks.
|
|
||||||
*
|
|
||||||
* @return:
|
|
||||||
* FreeType error code. 0 means success.
|
|
||||||
*/
|
|
||||||
|
|
||||||
typedef struct SVG_Renderer_Interface_
|
|
||||||
{
|
|
||||||
SVG_Set_Hooks_Func set_hooks;
|
|
||||||
} SVG_Renderer_Interface;
|
|
||||||
|
|
||||||
|
|
||||||
/* TODO: to document */
|
|
||||||
FT_EXPORT( FT_Error )
|
|
||||||
FT_Set_Svg_Hooks( FT_Library library,
|
|
||||||
SVG_Lib_Init_Func init_svg,
|
|
||||||
SVG_Lib_Free_Func free_svg,
|
|
||||||
SVG_Lib_Render_Func render_svg,
|
|
||||||
SVG_Lib_Get_Buffer_Size_Func get_buffer_size );
|
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
*
|
*
|
||||||
* @struct:
|
* @struct:
|
||||||
|
|
|
@ -5603,47 +5603,4 @@
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef FT_CONFIG_OPTION_SVG
|
|
||||||
FT_EXPORT_DEF( FT_Error )
|
|
||||||
FT_Set_Svg_Hooks( FT_Library library,
|
|
||||||
SVG_Lib_Init_Func init_svg,
|
|
||||||
SVG_Lib_Free_Func free_svg,
|
|
||||||
SVG_Lib_Render_Func render_svg,
|
|
||||||
SVG_Lib_Get_Buffer_Size_Func get_buffer_size )
|
|
||||||
{
|
|
||||||
FT_Module renderer;
|
|
||||||
SVG_Renderer_Interface *svg;
|
|
||||||
|
|
||||||
/* TODO: (OT-SVG) Handle the case if the module is not found */
|
|
||||||
renderer = FT_Get_Module( library, "ot-svg" );
|
|
||||||
|
|
||||||
/* If ot-svg module is not available return with error */
|
|
||||||
if ( renderer == 0 )
|
|
||||||
return FT_THROW( Missing_Module );
|
|
||||||
|
|
||||||
svg = (SVG_Renderer_Interface*)renderer->clazz->module_interface;
|
|
||||||
svg->set_hooks(renderer,
|
|
||||||
init_svg,
|
|
||||||
free_svg,
|
|
||||||
render_svg,
|
|
||||||
get_buffer_size );
|
|
||||||
return FT_Err_Ok;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
FT_EXPORT_DEF( FT_Error )
|
|
||||||
FT_Set_Svg_Hooks( FT_Library library,
|
|
||||||
SVG_Lib_Init_Func init_svg,
|
|
||||||
SVG_Lib_Free_Func free_svg,
|
|
||||||
SVG_Lib_Render_Func render_svg,
|
|
||||||
SVG_Lib_Get_Buffer_Size_Func get_buffer_size )
|
|
||||||
{
|
|
||||||
FT_UNUSED( library );
|
|
||||||
FT_UNUSED( init_svg );
|
|
||||||
FT_UNUSED( free_svg );
|
|
||||||
FT_UNUSED( render_svg );
|
|
||||||
FT_UNUSED( get_buffer_size );
|
|
||||||
return FT_THROW( Unimplemented_Feature );
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* END */
|
/* END */
|
||||||
|
|
105
src/svg/ftsvg.c
105
src/svg/ftsvg.c
|
@ -16,6 +16,8 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <ft2build.h>
|
#include <ft2build.h>
|
||||||
|
#include FT_INTERNAL_DEBUG_H
|
||||||
|
#include FT_SERVICE_PROPERTIES_H
|
||||||
#include FT_SVG_RENDER_H
|
#include FT_SVG_RENDER_H
|
||||||
#include FT_BBOX_H
|
#include FT_BBOX_H
|
||||||
|
|
||||||
|
@ -78,30 +80,89 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
static FT_Error
|
static FT_Error
|
||||||
ft_svg_set_hooks( FT_Module module,
|
ft_svg_property_set( FT_Module module,
|
||||||
SVG_Lib_Init_Func init_svg,
|
const char* property_name,
|
||||||
SVG_Lib_Free_Func free_svg,
|
const void* value,
|
||||||
SVG_Lib_Render_Func render_svg,
|
FT_Bool value_is_string )
|
||||||
SVG_Lib_Get_Buffer_Size_Func get_buffer_size )
|
|
||||||
{
|
{
|
||||||
SVG_Renderer renderer;
|
FT_Error error = FT_Err_Ok;
|
||||||
|
SVG_Renderer renderer = (SVG_Renderer)module;
|
||||||
|
|
||||||
renderer = (SVG_Renderer)module;
|
if ( !ft_strcmp( property_name, "init_svg_hook" ) )
|
||||||
renderer->hooks.init_svg = init_svg;
|
renderer->hooks.init_svg = (SVG_Lib_Init_Func)value;
|
||||||
renderer->hooks.free_svg = free_svg;
|
else if ( !ft_strcmp( property_name, "free_svg_hook" ) )
|
||||||
renderer->hooks.render_svg = render_svg;
|
renderer->hooks.free_svg = (SVG_Lib_Free_Func)value;
|
||||||
|
else if ( !ft_strcmp( property_name, "render_svg_hook" ) )
|
||||||
renderer->hooks.get_buffer_size = get_buffer_size;
|
renderer->hooks.render_svg = (SVG_Lib_Render_Func)value;
|
||||||
|
else if ( !ft_strcmp( property_name, "get_buffer_size_hook" ) )
|
||||||
return FT_Err_Ok;
|
renderer->hooks.get_buffer_size = (SVG_Lib_Get_Buffer_Size_Func)value;
|
||||||
|
else
|
||||||
|
{
|
||||||
|
error = FT_THROW( Missing_Property );
|
||||||
|
}
|
||||||
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static FT_Error
|
||||||
static const SVG_Renderer_Interface svg_renderer_interface =
|
ft_svg_property_get( FT_Module module,
|
||||||
|
const char* property_name,
|
||||||
|
const void* value )
|
||||||
{
|
{
|
||||||
(SVG_Set_Hooks_Func)ft_svg_set_hooks
|
FT_Error error = FT_Err_Ok;
|
||||||
};
|
SVG_Renderer renderer = (SVG_Renderer)module;
|
||||||
|
|
||||||
|
if ( !ft_strcmp( property_name, "init_svg_hook" ) )
|
||||||
|
{
|
||||||
|
SVG_Lib_Init_Func* val = (SVG_Lib_Init_Func*)value;
|
||||||
|
*val = (SVG_Lib_Init_Func)renderer->hooks.init_svg;
|
||||||
|
}
|
||||||
|
else if ( !ft_strcmp( property_name, "free_svg_hook" ) )
|
||||||
|
{
|
||||||
|
SVG_Lib_Free_Func* val = (SVG_Lib_Free_Func*)value;
|
||||||
|
*val = (SVG_Lib_Free_Func)renderer->hooks.free_svg;
|
||||||
|
}
|
||||||
|
else if ( !ft_strcmp( property_name, "render_svg_hook" ) )
|
||||||
|
{
|
||||||
|
SVG_Lib_Render_Func* val = (SVG_Lib_Render_Func*)value;
|
||||||
|
*val = (SVG_Lib_Render_Func)renderer->hooks.render_svg;
|
||||||
|
}
|
||||||
|
else if ( !ft_strcmp( property_name, "get_buffer_size_hook" ) )
|
||||||
|
{
|
||||||
|
SVG_Lib_Get_Buffer_Size_Func* val;
|
||||||
|
val = (SVG_Lib_Get_Buffer_Size_Func*)value;
|
||||||
|
*val = (SVG_Lib_Get_Buffer_Size_Func)renderer->hooks.render_svg;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
error = FT_THROW( Missing_Property );
|
||||||
|
}
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
FT_DEFINE_SERVICE_PROPERTIESREC(
|
||||||
|
ft_svg_service_properties,
|
||||||
|
|
||||||
|
(FT_Properties_SetFunc)ft_svg_property_set, /* set_property */
|
||||||
|
(FT_Properties_GetFunc)ft_svg_property_get /* get_property */
|
||||||
|
)
|
||||||
|
|
||||||
|
FT_DEFINE_SERVICEDESCREC1(
|
||||||
|
ft_svg_services,
|
||||||
|
FT_SERVICE_ID_PROPERTIES, &ft_svg_service_properties )
|
||||||
|
|
||||||
|
|
||||||
|
FT_CALLBACK_DEF( FT_Module_Interface )
|
||||||
|
ft_svg_get_interface( FT_Module module,
|
||||||
|
const char* ft_svg_interface )
|
||||||
|
{
|
||||||
|
FT_Module_Interface result;
|
||||||
|
|
||||||
|
|
||||||
|
result = ft_service_list_lookup( ft_svg_services, ft_svg_interface );
|
||||||
|
if ( result )
|
||||||
|
return result;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
FT_DEFINE_RENDERER(
|
FT_DEFINE_RENDERER(
|
||||||
ft_svg_renderer_class,
|
ft_svg_renderer_class,
|
||||||
|
@ -112,10 +173,10 @@
|
||||||
"ot-svg",
|
"ot-svg",
|
||||||
0x10000L,
|
0x10000L,
|
||||||
0x20000L,
|
0x20000L,
|
||||||
(const void*)&svg_renderer_interface, /* module specific interface */
|
NULL, /* module specific interface */
|
||||||
(FT_Module_Constructor)ft_svg_init, /* module_init */
|
(FT_Module_Constructor)ft_svg_init, /* module_init */
|
||||||
(FT_Module_Destructor)ft_svg_done, /* module_done */
|
(FT_Module_Destructor)ft_svg_done, /* module_done */
|
||||||
NULL,
|
ft_svg_get_interface, /* get_interface */
|
||||||
FT_GLYPH_FORMAT_SVG,
|
FT_GLYPH_FORMAT_SVG,
|
||||||
(FT_Renderer_RenderFunc)ft_svg_render,
|
(FT_Renderer_RenderFunc)ft_svg_render,
|
||||||
NULL,
|
NULL,
|
||||||
|
|
Loading…
Reference in New Issue