Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

737 lines
19 KiB

/*++
Copyright (c) 1996 Adobe Systems Incorporated
Copyright (c) 1996-1999 Microsoft Corporation
Module Name:
afm2ntm.h
Abstract:
Header file for converting AFM to NTM.
Environment:
Windows NT PostScript driver.
Revision History:
02/16/1998 -ksuzuki-
Added CS_SHIFTJIS83 and others for OCF font support.
10/17/1997 -ksuzuki-
Added CJK CMap names, fixed typos, and did clean-up.
10/24/1996 [email protected]
Implemented.
09/16/1996 -slam-
Created.
--*/
#ifndef _AFM2NTM_H_
#define _AFM2NTM_H_
//
// Parsing Macros.
//
#define EOL(a) \
(*a == '\r' || *a == '\n')
#define IS_EOF(a) \
(*a == -1)
#define IS_WHTSPACE(a) \
(*(a) <= ' ')
#define IS_ALPHA(a) \
((*a > 'A' && *a < 'Z') || (*a > 'a' && *a < 'z'))
#define IS_NUM(a) \
(*(a) >= '0' && *(a) <= '9')
#define IS_HEX_ALPHA(a) \
((*(a) >= 'a' && *(a) <= 'f') || (*(a) >= 'A' && *(a) <= 'F'))
#define IS_HEX_DIGIT(a) \
(IS_NUM(a) || IS_HEX_ALPHA(a))
#define SKIP_WHTSPACE(a) \
while ((IS_WHTSPACE(a)) && (!IS_EOF(a))) \
{ \
((ULONG_PTR) a)++; \
}
#define NEXT_LINE(a) \
while ((!EOL(a)) && (!IS_EOF(a))) \
{ \
((ULONG_PTR) a)++; \
} \
SKIP_WHTSPACE(a)
#define PARSE_TOKEN(a, Tok) \
SKIP_WHTSPACE(a); \
Tok = a; \
do \
{ \
if (!IS_EOF(a)) \
((ULONG_PTR) a)++; \
} while (!IS_WHTSPACE(a) && !IS_EOF(a)); \
while (!EOL(a) && !IS_EOF(a) && IS_WHTSPACE(a)) \
{ \
((ULONG_PTR) a)++; \
}
#define NEXT_TOKEN(a) \
while(!EOL(a) && *(a) != ';') \
((ULONG_PTR) a)++; \
while ((*(a) == ';' || IS_WHTSPACE(a))) \
{ \
((ULONG_PTR) (a))++; \
}
#define PARSE_RECT(ptr, rect) \
rect.left = atoi(ptr); \
while (!IS_WHTSPACE(ptr)) \
ptr++; \
SKIP_WHTSPACE(ptr); \
rect.bottom = atoi(ptr); \
while (!IS_WHTSPACE(ptr)) \
ptr++; \
SKIP_WHTSPACE(ptr); \
rect.right = atoi(ptr); \
while (!IS_WHTSPACE(ptr)) \
ptr++; \
SKIP_WHTSPACE(ptr); \
rect.top = atoi(ptr); \
while (!IS_WHTSPACE(ptr)) \
ptr++; \
SKIP_WHTSPACE(ptr)
//
// Macro to detect comments in font .DAT files. This macro is NOT for use
// with AFMs.
//
#define IS_COMMENT(a) \
(*(a) == '#')
//
// Token structure.
//
typedef struct _AFM_TOKEN
{
PSZ psTokName; // ASCII Key Name
PFN pfnTokHndlr; // Ptr to token handler fct
} AFM_TOKEN;
#define PS_CH_METRICS_TOK "StartCharMetrics"
#define PS_CH_NAME_TOK "N"
#define PS_CH_CODE_TOK "C"
#define PS_CH_BBOX_TOK "B"
#define PS_FONT_NAME_TOK "FontName"
#define PS_FONT_FULL_NAME_TOK "FullName"
#define PS_FONT_MS_NAME_TOK "MSFaceName"
#define PS_FONT_FAMILY_NAME_TOK "FamilyName"
#define PS_FONT_VERSION_TOK "Version"
#define PS_CHAR_WIDTH_TOK "CharWidth"
#define PS_PITCH_TOK "IsFixedPitch"
#define PS_CH_WIDTH_TOK "WX"
#define PS_CH_WIDTH0_TOK "W0X"
#define PS_COMMENT_TOK "Comment"
#define PS_END_METRICS_TOK "EndCharMetrics"
#define PS_FONT_BBOX_TOK "FontBBox"
#define PS_FONT_BBOX2_TOK "FontBBox2"
#define PS_EOF_TOK "EndFontMetrics"
#define PS_UNDERLINE_POS_TOK "UnderlinePosition"
#define PS_UNDERLINE_THICK_TOK "UnderlineThickness"
#define PS_KERN_DATA_TOK "StartKernData"
#define PS_NUM_KERN_PAIRS_TOK "StartKernPairs"
#define PS_END_KERN_PAIRS_TOK "EndKernPairs"
#define PS_KERN_PAIR_TOK "KPX"
#define PS_CHARSET_TOK "CharacterSet"
#define PS_STANDARD_CHARSET_TOK "Standard"
#define PS_SPECIAL_CHARSET_TOK "Special"
#define PS_EXTENDED_CHARSET_TOK "ExtendedRoman"
#define PS_ITALIC_TOK "ItalicAngle"
#define PS_WEIGHT_TOK "Weight"
#define PS_ENCODING_TOK "EncodingScheme"
#define PS_SYMBOL_ENCODING "FontSpecific"
#define PS_STANDARD_ENCODING "AdobeStandardEncoding"
#define PS_CH_NAME_EASTEUROPE "ncaron"
#define PS_CH_NAME_RUSSIAN "afii10071"
#define PS_CH_NAME_ANSI "ecircumflex"
#define PS_CH_NAME_GREEK "upsilondieresis"
#define PS_CH_NAME_TURKISH "Idotaccent"
#define PS_CH_NAME_HEBREW "afii57664"
#define PS_CH_NAME_ARABIC "afii57410"
#define PS_CH_NAME_BALTIC "uogonek"
#define PS_CIDFONT_TOK "IsCIDFont"
#define CHAR_NAME_LEN 50
#define NUM_PS_CHARS 602
#define NUM_UNICODE_CHARS 0x10000
#define MAX_TOKENS 3
#define NUM_CHARSETS 8
#define CS_THRESHOLD 200
#define MAX_CSET_CHARS 256
#define MAX_ASCII 127
#define CAP_HEIGHT_CHAR "H"
#define CAP_HEIGHT_CH 'H'
#define X_HEIGHT_CHAR "x"
#define X_HEIGHT_CH 'x'
#define LWR_ASCENT_CHAR "d"
#define LWR_ASCENT_CH 'd'
#define LWR_DESCENT_CHAR "p"
#define LWR_DESCENT_CH 'p'
#define UNICODE_PRV_STRT 0xf000
#define ANSI_CCODE_MAX 0x007f
// Equivalent symbol to '.notdef1f' (ref. unipstbl.c)
#define NOTDEF1F 0x1f
// Some CharSet numbers made up - only meaningful to the driver itself
#define ADOBE228_CHARSET 255 // Internally, we use the CodePage 0xFFF1 to match CharCol256
#define ADOBE314_CHARSET 255 // Internally, we use the CodePage 0xFFF2 to match CharCol257
// Special codepage for symbol fonts and the driver itself
#define SYMBOL_CODEPAGE 4
//
// Defs related to FD_GLYPHSET (unicode->glyphindex map) generation.
//
// Type which indicates source of "recommended" PS character name.
//
typedef enum
{
SRC_NONE, // There is no "recommended" PS char name
SRC_ADOBE_CURRENT, // Font name used in "shipping" font
SRC_ADOBE_FUTURE, // Font name to be used in future fonts
SRC_MSDN, // Name from MS Dev Network Docs
SRC_AFII // Some folks met and agreed on this name
} CHARNAMESRC;
//
// Possible Charsets supported by this font. Note that the charsets are
// listed in Win 3.x codepage order.
//
typedef enum
{
CS_228 = 0,
CS_314,
CS_EASTEUROPE,
CS_SYMBOL,
CS_RUSSIAN,
CS_ANSI,
CS_GREEK,
CS_TURKISH,
CS_HEBREW,
CS_ARABIC,
CS_BALTIC,
CS_ANSI_RUS,
CS_ANSI_RUS_EE_BAL_TURK,
CS_WEST_MAX,
CS_CHINESEBIG5 = CS_WEST_MAX,
CS_GB2312,
CS_SHIFTJIS,
CS_SHIFTJISP,
CS_SHIFTJIS83, // Bogus for OCF font support
CS_HANGEUL,
CS_HANGEULHW, // Added for fixing bug 360206
CS_JOHAB,
CS_MAX,
CS_UNICODE, // This codepage NOT to be referenced by NTMs!
CS_DEFAULT,
CS_OEM,
CS_VIETNAMESE,
CS_THAI,
CS_MAC,
CS_NOCHARSET
} CHSETSUPPORT, *PCHSETSUPPORT;
#define CS_UNIQUE CS_MAX // Charset is unique to this font.
#define CS_EURO \
(\
CSUP(CS_228) | \
CSUP(CS_EASTEUROPE) | \
CSUP(CS_RUSSIAN) | \
CSUP(CS_ANSI) | \
CSUP(CS_GREEK) | \
CSUP(CS_TURKISH) | \
CSUP(CS_HEBREW) | \
CSUP(CS_ARABIC) | \
CSUP(CS_BALTIC) \
)
#define CS_ALL \
(\
CSUP(CS_228) | \
CSUP(CS_314) | \
CSUP(CS_EASTEUROPE) | \
CSUP(CS_SYMBOL) | \
CSUP(CS_RUSSIAN) | \
CSUP(CS_ANSI) | \
CSUP(CS_GREEK) | \
CSUP(CS_TURKISH) | \
CSUP(CS_HEBREW) | \
CSUP(CS_ARABIC) | \
CSUP(CS_BALTIC) | \
CSUP(CS_ANSI_RUS) | \
CSUP(CS_ANSI_RUS_EE_BAL_TURK) | \
\
CSUP(CS_CHINESEBIG5) | \
CSUP(CS_GB2312) | \
CSUP(CS_SHIFTJIS) | \
CSUP(CS_SHIFTJISP) | \
CSUP(CS_SHIFTJIS83) | \
CSUP(CS_HANGEUL) | \
CSUP(CS_HANGEULHW) | \
CSUP(CS_JOHAB) | \
\
CSUP(CS_DEFAULT) | \
CSUP(CS_OEM) | \
CSUP(CS_VIETNAMESE) | \
CSUP(CS_THAI) | \
CSUP(CS_MAC) \
)
#define CS_CJK \
(\
CSUP(CS_CHINESEBIG5) | \
CSUP(CS_GB2312) | \
CSUP(CS_SHIFTJIS) | \
CSUP(CS_SHIFTJISP) | \
CSUP(CS_SHIFTJIS83) | \
CSUP(CS_HANGEUL) | \
CSUP(CS_HANGEULHW) | \
CSUP(CS_JOHAB) \
)
//
// Standard GLYPHSETDATA names. These are #defines as someday they may
// become public.
//
#define ADOBE228_GS_NAME "228"
#define ADOBE314_GS_NAME "314"
#define EASTEUROPE_GS_NAME "Eastern European"
#define SYMBOL_GS_NAME "Symbol"
#define CYRILLIC_GS_NAME "Cyrillic"
#define ANSI_GS_NAME "ANSI"
#define GREEK_GS_NAME "Greek"
#define TURKISH_GS_NAME "Turkish"
#define HEBREW_GS_NAME "Hebrew"
#define ARABIC_GS_NAME "Arabic"
#define BALTIC_GS_NAME "Baltic"
#define ANSI_CYR_GS_NAME "ANSI/Cyrillic"
#define ANSI_CYR_EE_BAL_TURK_GS_NAME "ANSI/Cyrillic/EastEurope/Baltic/Turkish"
#define CHN_BIG5_GS_NAME "--ETen-B5-"
#define CHN_SMPL_GBK_GS_NAME "--GBK-EUC-"
#define SHIFTJIS_GS_NAME "-90ms-RKSJ-"
#define SHIFTJIS_P_GS_NAME "-90msp-RKSJ-"
#define KSCMS_UHC_GS_NAME "--KSCms-UHC-"
#define KSC_JOHAB_GS_NAME "--KSC-Johab-"
#define UNICODE_GS_NAME "Unicode"
#define CHN_SMPL_GB_GS_NAME "--GB-EUC-"
#define CHN_SMPL_GBT_GS_NAME "--GBT-EUC-"
#define CHN_B5_GS_NAME "--B5-"
#define SHIFTJIS_83PV_GS_NAME "-83pv-RKSJ-"
#define KSC_GS_NAME "--KSC-EUC-"
#define KSCMS_UHC_HW_GS_NAME "--KSCms-UHC-HW-"
#define SHIFTJIS_P_GS_HNAME "-90msp-RKSJ-H"
#define SHIFTJIS_P_GS_VNAME "-90msp-RKSJ-V"
#define KSCMS_UHC_GS_HNAME "--KSCms-UHC-H"
#define KSCMS_UHC_GS_VNAME "--KSCms-UHC-V"
//
// CJK related stuff.
//
#define CMAPS_PER_COL 4
//
// Win CJK Codepage values.
//
#define CH_BIG5 950 // Traditional Chinese
#define CH_SIMPLE 936 // Simplified Chinese
#define CH_JIS 932 // Japanese
#define CH_HANA 949 // Korean Wansung
#define CH_JOHAB 1361 // Korean Johab
//
// Font Metrics Stuff.
//
#define EM 1000
#define NOTDEF_WIDTH_BIAS 166 // Bias of space char in avg charwidth
// computation.
//
// Structure to xlat between Postscript char names and unicode code points.
//
typedef struct _UPSCODEPT
{
WCHAR wcUnicodeid; // Unicode code point
PUCHAR pPsName; // PS Char Name
CHSETSUPPORT flCharSets; // Which Win CPs are supported?
} UPSCODEPT, *PUPSCODEPT;
//
// Structure to store AFM char metrics.
//
typedef struct _AFMCHMETRICS
{
ULONG chWidth; // WX, W0X: Char width
} AFMCHMETRICS, *PAFMCHMETRICS;
//
// PS Char Info Structure.
//
typedef struct _PSCHARMETRICS
{
CHAR pPsName[CHAR_NAME_LEN];
ULONG chWidth;
RECT rcChBBox;
} PSCHARMETRICS, *PPSCHARMETRICS;
//
// Codepage mapping table structure. Maps PS char names to Win
// codepages/codepoints.
//
//
// Win codept to PS char name mapping.
//
typedef struct _WINCPT
{
PUCHAR pPsName; // PS Char Name
USHORT usWinCpt; // Windows codept
} WINCPT, *PWINCPT;
//
// Win Codepage to PS char name mapping.
//
typedef struct _WINCPTOPS
{
USHORT usACP; // Windows ANSI Codepage
BYTE jWinCharset; // Win 3.1 IFIMETRICS.jWinCharset
PUCHAR pGSName; // Glyphset name for this Codepage
ULONG ulChCnt; // Count of supported chars
WINCPT aWinCpts[MAX_CSET_CHARS];
} WINCPTOPS, *PWINCPTOPS;
//
// Win codepoint to Unicode mapping.
//
typedef struct _UNIWINCPT
{
WCHAR wcWinCpt; // Windows charcode value
WCHAR wcUnicodeid; // Unicode id
} UNIWINCPT, *PUNIWINCPT;
//
// Windows codepage structure.
//
typedef struct _WINCODEPAGE
{
USHORT usNumBaseCsets; // # of base csets
PSZ pszCPname; // Name of this "codepage"
CHSETSUPPORT pCsetList[CS_MAX]; // ptr to base csets supported
} WINCODEPAGE, *PWINCODEPAGE;
//
// Structure used to store EXTTEXTMETRIC info which must be derived
// from the AFM char metrics. These fields are identical to the fields
// etmCapHeight -> etmLowerCaseDescent in the EXTTEXTMETRIC struct.
//
typedef struct _ETMINFO
{
SHORT etmCapHeight;
SHORT etmXHeight;
SHORT etmLowerCaseAscent;
SHORT etmLowerCaseDescent;
} ETMINFO, *PETMINFO;
//
// Generic Key-Value pair.
//
typedef struct _KEY
{
CHAR pName[CHAR_NAME_LEN]; // Key name
USHORT usValue; // Value
} KEY, *PKEY;
//
// Format of table entries which map PS font names to MS face (family) names.
//
typedef struct _PSFAMILYINFO
{
CHAR pFontName[CHAR_NAME_LEN];
CHAR pEngFamilyName[CHAR_NAME_LEN];
KEY FamilyKey;
USHORT usPitch;
} PSFAMILYINFO, *PPSFAMILYINFO;
//
// Generic table struct.
//
typedef struct _TBL
{
USHORT usNumEntries; // Number of PSFAMILYINFOs
PVOID pTbl; // -> to table entries
} TBL, *PTBL;
//
// Macro used to determine if a particular codept's CHSETSUPPORT field
// (see UPSCODEPT above) indicates support for a particular charset.
//
#define CSUP(a) \
(1 << a)
#define CSET_SUPPORT(cpt, cset) \
(cpt & (CSUP(cset)))
//
// Macros used to determine if a char from a glyphset is supported by a
// font. Takes the char index and IsCharDefined table as parms.
//
#define CHR_DEF(gi) \
(1 << (gi % 8))
#define CHR_DEF_INDEX(gi) \
(gi / 8)
#define IS_CHAR_DEFINED(gi, cdeftbl) \
(cdeftbl[CHR_DEF_INDEX(gi)] & CHR_DEF(gi))
#define DEFINE_CHAR(gi, cdeftbl) \
(cdeftbl[CHR_DEF_INDEX(gi)] |= CHR_DEF(gi))
//
// Macro used to create a void ptr from a pointer to a structure and its
// element name. The result must be cast to the desired type.
//
#ifndef MK_PTR
#define MK_PTR(pstruct, element) ((PVOID)((PBYTE)(pstruct)+(pstruct)->element))
#endif
//
// External global data defined in UNIPSTBL.C.
//
extern ULONG cFontChsetCnt[CS_MAX];
extern UPSCODEPT PstoUnicode[NUM_PS_CHARS];
extern PUPSCODEPT UnicodetoPs;
extern WINCODEPAGE aStdCPList[];
extern AFM_TOKEN afmTokenList[MAX_TOKENS];
extern WINCPTOPS aPStoCP[];
extern WINCODEPAGE aStdCPList[];
extern char *TimesAlias[];
extern char *HelveticaAlias[];
extern char *CourierAlias[];
extern char *HelveticaNarrowAlias[];
extern char *PalatinoAlias[];
extern char *BookmanAlias[];
extern char *NewCenturySBAlias[];
extern char *AvantGardeAlias[];
extern char *ZapfChanceryAlias[];
extern char *ZapfDingbatsAlias[];
extern KEY FontFamilies[];
extern PWCHAR DatFileName;
extern PTBL pFamilyTbl;
extern TBL FamilyKeyTbl;
extern TBL PitchKeyTbl;
extern TBL WeightKeyTbl[];
extern TBL CjkColTbl;
extern ULONG CharWidthBias[];
extern PWCHAR CjkFnameTbl[8][CMAPS_PER_COL];
extern WINCODEPAGE UnicodePage;
extern char *PropCjkGsNames[];
extern PSTR pAFMCharacterSetString;
//
// Local fct protos.
//
PNTM
AFMToNTM(
PBYTE pAFM,
PGLYPHSETDATA pGlyphSetData,
PULONG pUniPs,
CHSETSUPPORT *pCharSet,
BOOL bIsCJKFont,
BOOL bIs90mspFont
);
CHSETSUPPORT
GetAFMCharSetSupport(
PBYTE pAFM,
CHSETSUPPORT *pGlyphSet
);
PBYTE
FindAFMToken(
PBYTE pAFM,
PSZ pszToken
);
extern int __cdecl
StrCmp(
const VOID *str1,
const VOID *str2
);
extern size_t
StrLen(
PBYTE pString
);
extern int
StrCpy(
const VOID *str1,
const VOID *str2
);
extern int __cdecl
StrPos(
const PBYTE str1,
CHAR c
);
int __cdecl
CmpUniCodePts(
const VOID *p1,
const VOID *p2
);
static int __cdecl
CmpUnicodePsNames(
const VOID *p1,
const VOID *p2
);
extern int __cdecl
CmpPsChars(
const VOID *p1,
const VOID *p2
);
ULONG
CreateGlyphSets(
PGLYPHSETDATA *pGlyphSet,
PWINCODEPAGE pWinCodePage,
PULONG *pUniPs
);
ULONG
BuildPSFamilyTable(
PBYTE pDatFile,
PTBL *pPsFamilyTbl,
ULONG ulFileSize
);
LONG
FindClosestCodePage(
PWINCODEPAGE *pWinCodePages,
ULONG ulNumCodePages,
CHSETSUPPORT chSets,
PCHSETSUPPORT pchCsupMatch
);
ULONG
GetAFMCharWidths(
PBYTE pAFM,
PWIDTHRUN *pWidthRuns,
PPSCHARMETRICS pFontChars,
PULONG pUniPs,
ULONG ulChCnt,
PUSHORT pusAvgCharWidth,
PUSHORT pusMaxCharWidth
);
ULONG
GetAFMETM(
PBYTE pAFM,
PPSCHARMETRICS pFontChars,
PETMINFO pEtmInfo
);
ULONG
GetAFMKernPairs(
PBYTE pAFM,
FD_KERNINGPAIR *pKernPairs,
PGLYPHSETDATA pGlyphSetData
);
static int __cdecl
CmpPsChars(
const VOID *p1,
const VOID *p2
);
static int __cdecl
CmpPsNameWinCpt(
const VOID *p1,
const VOID *p2
);
static int __cdecl
CmpKernPairs(
const VOID *p1,
const VOID *p2
);
int __cdecl
CmpGlyphRuns(
const VOID *p1,
const VOID *p2
);
ULONG
BuildPSCharMetrics(
PBYTE pAFM,
PULONG pUniPs,
PPSCHARMETRICS pFontChars,
PBYTE pCharDefTbl,
ULONG cGlyphSetChars
);
ULONG
cjGetFamilyAliases(
IFIMETRICS *pifi,
PSTR pstr,
UINT cp
);
PBYTE
FindStringToken(
PBYTE pPSFile,
PBYTE pToken
);
BOOLEAN
AsciiToHex(
PBYTE pStr,
PUSHORT pNum
);
BOOLEAN
IsPiFont(
PBYTE pAFM
);
BOOLEAN
IsCJKFixedPitchEncoding(
PGLYPHSETDATA pGlyphSetData
);
PBYTE
FindUniqueID(
PBYTE pAFM
);
#endif //!_AFM2NTM_H_