1 /**************************************************************************** 2 * 3 * ftsystem.h 4 * 5 * FreeType low-level system interface definition (specification). 6 * 7 * Copyright (C) 1996-2021 by 8 * David Turner, Robert Wilhelm, and Werner Lemberg. 9 * 10 * This file is part of the FreeType project, and may only be used, 11 * modified, and distributed under the terms of the FreeType project 12 * license, LICENSE.TXT. By continuing to use, modify, or distribute 13 * this file you indicate that you have read the license and 14 * understand and accept it fully. 15 * 16 */ 17 18 19 #ifndef FTSYSTEM_H_ 20 #define FTSYSTEM_H_ 21 22 23 24 25 FT_BEGIN_HEADER 26 27 28 /************************************************************************** 29 * 30 * @section: 31 * system_interface 32 * 33 * @title: 34 * System Interface 35 * 36 * @abstract: 37 * How FreeType manages memory and i/o. 38 * 39 * @description: 40 * This section contains various definitions related to memory management 41 * and i/o access. You need to understand this information if you want to 42 * use a custom memory manager or you own i/o streams. 43 * 44 */ 45 46 47 /************************************************************************** 48 * 49 * M E M O R Y M A N A G E M E N T 50 * 51 */ 52 53 54 /************************************************************************** 55 * 56 * @type: 57 * FT_Memory 58 * 59 * @description: 60 * A handle to a given memory manager object, defined with an 61 * @FT_MemoryRec structure. 62 * 63 */ 64 typedef struct FT_MemoryRec_* FT_Memory; 65 66 67 /************************************************************************** 68 * 69 * @functype: 70 * FT_Alloc_Func 71 * 72 * @description: 73 * A function used to allocate `size` bytes from `memory`. 74 * 75 * @input: 76 * memory :: 77 * A handle to the source memory manager. 78 * 79 * size :: 80 * The size in bytes to allocate. 81 * 82 * @return: 83 * Address of new memory block. 0~in case of failure. 84 * 85 */ 86 typedef void* 87 (*FT_Alloc_Func)( FT_Memory memory, 88 long size ); 89 90 91 /************************************************************************** 92 * 93 * @functype: 94 * FT_Free_Func 95 * 96 * @description: 97 * A function used to release a given block of memory. 98 * 99 * @input: 100 * memory :: 101 * A handle to the source memory manager. 102 * 103 * block :: 104 * The address of the target memory block. 105 * 106 */ 107 typedef void 108 (*FT_Free_Func)( FT_Memory memory, 109 void* block ); 110 111 112 /************************************************************************** 113 * 114 * @functype: 115 * FT_Realloc_Func 116 * 117 * @description: 118 * A function used to re-allocate a given block of memory. 119 * 120 * @input: 121 * memory :: 122 * A handle to the source memory manager. 123 * 124 * cur_size :: 125 * The block's current size in bytes. 126 * 127 * new_size :: 128 * The block's requested new size. 129 * 130 * block :: 131 * The block's current address. 132 * 133 * @return: 134 * New block address. 0~in case of memory shortage. 135 * 136 * @note: 137 * In case of error, the old block must still be available. 138 * 139 */ 140 typedef void* 141 (*FT_Realloc_Func)( FT_Memory memory, 142 long cur_size, 143 long new_size, 144 void* block ); 145 146 147 /************************************************************************** 148 * 149 * @struct: 150 * FT_MemoryRec 151 * 152 * @description: 153 * A structure used to describe a given memory manager to FreeType~2. 154 * 155 * @fields: 156 * user :: 157 * A generic typeless pointer for user data. 158 * 159 * alloc :: 160 * A pointer type to an allocation function. 161 * 162 * free :: 163 * A pointer type to an memory freeing function. 164 * 165 * realloc :: 166 * A pointer type to a reallocation function. 167 * 168 */ 169 struct FT_MemoryRec_ 170 { 171 void* user; 172 FT_Alloc_Func alloc; 173 FT_Free_Func free; 174 FT_Realloc_Func realloc; 175 }; 176 177 178 /************************************************************************** 179 * 180 * I / O M A N A G E M E N T 181 * 182 */ 183 184 185 /************************************************************************** 186 * 187 * @type: 188 * FT_Stream 189 * 190 * @description: 191 * A handle to an input stream. 192 * 193 * @also: 194 * See @FT_StreamRec for the publicly accessible fields of a given stream 195 * object. 196 * 197 */ 198 typedef struct FT_StreamRec_* FT_Stream; 199 200 201 /************************************************************************** 202 * 203 * @struct: 204 * FT_StreamDesc 205 * 206 * @description: 207 * A union type used to store either a long or a pointer. This is used 208 * to store a file descriptor or a `FILE*` in an input stream. 209 * 210 */ 211 typedef union FT_StreamDesc_ 212 { 213 long value; 214 void* pointer; 215 216 } FT_StreamDesc; 217 218 219 /************************************************************************** 220 * 221 * @functype: 222 * FT_Stream_IoFunc 223 * 224 * @description: 225 * A function used to seek and read data from a given input stream. 226 * 227 * @input: 228 * stream :: 229 * A handle to the source stream. 230 * 231 * offset :: 232 * The offset of read in stream (always from start). 233 * 234 * buffer :: 235 * The address of the read buffer. 236 * 237 * count :: 238 * The number of bytes to read from the stream. 239 * 240 * @return: 241 * The number of bytes effectively read by the stream. 242 * 243 * @note: 244 * This function might be called to perform a seek or skip operation with 245 * a `count` of~0. A non-zero return value then indicates an error. 246 * 247 */ 248 typedef unsigned long 249 (*FT_Stream_IoFunc)( FT_Stream stream, 250 unsigned long offset, 251 unsigned char* buffer, 252 unsigned long count ); 253 254 255 /************************************************************************** 256 * 257 * @functype: 258 * FT_Stream_CloseFunc 259 * 260 * @description: 261 * A function used to close a given input stream. 262 * 263 * @input: 264 * stream :: 265 * A handle to the target stream. 266 * 267 */ 268 typedef void 269 (*FT_Stream_CloseFunc)( FT_Stream stream ); 270 271 272 /************************************************************************** 273 * 274 * @struct: 275 * FT_StreamRec 276 * 277 * @description: 278 * A structure used to describe an input stream. 279 * 280 * @input: 281 * base :: 282 * For memory-based streams, this is the address of the first stream 283 * byte in memory. This field should always be set to `NULL` for 284 * disk-based streams. 285 * 286 * size :: 287 * The stream size in bytes. 288 * 289 * In case of compressed streams where the size is unknown before 290 * actually doing the decompression, the value is set to 0x7FFFFFFF. 291 * (Note that this size value can occur for normal streams also; it is 292 * thus just a hint.) 293 * 294 * pos :: 295 * The current position within the stream. 296 * 297 * descriptor :: 298 * This field is a union that can hold an integer or a pointer. It is 299 * used by stream implementations to store file descriptors or `FILE*` 300 * pointers. 301 * 302 * pathname :: 303 * This field is completely ignored by FreeType. However, it is often 304 * useful during debugging to use it to store the stream's filename 305 * (where available). 306 * 307 * read :: 308 * The stream's input function. 309 * 310 * close :: 311 * The stream's close function. 312 * 313 * memory :: 314 * The memory manager to use to preload frames. This is set internally 315 * by FreeType and shouldn't be touched by stream implementations. 316 * 317 * cursor :: 318 * This field is set and used internally by FreeType when parsing 319 * frames. In particular, the `FT_GET_XXX` macros use this instead of 320 * the `pos` field. 321 * 322 * limit :: 323 * This field is set and used internally by FreeType when parsing 324 * frames. 325 * 326 */ 327 typedef struct FT_StreamRec_ 328 { 329 unsigned char* base; 330 unsigned long size; 331 unsigned long pos; 332 333 FT_StreamDesc descriptor; 334 FT_StreamDesc pathname; 335 FT_Stream_IoFunc read; 336 FT_Stream_CloseFunc close; 337 338 FT_Memory memory; 339 unsigned char* cursor; 340 unsigned char* limit; 341 342 } FT_StreamRec; 343 344 /* */ 345 346 347 FT_END_HEADER 348 349 #endif /* FTSYSTEM_H_ */ 350 351 352 /* END */ 353