Subversion Repositories Kolibri OS

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
4349 Serge 1
/***************************************************************************/
2
/*                                                                         */
3
/*  ftsystem.c                                                             */
4
/*                                                                         */
5
/*    ANSI-specific FreeType low-level system interface (body).            */
6
/*                                                                         */
7
/*  Copyright 1996-2002, 2006, 2008-2011, 2013 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
  /*                                                                       */
20
  /* This file contains the default interface used by FreeType to access   */
21
  /* low-level, i.e. memory management, i/o access as well as thread       */
22
  /* synchronisation.  It can be replaced by user-specific routines if     */
23
  /* necessary.                                                            */
24
  /*                                                                       */
25
  /*************************************************************************/
26
 
27
 
28
#include 
29
#include FT_CONFIG_CONFIG_H
30
#include FT_INTERNAL_DEBUG_H
31
#include FT_INTERNAL_STREAM_H
32
#include FT_SYSTEM_H
33
#include FT_ERRORS_H
34
#include FT_TYPES_H
35
 
36
 
37
  /*************************************************************************/
38
  /*                                                                       */
39
  /*                       MEMORY MANAGEMENT INTERFACE                     */
40
  /*                                                                       */
41
  /*************************************************************************/
42
 
43
  /*************************************************************************/
44
  /*                                                                       */
45
  /* It is not necessary to do any error checking for the                  */
46
  /* allocation-related functions.  This will be done by the higher level  */
47
  /* routines like ft_mem_alloc() or ft_mem_realloc().                     */
48
  /*                                                                       */
49
  /*************************************************************************/
50
 
51
 
52
  /*************************************************************************/
53
  /*                                                                       */
54
  /*                                                             */
55
  /*    ft_alloc                                                           */
56
  /*                                                                       */
57
  /*                                                          */
58
  /*    The memory allocation function.                                    */
59
  /*                                                                       */
60
  /*                                                                */
61
  /*    memory :: A pointer to the memory object.                          */
62
  /*                                                                       */
63
  /*    size   :: The requested size in bytes.                             */
64
  /*                                                                       */
65
  /*                                                               */
66
  /*    The address of newly allocated block.                              */
67
  /*                                                                       */
68
  FT_CALLBACK_DEF( void* )
69
  ft_alloc( FT_Memory  memory,
70
            long       size )
71
  {
72
    FT_UNUSED( memory );
73
 
74
    return ft_smalloc( size );
75
  }
76
 
77
 
78
  /*************************************************************************/
79
  /*                                                                       */
80
  /*                                                             */
81
  /*    ft_realloc                                                         */
82
  /*                                                                       */
83
  /*                                                          */
84
  /*    The memory reallocation function.                                  */
85
  /*                                                                       */
86
  /*                                                                */
87
  /*    memory   :: A pointer to the memory object.                        */
88
  /*                                                                       */
89
  /*    cur_size :: The current size of the allocated memory block.        */
90
  /*                                                                       */
91
  /*    new_size :: The newly requested size in bytes.                     */
92
  /*                                                                       */
93
  /*    block    :: The current address of the block in memory.            */
94
  /*                                                                       */
95
  /*                                                               */
96
  /*    The address of the reallocated memory block.                       */
97
  /*                                                                       */
98
  FT_CALLBACK_DEF( void* )
99
  ft_realloc( FT_Memory  memory,
100
              long       cur_size,
101
              long       new_size,
102
              void*      block )
103
  {
104
    FT_UNUSED( memory );
105
    FT_UNUSED( cur_size );
106
 
107
    return ft_srealloc( block, new_size );
108
  }
109
 
110
 
111
  /*************************************************************************/
112
  /*                                                                       */
113
  /*                                                             */
114
  /*    ft_free                                                            */
115
  /*                                                                       */
116
  /*                                                          */
117
  /*    The memory release function.                                       */
118
  /*                                                                       */
119
  /*                                                                */
120
  /*    memory  :: A pointer to the memory object.                         */
121
  /*                                                                       */
122
  /*    block   :: The address of block in memory to be freed.             */
123
  /*                                                                       */
124
  FT_CALLBACK_DEF( void )
125
  ft_free( FT_Memory  memory,
126
           void*      block )
127
  {
128
    FT_UNUSED( memory );
129
 
130
    ft_sfree( block );
131
  }
132
 
133
 
134
  /*************************************************************************/
135
  /*                                                                       */
136
  /*                     RESOURCE MANAGEMENT INTERFACE                     */
137
  /*                                                                       */
138
  /*************************************************************************/
139
 
140
#ifndef FT_CONFIG_OPTION_DISABLE_STREAM_SUPPORT
141
 
142
  /*************************************************************************/
143
  /*                                                                       */
144
  /* The macro FT_COMPONENT is used in trace mode.  It is an implicit      */
145
  /* parameter of the FT_TRACE() and FT_ERROR() macros, used to print/log  */
146
  /* messages during execution.                                            */
147
  /*                                                                       */
148
#undef  FT_COMPONENT
149
#define FT_COMPONENT  trace_io
150
 
151
  /* We use the macro STREAM_FILE for convenience to extract the       */
152
  /* system-specific stream handle from a given FreeType stream object */
153
#define STREAM_FILE( stream )  ( (FT_FILE*)stream->descriptor.pointer )
154
 
155
 
156
  /*************************************************************************/
157
  /*                                                                       */
158
  /*                                                             */
159
  /*    ft_ansi_stream_close                                               */
160
  /*                                                                       */
161
  /*                                                          */
162
  /*    The function to close a stream.                                    */
163
  /*                                                                       */
164
  /*                                                                */
165
  /*    stream :: A pointer to the stream object.                          */
166
  /*                                                                       */
167
  FT_CALLBACK_DEF( void )
168
  ft_ansi_stream_close( FT_Stream  stream )
169
  {
170
    ft_fclose( STREAM_FILE( stream ) );
171
 
172
    stream->descriptor.pointer = NULL;
173
    stream->size               = 0;
174
    stream->base               = 0;
175
  }
176
 
177
 
178
  /*************************************************************************/
179
  /*                                                                       */
180
  /*                                                             */
181
  /*    ft_ansi_stream_io                                                  */
182
  /*                                                                       */
183
  /*                                                          */
184
  /*    The function to open a stream.                                     */
185
  /*                                                                       */
186
  /*                                                                */
187
  /*    stream :: A pointer to the stream object.                          */
188
  /*                                                                       */
189
  /*    offset :: The position in the data stream to start reading.        */
190
  /*                                                                       */
191
  /*    buffer :: The address of buffer to store the read data.            */
192
  /*                                                                       */
193
  /*    count  :: The number of bytes to read from the stream.             */
194
  /*                                                                       */
195
  /*                                                               */
196
  /*    The number of bytes actually read.  If `count' is zero (this is,   */
197
  /*    the function is used for seeking), a non-zero return value         */
198
  /*    indicates an error.                                                */
199
  /*                                                                       */
200
  FT_CALLBACK_DEF( unsigned long )
201
  ft_ansi_stream_io( FT_Stream       stream,
202
                     unsigned long   offset,
203
                     unsigned char*  buffer,
204
                     unsigned long   count )
205
  {
206
    FT_FILE*  file;
207
 
208
 
209
    if ( !count && offset > stream->size )
210
      return 1;
211
 
212
    file = STREAM_FILE( stream );
213
 
214
    if ( stream->pos != offset )
215
      ft_fseek( file, offset, SEEK_SET );
216
 
217
    return (unsigned long)ft_fread( buffer, 1, count, file );
218
  }
219
 
220
 
221
  /* documentation is in ftstream.h */
222
 
223
  FT_BASE_DEF( FT_Error )
224
  FT_Stream_Open( FT_Stream    stream,
225
                  const char*  filepathname )
226
  {
227
    FT_FILE*  file;
228
 
229
 
230
    if ( !stream )
231
      return FT_THROW( Invalid_Stream_Handle );
232
 
233
    stream->descriptor.pointer = NULL;
234
    stream->pathname.pointer   = (char*)filepathname;
235
    stream->base               = 0;
236
    stream->pos                = 0;
237
    stream->read               = NULL;
238
    stream->close              = NULL;
239
 
240
    file = ft_fopen( filepathname, "rb" );
241
    if ( !file )
242
    {
243
      FT_ERROR(( "FT_Stream_Open:"
244
                 " could not open `%s'\n", filepathname ));
245
 
246
      return FT_THROW( Cannot_Open_Resource );
247
    }
248
 
249
    ft_fseek( file, 0, SEEK_END );
250
    stream->size = ft_ftell( file );
251
    if ( !stream->size )
252
    {
253
      FT_ERROR(( "FT_Stream_Open:" ));
254
      FT_ERROR(( " opened `%s' but zero-sized\n", filepathname ));
255
      ft_fclose( file );
256
      return FT_THROW( Cannot_Open_Stream );
257
    }
258
    ft_fseek( file, 0, SEEK_SET );
259
 
260
    stream->descriptor.pointer = file;
261
    stream->read  = ft_ansi_stream_io;
262
    stream->close = ft_ansi_stream_close;
263
 
264
    FT_TRACE1(( "FT_Stream_Open:" ));
265
    FT_TRACE1(( " opened `%s' (%d bytes) successfully\n",
266
                filepathname, stream->size ));
267
 
268
    return FT_Err_Ok;
269
  }
270
 
271
#endif /* !FT_CONFIG_OPTION_DISABLE_STREAM_SUPPORT */
272
 
273
#ifdef FT_DEBUG_MEMORY
274
 
275
  extern FT_Int
276
  ft_mem_debug_init( FT_Memory  memory );
277
 
278
  extern void
279
  ft_mem_debug_done( FT_Memory  memory );
280
 
281
#endif
282
 
283
 
284
  /* documentation is in ftobjs.h */
285
 
286
  FT_BASE_DEF( FT_Memory )
287
  FT_New_Memory( void )
288
  {
289
    FT_Memory  memory;
290
 
291
 
292
    memory = (FT_Memory)ft_smalloc( sizeof ( *memory ) );
293
    if ( memory )
294
    {
295
      memory->user    = 0;
296
      memory->alloc   = ft_alloc;
297
      memory->realloc = ft_realloc;
298
      memory->free    = ft_free;
299
#ifdef FT_DEBUG_MEMORY
300
      ft_mem_debug_init( memory );
301
#endif
302
    }
303
 
304
    return memory;
305
  }
306
 
307
 
308
  /* documentation is in ftobjs.h */
309
 
310
  FT_BASE_DEF( void )
311
  FT_Done_Memory( FT_Memory  memory )
312
  {
313
#ifdef FT_DEBUG_MEMORY
314
    ft_mem_debug_done( memory );
315
#endif
316
    ft_sfree( memory );
317
  }
318
 
319
 
320
/* END */