1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433
|
/*
* Public header file.
* Copyright (c) 1995-1998 Markku Rossi.
*
* Author: Markku Rossi <mtr@iki.fi>
*/
/*
* Enscript is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Enscript is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Enscript. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef AFM_H
#define AFM_H
#ifndef ___P
#if PROTOTYPES
#define ___P(protos) protos
#else /* no PROTOTYPES */
#define ___P(protos) ()
#endif /* no PROTOTYPES */
#endif
/**********************************************************************
*
* AFM file entities.
*
**********************************************************************/
/* AFM types. */
#define AFM_TYPE_STRING 1
#define AFM_TYPE_NAME 2
#define AFM_TYPE_NUMBER 3
#define AFM_TYPE_INTEGER 4
#define AFM_TYPE_ARRAY 5
#define AFM_TYPE_BOOLEAN 6
typedef char *AFMString;
typedef char *AFMName;
typedef double AFMNumber;
typedef long AFMInteger;
typedef enum
{
AFMFalse = 0,
AFMTrue = 1
} AFMBoolean;
typedef struct afm_array_st *AFMArray;
struct afm_node_st
{
int type;
union
{
AFMString string;
AFMName name;
AFMNumber number;
AFMInteger integer;
AFMArray array;
AFMBoolean boolean;
} u;
};
typedef struct afm_node_st AFMNode;
struct afm_array_st
{
AFMNumber num_items;
AFMNode *items;
};
/* AFM file data structures. */
/*
* Sorry! I know that those mixed case variable names are ugly,
* but this is the way how they are written in Adobe's document
* so I think that this is the best way for documentary reasons.
*/
/* Global Font Information*/
struct global_font_information_st
{
AFMString FontName;
AFMString FullName;
AFMString FamilyName;
AFMString Weight;
AFMNumber FontBBox_llx;
AFMNumber FontBBox_lly;
AFMNumber FontBBox_urx;
AFMNumber FontBBox_ury;
AFMString Version;
AFMString Notice;
AFMString EncodingScheme;
AFMInteger MappingScheme;
AFMInteger EscChar;
AFMString CharacterSet;
AFMInteger Characters;
AFMBoolean IsBaseFont;
AFMNumber VVector_0;
AFMNumber VVector_1;
AFMBoolean IsFixedV;
AFMNumber CapHeight;
AFMNumber XHeight;
AFMNumber Ascender;
AFMNumber Descender;
AFMArray BlendAxisTypes;
AFMArray BlendDesignPositions;
AFMArray BlendDesignMap;
AFMArray WeightVector;
};
typedef struct global_font_information_st AFMGlobalFontInformation;
/* Writing Direction Metrics. */
struct writing_direction_metrics_st
{
AFMBoolean is_valid;
AFMNumber UnderlinePosition;
AFMNumber UnderlineThickness;
AFMNumber ItalicAngle;
AFMNumber CharWidth_x;
AFMNumber CharWidth_y;
AFMBoolean IsFixedPitch;
};
typedef struct writing_direction_metrics_st AFMWritingDirectionMetrics;
/* Multiple Master Axis Information. */
struct multiple_master_axis_info_st
{
AFMString AxisType;
AFMString AxisLabel;
};
typedef struct multiple_master_axis_info_st AFMMultipleMasterAxisInformation;
/* Individual Character Metrics. */
struct ligature_st
{
AFMName successor;
AFMName ligature;
};
typedef struct ligature_st AFMLigature;
/* Single individual character. */
struct individual_character_metrics_st
{
AFMInteger character_code; /* default charcode (-1 if not encoded) */
AFMNumber w0x; /* character width x in writing direction 0 */
AFMNumber w0y; /* character width y in writing direction 0 */
AFMNumber w1x; /* character width x in writing direction 1 */
AFMNumber w1y; /* character width y in writing direction 1 */
AFMName name; /* character name */
AFMNumber vv_x; /* local VVector x */
AFMNumber vv_y; /* local VVector y */
/* character bounding box. */
AFMNumber llx;
AFMNumber lly;
AFMNumber urx;
AFMNumber ury;
AFMNumber num_ligatures;
AFMLigature *ligatures;
};
typedef struct individual_character_metrics_st AFMIndividualCharacterMetrics;
/* Kerning Data. */
/* Track Kerning Data. */
struct track_kern_st
{
AFMInteger degree;
AFMNumber min_ptsize;
AFMNumber min_kern;
AFMNumber max_ptsize;
AFMNumber max_kern;
};
typedef struct track_kern_st AFMTrackKern;
/* Pair-Wise Kerning. */
struct pair_wise_kerning_st
{
AFMName name1;
AFMName name2;
AFMNumber kx;
AFMNumber ky;
};
typedef struct pair_wise_kerning_st AFMPairWiseKerning;
/* Composite fonts. */
/* Single composite component. */
struct composite_component_st
{
AFMName name;
AFMNumber deltax;
AFMNumber deltay;
};
typedef struct composite_component_st AFMCompositeComponent;
struct composite_st
{
AFMName name;
AFMInteger num_components;
AFMCompositeComponent *components;
};
typedef struct composite_st AFMComposite;
/**********************************************************************
*
* Library API.
*
**********************************************************************/
/* Constants. */
#define UNITS_PER_POINT 1000
/* Successful operation. */
#define AFM_SUCCESS 0
/*
* AFM information levels. The AFM libarary returns always Global
* Font information, Writing Direction Metrics and Individual
* Character Metrics. Other fields can be retrieved by defining some
* of the following flags to afm_open_{font, file}() functions.
*/
#define AFM_I_MINIMUM 0x00
#define AFM_I_COMPOSITES 0x01
#define AFM_I_KERN_PAIRS 0x02
#define AFM_I_TRACK_KERNS 0x04
#define AFM_I_ALL 0xffffffff
/*
* Flags for the encoding functions.
*/
#define AFM_ENCODE_ACCEPT_COMPOSITES 0x01
typedef unsigned int AFMError;
typedef struct afm_handle_st *AFMHandle;
/* Supported encoding types. */
typedef enum
{
AFM_ENCODING_DEFAULT, /* Font's default encoding. */
AFM_ENCODING_ISO_8859_1, /* ISO-8859-1 */
AFM_ENCODING_ISO_8859_2, /* ISO-8859-2 */
AFM_ENCODING_ISO_8859_3, /* ISO-8859-3 */
AFM_ENCODING_ISO_8859_4, /* ISO-8859-4 */
AFM_ENCODING_ISO_8859_5, /* ISO-8859-5 */
AFM_ENCODING_ISO_8859_7, /* ISO-8859-7 */
AFM_ENCODING_ISO_8859_9, /* ISO-8859-9 */
AFM_ENCODING_ISO_8859_10, /* ISO-8859-10 */
AFM_ENCODING_IBMPC, /* IBM PC */
AFM_ENCODING_ASCII, /* 7 bit ASCII */
AFM_ENCODING_MAC, /* Mac */
AFM_ENCODING_VMS, /* VMS multinational */
AFM_ENCODING_HP8, /* HP Roman-8 */
AFM_ENCODING_KOI8 /* Adobe Standard Cyrillic Font KOI8 */
} AFMEncoding;
/* Special encoding types for individual characters. */
#define AFM_ENC_NONE ((void *) 0)
#define AFM_ENC_NON_EXISTENT ((void *) 1)
/* AFM information for a single PostScript font. */
struct afm_font_st
{
/* AFM Library's private data. */
struct afm_font_private_data_st *private;
AFMNumber version; /* AFM format specification version number. */
unsigned int info_level;
/*
* Current font encoding. Following values are valid:
*
* AFM_ENC_NONE character is not encoded
* AFM_ENC_NON_EXISTENT character is encoded, but font does not
* have the specified character
* <pointer to character's metrics>
* character is encoded and it exists in font
*/
AFMIndividualCharacterMetrics *encoding[256];
AFMGlobalFontInformation global_info;
AFMWritingDirectionMetrics writing_direction_metrics[2];
AFMInteger num_character_metrics;
AFMIndividualCharacterMetrics *character_metrics;
AFMInteger num_composites;
AFMComposite *composites;
AFMInteger num_kern_pairs;
AFMPairWiseKerning *kern_pairs;
AFMInteger num_track_kerns;
AFMTrackKern *track_kerns;
};
typedef struct afm_font_st *AFMFont;
/*
* Prototypes for public functions.
*/
/*
* Format error <error> to human readable format to buffer <buf>.
* Buffer must be long enough for error messages (256 bytes is good).
*/
void afm_error_to_string ___P ((AFMError error, char *buf));
/*
* Open AFM library. <path> specifies the search path for the AFM
* files. A handle to the library is returned in <handle_return>.
*/
AFMError afm_create ___P ((const char *path, unsigned int verbose_level,
AFMHandle *handle_return));
/*
* Close AFM library handle <handle>.
*/
AFMError afm_destroy ___P ((AFMHandle handle));
/*
* Set AFM library's verbose level to <level>. Value 0 means "no output".
*/
AFMError afm_set_verbose ___P ((AFMHandle handle, unsigned int level));
/*
* Return a prefix to the font <fontname>'s data. Various font
* resource file names can be constructed from the returned prefix:
* AFM <prefix>.afm
* PFA <prefix>.pfa
*
* Returned prefix belongs to AFM library, user should not modify it.
*/
AFMError afm_font_prefix ___P ((AFMHandle handle, const char *fontname,
const char **prefix_return));
/*
* Open font <name> and return font handle in <font_return>.
*/
AFMError afm_open_font ___P ((AFMHandle handle, unsigned int info_level,
const char *name, AFMFont *font_return));
/*
* Open AFM file <filename> and return font handle in <font_return>.
*/
AFMError afm_open_file ___P ((AFMHandle handle, unsigned int info_level,
const char *filename, AFMFont *font_return));
/*
* Open built-in default font (Courier).
*/
AFMError afm_open_default_font ___P ((AFMHandle handle, AFMFont *font_return));
/*
* Close font <font>.
*/
AFMError afm_close_font ___P ((AFMFont font));
/*
* Dump font information to file <fp>.
*/
void afm_font_dump ___P ((FILE *fp, AFMFont font));
/*
* Return the width of the string <string, stringlen>.
*/
AFMError afm_font_stringwidth ___P ((AFMFont font, AFMNumber ptsize,
char *string, unsigned int stringlen,
AFMNumber *w0x_return,
AFMNumber *w0y_return));
/*
* Return the width of the character <ch>.
*/
AFMError afm_font_charwidth ___P ((AFMFont font, AFMNumber ptsize,
char ch, AFMNumber *w0x_return,
AFMNumber *w0y_return));
/*
* Encode character code <code> to print as character <name>.
* If <name> is NULL, encoding is removed. <flags> can contain
* any combination of the AFM_ENCODE_* values.
*/
AFMError afm_font_encode ___P ((AFMFont font, unsigned char code, char *name,
unsigned int flags));
/*
* Apply encoding <enc> to font <font>. <flags> can contain any
* combination of the AFM_ENCODE_* values.
*/
AFMError afm_font_encoding ___P ((AFMFont font, AFMEncoding enc,
unsigned int flags));
#endif /* not AFM_H */
|