1999-12-17 00:11:37 +01:00
|
|
|
/***************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* ftinit.c */
|
|
|
|
/* */
|
|
|
|
/* FreeType initialisation layer (body). */
|
|
|
|
/* */
|
|
|
|
/* Copyright 1996-1999 by */
|
|
|
|
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
|
|
|
/* */
|
|
|
|
/* This file is part of the FreeType project, and may only be used */
|
|
|
|
/* modified and distributed under the terms of the FreeType project */
|
|
|
|
/* license, LICENSE.TXT. By continuing to use, modify, or distribute */
|
|
|
|
/* this file you indicate that you have read the license and */
|
|
|
|
/* understand and accept it fully. */
|
|
|
|
/* */
|
|
|
|
/***************************************************************************/
|
|
|
|
|
|
|
|
/**************************************************************************
|
|
|
|
*
|
|
|
|
* The purpose of this file is to implement the three following
|
|
|
|
* functions:
|
|
|
|
*
|
|
|
|
* FT_Default_Drivers:
|
|
|
|
* This function is used to add the set of default drivers
|
|
|
|
* to a fresh new library object. The set is computed at compile
|
|
|
|
* time from the Makefiles inclusions in Makefile.lib. See the
|
|
|
|
* document "FreeType Internals" for more info.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* FT_Init_FreeType:
|
|
|
|
* This function creates a system object for the current platform,
|
|
|
|
* builds a library out of it, then calls FT_Default_Drivers
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* FT_Done_FreeType:
|
|
|
|
* This function simply finalise the library and the corresponding
|
|
|
|
* system object.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* Note that even if FT_Init_FreeType uses the implementation of the
|
|
|
|
* system object defined at build time, client applications are still
|
|
|
|
* able to provide their own "ftsystem.c"
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#include <ftobjs.h>
|
|
|
|
#include <ftconfig.h>
|
|
|
|
#include <ftdebug.h>
|
1999-12-29 01:22:24 +01:00
|
|
|
#include <ftdriver.h>
|
1999-12-17 00:11:37 +01:00
|
|
|
|
|
|
|
#undef FT_COMPONENT
|
|
|
|
#define FT_COMPONENT trace_init
|
|
|
|
|
1999-12-29 01:22:24 +01:00
|
|
|
#undef FT_DRIVER
|
|
|
|
#define FT_DRIVER(x) extern FT_DriverInterface x;
|
|
|
|
#include <ftmodule.h>
|
1999-12-17 00:11:37 +01:00
|
|
|
|
1999-12-29 01:22:24 +01:00
|
|
|
#undef FT_DRIVER
|
|
|
|
#define FT_DRIVER(x) &x,
|
1999-12-17 00:11:37 +01:00
|
|
|
|
1999-12-29 01:22:24 +01:00
|
|
|
static
|
|
|
|
const FT_DriverInterface* ft_default_drivers[] = {
|
|
|
|
#include <ftmodule.h>
|
|
|
|
0
|
|
|
|
};
|
1999-12-17 00:11:37 +01:00
|
|
|
|
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* <Function> */
|
|
|
|
/* FT_Default_Drivers */
|
|
|
|
/* */
|
|
|
|
/* <Description> */
|
|
|
|
/* Adds the set of default drivers to a given library object. */
|
|
|
|
/* */
|
|
|
|
/* <Input> */
|
|
|
|
/* library :: A handle to a new library object. */
|
|
|
|
/* */
|
|
|
|
EXPORT_FUNC
|
|
|
|
void FT_Default_Drivers( FT_Library library )
|
|
|
|
{
|
1999-12-29 01:22:24 +01:00
|
|
|
FT_Error error;
|
|
|
|
const FT_DriverInterface* *cur;
|
1999-12-17 00:11:37 +01:00
|
|
|
|
1999-12-29 01:22:24 +01:00
|
|
|
cur = ft_default_drivers;
|
|
|
|
while (*cur)
|
1999-12-17 00:11:37 +01:00
|
|
|
{
|
1999-12-29 01:22:24 +01:00
|
|
|
error = FT_Add_Driver( library, *cur );
|
1999-12-17 00:11:37 +01:00
|
|
|
/* notify errors, but don't stop */
|
|
|
|
if (error)
|
|
|
|
{
|
|
|
|
FT_ERROR(( "FT.Default_Drivers: cannot install `%s', error = %x\n",
|
1999-12-29 01:22:24 +01:00
|
|
|
(*cur)->driver_name, error ));
|
1999-12-17 00:11:37 +01:00
|
|
|
}
|
1999-12-29 01:22:24 +01:00
|
|
|
cur++;
|
1999-12-17 00:11:37 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* <Function> */
|
|
|
|
/* FT_Init_FreeType */
|
|
|
|
/* */
|
|
|
|
/* <Description> */
|
|
|
|
/* Initializes a new FreeType library object. The set of drivers */
|
|
|
|
/* that are registered by this function is determined at build time. */
|
|
|
|
/* */
|
|
|
|
/* <Output> */
|
|
|
|
/* library :: A handle to a new library object. */
|
|
|
|
/* */
|
|
|
|
/* <Return> */
|
|
|
|
/* Error code. 0 means success. */
|
|
|
|
/* */
|
|
|
|
EXPORT_FUNC
|
|
|
|
FT_Error FT_Init_FreeType( FT_Library* library )
|
|
|
|
{
|
|
|
|
FT_Error error;
|
|
|
|
FT_Memory memory;
|
|
|
|
|
|
|
|
/* First of all, allocate a new system object -this function is part */
|
|
|
|
/* of the system-specific component, i.e. ftsystem.c */
|
|
|
|
memory = FT_New_Memory();
|
|
|
|
if (!memory)
|
|
|
|
{
|
|
|
|
FT_ERROR(( "FT_Init_FreeType:" ));
|
|
|
|
FT_ERROR(( " cannot find memory manager" ));
|
|
|
|
return FT_Err_Unimplemented_Feature;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* builds a library out of it, then fill it with the set of */
|
|
|
|
/* default drivers.. */
|
|
|
|
error = FT_New_Library( memory, library );
|
|
|
|
if ( !error )
|
|
|
|
FT_Default_Drivers(*library);
|
|
|
|
|
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* END */
|