blob: 903be027c0c17438375092514efbe993b765ee0e [file] [log] [blame]
/* ftglue.c: Glue code for compiling the OpenType code from
* FreeType 1 using only the public API of FreeType 2
*
* By David Turner, The FreeType Project (www.freetype.org)
*
* This code is explicitely put in the public domain
*
* ==========================================================================
*
* the OpenType parser codes was originally written as an extension to
* FreeType 1.x. As such, its source code was embedded within the library,
* and used many internal FreeType functions to deal with memory and
* stream i/o.
*
* When it was 'salvaged' for Pango and Qt, the code was "ported" to FreeType 2,
* which basically means that some macro tricks were performed in order to
* directly access FT2 _internal_ functions.
*
* these functions were never part of FT2 public API, and _did_ change between
* various releases. This created chaos for many users: when they upgraded the
* FreeType library on their system, they couldn't run Gnome anymore since
* Pango refused to link.
*
* Very fortunately, it's possible to completely avoid this problem because
* the FT_StreamRec and FT_MemoryRec structure types, which describe how
* memory and stream implementations interface with the rest of the font
* library, have always been part of the public API, and never changed.
*
* What we do thus is re-implement, within the OpenType parser, the few
* functions that depend on them. This only adds one or two kilobytes of
* code, and ensures that the parser can work with _any_ version
* of FreeType installed on your system. How sweet... !
*
* Note that we assume that Pango doesn't use any other internal functions
* from FreeType. It used to in old versions, but this should no longer
* be the case. (crossing my fingers).
*
* - David Turner
* - The FreeType Project (www.freetype.org)
*
* PS: This "glue" code is explicitely put in the public domain
*/
#ifndef __OPENTYPE_FTGLUE_H__
#define __OPENTYPE_FTGLUE_H__
#include "fcint.h"
#include <ft2build.h>
#include FT_FREETYPE_H
FT_BEGIN_HEADER
#define SET_ERR(c) ((error = (c)) != 0)
#ifndef FTGLUE_API
# define FTGLUE_API(x) extern FcPrivate x
#endif
#ifndef FTGLUE_APIDEF
# define FTGLUE_APIDEF(x) x
#endif
/* stream macros used by the OpenType parser */
#define FILE_Pos() ftglue_stream_pos (stream)
#define FILE_Seek(pos) SET_ERR (ftglue_stream_seek (stream, pos))
#define ACCESS_Frame(size) SET_ERR (ftglue_stream_frame_enter (stream, size))
#define FORGET_Frame() ftglue_stream_frame_exit (stream)
#define GET_Byte() (*stream->cursor++)
#define GET_Short() (stream->cursor += 2, (FT_Short)(((FT_ULong) * (((FT_Byte *)stream->cursor) - 2) << 8) | \
(FT_ULong) * (((FT_Byte *)stream->cursor) - 1)))
#define GET_Long() (stream->cursor += 4, (FT_Long)(((FT_ULong) * (((FT_Byte *)stream->cursor) - 4) << 24) | \
((FT_ULong) * (((FT_Byte *)stream->cursor) - 3) << 16) | \
((FT_ULong) * (((FT_Byte *)stream->cursor) - 2) << 8) | \
(FT_ULong) * (((FT_Byte *)stream->cursor) - 1)))
#define GET_Char() ((FT_Char)GET_Byte())
#define GET_UShort() ((FT_UShort)GET_Short())
#define GET_ULong() ((FT_ULong)GET_Long())
#define GET_Tag4() GET_ULong()
#define FT_SET_ERROR(expression) \
((error = (expression)) != 0)
FTGLUE_API (FT_Long)
ftglue_stream_pos (FT_Stream stream);
FTGLUE_API (FT_Error)
ftglue_stream_seek (FT_Stream stream,
FT_Long pos);
FTGLUE_API (FT_Error)
ftglue_stream_frame_enter (FT_Stream stream,
FT_ULong size);
FTGLUE_API (void)
ftglue_stream_frame_exit (FT_Stream stream);
FTGLUE_API (FT_Error)
ftglue_face_goto_table (FT_Face face,
FT_ULong tag,
FT_Stream stream,
FT_ULong *table_size);
FT_END_HEADER
#endif /* __OPENTYPE_FTGLUE_H__ */