* include/freetype/internal/fnttypes.h, src/winfnt/*.c: updating

the type definitions of the Windows FNT font driver
BRANCH-2-1-5
David Turner 23 years ago
parent 5acebac70f
commit 2999605407
  1. 2
      ChangeLog
  2. 30
      include/freetype/internal/fnttypes.h
  3. 50
      src/winfonts/winfnt.c

@ -13,6 +13,8 @@
(i.e. CFF_Font => CFF_FontRec
CFF_Font* => CFF_Font, etc...)
* include/freetype/internal/fnttypes.h, src/winfnt/*.c: updating
the type definitions of the Windows FNT font driver
2002-03-13 Antoine Leca <antoine@oriolnet.com>

@ -28,26 +28,26 @@
FT_BEGIN_HEADER
typedef struct WinMZ_Header_
typedef struct WinMZ_HeaderRec_
{
FT_UShort magic;
/* skipped content */
FT_UShort lfanew;
} WinMZ_Header;
} WinMZ_HeaderRec;
typedef struct WinNE_Header_
typedef struct WinNE_HeaderRec_
{
FT_UShort magic;
/* skipped content */
FT_UShort resource_tab_offset;
FT_UShort rname_tab_offset;
} WinNE_Header;
} WinNE_HeaderRec;
typedef struct WinNameInfo_
typedef struct WinNameInfoRec_
{
FT_UShort offset;
FT_UShort length;
@ -56,22 +56,22 @@ FT_BEGIN_HEADER
FT_UShort handle;
FT_UShort usage;
} WinNameInfo;
} WinNameInfoRec;
typedef struct WinResourceInfo_
typedef struct WinResourceInfoRec_
{
FT_UShort type_id;
FT_UShort count;
} WinResourceInfo;
} WinResourceInfoRec;
#define WINFNT_MZ_MAGIC 0x5A4D
#define WINFNT_NE_MAGIC 0x454E
typedef struct WinFNT_Header_
typedef struct WinFNT_HeaderRec_
{
FT_UShort version;
FT_ULong file_size;
@ -110,26 +110,26 @@ FT_BEGIN_HEADER
FT_UShort color_table_offset;
FT_Byte reserved2[4];
} WinFNT_Header;
} WinFNT_HeaderRec, *WinFNT_Header;
typedef struct FNT_Font_
typedef struct FNT_FontRec_
{
FT_ULong offset;
FT_Int size_shift;
WinFNT_Header header;
WinFNT_HeaderRec header;
FT_Byte* fnt_frame;
FT_ULong fnt_size;
} FNT_Font;
} FNT_FontRec, *FNT_Font;
typedef struct FNT_SizeRec_
{
FT_SizeRec root;
FNT_Font* font;
FNT_Font font;
} FNT_SizeRec, *FNT_Size;
@ -139,7 +139,7 @@ FT_BEGIN_HEADER
FT_FaceRec root;
FT_UInt num_fonts;
FNT_Font* fonts;
FNT_Font fonts;
FT_CharMap charmap_handle;
FT_CharMapRec charmap; /* a single charmap per face */

@ -41,7 +41,7 @@
const FT_Frame_Field winmz_header_fields[] =
{
#undef FT_STRUCTURE
#define FT_STRUCTURE WinMZ_Header
#define FT_STRUCTURE WinMZ_HeaderRec
FT_FRAME_START( 64 ),
FT_FRAME_USHORT_LE ( magic ),
@ -54,7 +54,7 @@
const FT_Frame_Field winne_header_fields[] =
{
#undef FT_STRUCTURE
#define FT_STRUCTURE WinNE_Header
#define FT_STRUCTURE WinNE_HeaderRec
FT_FRAME_START( 40 ),
FT_FRAME_USHORT_LE ( magic ),
@ -68,7 +68,7 @@
const FT_Frame_Field winfnt_header_fields[] =
{
#undef FT_STRUCTURE
#define FT_STRUCTURE WinFNT_Header
#define FT_STRUCTURE WinFNT_HeaderRec
FT_FRAME_START( 134 ),
FT_FRAME_USHORT_LE( version ),
@ -112,7 +112,7 @@
static void
fnt_font_done( FNT_Font* font,
fnt_font_done( FNT_Font font,
FT_Stream stream )
{
if ( font->fnt_frame )
@ -124,11 +124,11 @@
static FT_Error
fnt_font_load( FNT_Font* font,
fnt_font_load( FNT_Font font,
FT_Stream stream )
{
FT_Error error;
WinFNT_Header* header = &font->header;
WinFNT_Header header = &font->header;
/* first of all, read the FNT header */
@ -171,8 +171,8 @@
{
FT_Memory memory = FT_FACE(face)->memory;
FT_Stream stream = FT_FACE(face)->stream;
FNT_Font* cur = face->fonts;
FNT_Font* limit = cur + face->num_fonts;
FNT_Font cur = face->fonts;
FNT_Font limit = cur + face->num_fonts;
for ( ; cur < limit; cur++ )
@ -189,7 +189,7 @@
FT_Error error;
FT_Stream stream = FT_FACE(face)->stream;
FT_Memory memory = FT_FACE(face)->memory;
WinMZ_Header mz_header;
WinMZ_HeaderRec mz_header;
face->fonts = 0;
@ -204,7 +204,7 @@
if ( mz_header.magic == WINFNT_MZ_MAGIC )
{
/* yes, now look for a NE header in the file */
WinNE_Header ne_header;
WinNE_HeaderRec ne_header;
if ( FILE_Seek( mz_header.lfanew ) ||
@ -261,7 +261,7 @@
}
if ( FILE_Seek( font_offset ) ||
ALLOC_ARRAY( face->fonts, font_count, FNT_Font ) )
ALLOC_ARRAY( face->fonts, font_count, FNT_FontRec ) )
goto Exit;
face->num_fonts = font_count;
@ -271,8 +271,8 @@
/* now read the offset and position of each FNT font */
{
FNT_Font* cur = face->fonts;
FNT_Font* limit = cur + font_count;
FNT_Font cur = face->fonts;
FNT_Font limit = cur + font_count;
for ( ; cur < limit; cur++ )
@ -287,8 +287,8 @@
/* finally, try to load each font there */
{
FNT_Font* cur = face->fonts;
FNT_Font* limit = cur + font_count;
FNT_Font cur = face->fonts;
FNT_Font limit = cur + font_count;
for ( ; cur < limit; cur++ )
@ -326,7 +326,7 @@
fnt_cmap_init( FT_CMap cmap )
{
FNT_Face face = (FNT_Face) FT_CMAP_FACE(cmap);
FNT_Font* font = face->fonts;
FNT_Font font = face->fonts;
cmap->first = (FT_UInt32) font->header.first_char;
cmap->count = (FT_UInt32)(font->header.last_char - cmap->first + 1);
@ -399,7 +399,7 @@
if ( charmap )
{
FNT_Font* font = ((FNT_Face)charmap->face)->fonts;
FNT_Font font = ((FNT_Face)charmap->face)->fonts;
FT_Long first = font->header.first_char;
FT_Long count = font->header.last_char - first + 1;
@ -422,7 +422,7 @@
char_code++;
if ( charmap )
{
FNT_Font* font = ((FNT_Face)charmap->face)->fonts;
FNT_Font font = ((FNT_Face)charmap->face)->fonts;
FT_Long first = font->header.first_char;
@ -472,7 +472,7 @@
if ( error )
{
/* this didn't work, now try to load a single FNT font */
FNT_Font* font;
FNT_Font font;
if ( ALLOC( face->fonts, sizeof ( *face->fonts ) ) )
goto Exit;
@ -492,9 +492,9 @@
/* fill the root FT_Face fields with relevant information */
{
FT_Face root = FT_FACE( face );
FNT_Font* fonts = face->fonts;
FNT_Font* limit = fonts + face->num_fonts;
FNT_Font* cur;
FNT_Font fonts = face->fonts;
FNT_Font limit = fonts + face->num_fonts;
FNT_Font cur;
root->num_faces = 1;
@ -595,8 +595,8 @@
{
/* look up a font corresponding to the current pixel size */
FNT_Face face = (FNT_Face)FT_SIZE_FACE( size );
FNT_Font* cur = face->fonts;
FNT_Font* limit = cur + face->num_fonts;
FNT_Font cur = face->fonts;
FNT_Font limit = cur + face->num_fonts;
size->font = 0;
@ -626,7 +626,7 @@
FT_UInt glyph_index,
FT_Int load_flags )
{
FNT_Font* font = size->font;
FNT_Font font = size->font;
FT_Error error = 0;
FT_Byte* p;
FT_Int len;

Loading…
Cancel
Save