2002-04-18 00:54:02 +02:00
|
|
|
#ifndef __FT_SYSTEM_IO_H__
|
|
|
|
#define __FT_SYSTEM_IO_H__
|
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
/********************************************************************
|
|
|
|
*
|
|
|
|
* designing custom streams is a bit different now
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2002-04-18 00:54:02 +02:00
|
|
|
#include <ft2build.h>
|
|
|
|
#include FT_INTERNAL_OBJECT_H
|
|
|
|
|
|
|
|
FT_BEGIN_HEADER
|
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
/********************************************************************
|
|
|
|
*
|
|
|
|
* @type: FT_Stream
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* handle to an input stream object. These are also @FT_Object handles
|
|
|
|
*/
|
2002-04-18 00:54:02 +02:00
|
|
|
typedef struct FT_StreamRec_* FT_Stream;
|
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
*
|
|
|
|
* @type: FT_Stream_Class
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* opaque handle to a @FT_Stream_ClassRec class structure describing
|
|
|
|
* the methods of input streams
|
|
|
|
*/
|
2002-04-18 00:54:02 +02:00
|
|
|
typedef const struct FT_Stream_ClassRec_* FT_Stream_Class;
|
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
*
|
|
|
|
* @functype: FT_Stream_ReadFunc
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* a method used to read bytes from an input stream into memory
|
|
|
|
*
|
|
|
|
* @input:
|
|
|
|
* stream :: target stream handle
|
|
|
|
* buffer :: target buffer address
|
|
|
|
* size :: number of bytes to read
|
|
|
|
*
|
|
|
|
* @return:
|
|
|
|
* number of bytes effectively read. Must be <= 'size'.
|
|
|
|
*/
|
2002-04-18 00:54:02 +02:00
|
|
|
typedef FT_ULong (*FT_Stream_ReadFunc)( FT_Stream stream,
|
|
|
|
FT_Byte* buffer,
|
|
|
|
FT_ULong size );
|
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
*
|
|
|
|
* @functype: FT_Stream_SeekFunc
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* a method used to seek to a new position within a stream
|
|
|
|
*
|
|
|
|
* @input:
|
|
|
|
* stream :: target stream handle
|
|
|
|
* pos :: new read position, from start of stream
|
|
|
|
*
|
|
|
|
* @return:
|
|
|
|
* error code. 0 means success
|
|
|
|
*/
|
2002-04-18 00:54:02 +02:00
|
|
|
typedef FT_Error (*FT_Stream_SeekFunc)( FT_Stream stream,
|
|
|
|
FT_ULong pos );
|
|
|
|
|
* massive re-formatting changes to many, many source files. I don't
want to list them all here. The operations performed were all logical
transformations of the sources:
- trying to convert all enums and constants to CAPITALIZED_STYLE, with
#define definitions like
#define my_old_constants MY_NEW_CONSTANT
- big, big update of the documentation comments
* include/freetype/freetype.h, src/base/ftobjs.c, src/smooth/ftsmooth.c,
include/freetype/ftimage.h: adding support for LCD-optimized rendering
though the new constants/enums:
FT_RENDER_MODE_LCD, FT_RENDER_MODE_LCD_V
FT_PIXEL_MODE_LCD, FT_PIXEL_MODE_LCD_V
this is still work in progress, don't expect everything to work correctly
though most of the features have been implemented.
* adding new FT_LOAD_XXX flags, used to specify both hinting and rendering
targets:
FT_LOAD_TARGET_NORMAL :: anti-aliased hinting & rendering
FT_LOAD_TARGET_MONO :: monochrome bitmaps
FT_LOAD_TARGET_LCD :: horizontal RGB/BGR decimated hinting & rendering
FT_LOAD_TARGET_LCD_V :: vertical RGB/BGR decimated hinting & rendering
note that FT_LOAD_TARGET_NORMAL is 0, which means that the default
behaviour of the font engine is _unchanged_.
2002-08-27 22:20:29 +02:00
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
/********************************************************************
|
|
|
|
*
|
|
|
|
* @struct: FT_Stream_ClassRec
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* a structure used to describe an input stream class
|
|
|
|
*
|
|
|
|
* @input:
|
|
|
|
* clazz :: root @FT_ClassRec fields
|
|
|
|
* stream_read :: stream byte read method
|
|
|
|
* stream_seek :: stream seek method
|
|
|
|
*/
|
2002-04-18 00:54:02 +02:00
|
|
|
typedef struct FT_Stream_ClassRec_
|
|
|
|
{
|
|
|
|
FT_ClassRec clazz;
|
|
|
|
FT_Stream_ReadFunc stream_read;
|
|
|
|
FT_Stream_SeekFunc stream_seek;
|
2002-05-01 10:46:56 +02:00
|
|
|
|
2002-04-18 00:54:02 +02:00
|
|
|
} FT_Stream_ClassRec;
|
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
/* */
|
2002-04-18 00:54:02 +02:00
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
#define FT_STREAM_CLASS(x) ((FT_Stream_Class)(x))
|
2002-04-18 00:54:02 +02:00
|
|
|
#define FT_STREAM_CLASS__READ(x) FT_STREAM_CLASS(x)->stream_read
|
|
|
|
#define FT_STREAM_CLASS__SEEK(x) FT_STREAM_CLASS(x)->stream_seek;
|
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
/********************************************************************
|
|
|
|
*
|
|
|
|
* @struct: FT_StreamRec
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* the input stream object structure. See @FT_Stream_ClassRec for
|
|
|
|
* its class descriptor
|
|
|
|
*
|
|
|
|
* @fields:
|
|
|
|
* object :: root @FT_ObjectRec fields
|
|
|
|
* size :: size of stream in bytes (0 if unknown)
|
|
|
|
* pos :: current position within stream
|
|
|
|
* base :: for memory-based streams, the address of the stream's
|
|
|
|
* first data byte in memory. NULL otherwise
|
|
|
|
*
|
|
|
|
* cursor :: the current cursor position within an input stream
|
|
|
|
* frame. Only valid within a FT_FRAME_ENTER .. FT_FRAME_EXIT
|
|
|
|
* block; NULL otherwise
|
|
|
|
*
|
|
|
|
* limit :: the current frame limit within a FT_FRAME_ENTER ..
|
|
|
|
* FT_FRAME_EXIT block. NULL otherwise
|
|
|
|
*/
|
2002-04-18 00:54:02 +02:00
|
|
|
typedef struct FT_StreamRec_
|
|
|
|
{
|
|
|
|
FT_ObjectRec object;
|
|
|
|
FT_ULong size;
|
|
|
|
FT_ULong pos;
|
|
|
|
const FT_Byte* base;
|
|
|
|
const FT_Byte* cursor;
|
|
|
|
const FT_Byte* limit;
|
|
|
|
|
|
|
|
} FT_StreamRec;
|
|
|
|
|
|
|
|
/* some useful macros */
|
|
|
|
#define FT_STREAM(x) ((FT_Stream)(x))
|
|
|
|
#define FT_STREAM_P(x) ((FT_Stream*)(x))
|
|
|
|
|
|
|
|
#define FT_STREAM__READ(x) FT_STREAM_CLASS__READ(FT_OBJECT__CLASS(x))
|
|
|
|
#define FT_STREAM__SEEK(x) FT_STREAM_CLASS__SEEK(FT_OBJECT__CLASS(x))
|
|
|
|
|
|
|
|
#define FT_STREAM_IS_BASED(x) ( FT_STREAM(x)->base != NULL )
|
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
/* */
|
2002-04-18 00:54:02 +02:00
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
/* create new memory-based stream */
|
|
|
|
FT_BASE( FT_Error ) ft_stream_new_memory( const FT_Byte* stream_base,
|
|
|
|
FT_ULong stream_size,
|
|
|
|
FT_Memory memory,
|
|
|
|
FT_Stream *astream );
|
2002-04-18 00:54:02 +02:00
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
FT_BASE( FT_Error ) ft_stream_new_iso( const char* pathanme,
|
|
|
|
FT_Memory memory,
|
|
|
|
FT_Stream *astream );
|
2002-04-18 00:54:02 +02:00
|
|
|
|
2002-05-01 10:46:56 +02:00
|
|
|
|
|
|
|
/* handle to default stream class implementation for a given build */
|
|
|
|
/* this is used by "FT_New_Face" */
|
|
|
|
/* */
|
|
|
|
FT_APIVAR( FT_Type ) ft_stream_default_type;
|
2002-04-18 00:54:02 +02:00
|
|
|
|
|
|
|
FT_END_HEADER
|
|
|
|
|
|
|
|
#endif /* __FT_SYSTEM_STREAM_H__ */
|