[sdf] Add alloc/free functions.

* src/sdf/ftsdf.c (*): Add `sdf_alloc' and `sdf_free'
  to allocate and deallocate memory respectively.
  By using function we can directly use them in the
  conditional statements, which is not possible when
  using `do {} while ( 0 )'.

* src/sdf/ftsdf.c (SDF_MEMORY_TRACKER_): When not
  debugging don't leave the macros empty otherwise
  some compiler may emit warning because of empty
  `;' semi-colon.
This commit is contained in:
Anuj Verma 2020-07-19 08:36:38 +05:30 committed by anujverma
parent f41ee8f0c3
commit ddfa07c5da
2 changed files with 81 additions and 39 deletions

View File

@ -1,3 +1,18 @@
2020-07-19 Anuj Verma <anujv@iitbhilai.ac.in>
[sdf] Add alloc/free functions.
* src/sdf/ftsdf.c (*): Add `sdf_alloc' and `sdf_free'
to allocate and deallocate memory respectively.
By using function we can directly use them in the
conditional statements, which is not possible when
using `do {} while ( 0 )'.
* src/sdf/ftsdf.c (SDF_MEMORY_TRACKER_): When not
debugging don't leave the macros empty otherwise
some compiler may emit warning because of empty
`;' semi-colon.
2020-07-19 Anuj Verma <anujv@iitbhilai.ac.in> 2020-07-19 Anuj Verma <anujv@iitbhilai.ac.in>
[sdf] Added new renderer `bsdf'. [sdf] Added new renderer `bsdf'.

View File

@ -14,6 +14,17 @@
#ifdef FT_DEBUG_LEVEL_TRACE #ifdef FT_DEBUG_LEVEL_TRACE
#undef FT_DEBUG_INNER
#undef FT_ASSIGNP_INNER
#define FT_DEBUG_INNER( exp ) ( _ft_debug_file = __FILE__, \
_ft_debug_lineno = line, \
(exp) )
#define FT_ASSIGNP_INNER( p, exp ) ( _ft_debug_file = __FILE__, \
_ft_debug_lineno = line, \
FT_ASSIGNP( p, exp ) )
/* To be used with `FT_Memory::user' in order to track */ /* To be used with `FT_Memory::user' in order to track */
/* memory allocations. */ /* memory allocations. */
typedef struct SDF_MemoryUser_ typedef struct SDF_MemoryUser_
@ -23,39 +34,57 @@
} SDF_MemoryUser; } SDF_MemoryUser;
/* Use these macros while allocating and deallocating */ /* Use these functions while allocating and deallocating */
/* memory. These macros restore the previous user pointer */ /* memory. These macros restore the previous user pointer */
/* before calling the allocation functions, which is ess- */ /* before calling the allocation functions, which is ess- */
/* ential if the program is compiled with macro */ /* ential if the program is compiled with macro */
/* `FT_DEBUG_MEMORY'. */ /* `FT_DEBUG_MEMORY'. */
#define SDF_ALLOC( ptr, size ) \
do \
{ \
SDF_MemoryUser* current_user; \
\
\
current_user = (SDF_MemoryUser*)memory->user; \
memory->user = current_user->prev_user; \
\
if ( !FT_QALLOC( ptr, size ) ) \
current_user->total_usage += size; \
\
memory->user = (void*)current_user; \
} while ( 0 )
#define SDF_FREE( ptr ) \ static FT_Pointer
do \ sdf_alloc( FT_Memory memory,
{ \ FT_Long size,
SDF_MemoryUser* current_user; \ FT_Error* err,
\ FT_Int line )
\ {
current_user = (SDF_MemoryUser*)memory->user; \ SDF_MemoryUser* current_user;
memory->user = current_user->prev_user; \ FT_Pointer ptr;
\ FT_Error error;
FT_FREE( ptr ); \
\
memory->user = (void*)current_user; \ current_user = (SDF_MemoryUser*)memory->user;
} while ( 0 ) memory->user = current_user->prev_user;
if ( !FT_QALLOC( ptr, size ) )
current_user->total_usage += size;
memory->user = (void*)current_user;
*err = error;
return ptr;
}
static void
sdf_free( FT_Memory memory,
FT_Pointer ptr,
FT_Int line )
{
SDF_MemoryUser* current_user;
current_user = (SDF_MemoryUser*)memory->user;
memory->user = current_user->prev_user;
FT_FREE( ptr );
memory->user = (void*)current_user;
}
#define SDF_ALLOC( ptr, size ) \
( ptr = sdf_alloc( memory, size, \
&error, __LINE__ ), \
error != 0 )
#define SDF_FREE( ptr ) \
sdf_free( memory, ptr, __LINE__ ) \
#define SDF_MEMORY_TRACKER_DECLARE() SDF_MemoryUser sdf_memory_user #define SDF_MEMORY_TRACKER_DECLARE() SDF_MemoryUser sdf_memory_user
@ -77,9 +106,9 @@
#define SDF_FREE FT_FREE #define SDF_FREE FT_FREE
/* Do nothing */ /* Do nothing */
#define SDF_MEMORY_TRACKER_DECLARE() #define SDF_MEMORY_TRACKER_DECLARE() do {} while ( 0 )
#define SDF_MEMORY_TRACKER_SETUP() #define SDF_MEMORY_TRACKER_SETUP() do {} while ( 0 )
#define SDF_MEMORY_TRACKER_DONE() #define SDF_MEMORY_TRACKER_DONE() do {} while ( 0 )
#endif #endif
@ -314,8 +343,7 @@
goto Exit; goto Exit;
} }
SDF_ALLOC( ptr, sizeof( *ptr ) ); if ( !SDF_ALLOC( ptr, sizeof( *ptr ) ) )
if ( error == 0 )
{ {
*ptr = null_edge; *ptr = null_edge;
*edge = ptr; *edge = ptr;
@ -352,8 +380,7 @@
goto Exit; goto Exit;
} }
SDF_ALLOC( ptr, sizeof( *ptr ) ); if ( !SDF_ALLOC( ptr, sizeof( *ptr ) ) )
if ( error == 0 )
{ {
*ptr = null_contour; *ptr = null_contour;
*contour = ptr; *contour = ptr;
@ -405,8 +432,7 @@
goto Exit; goto Exit;
} }
SDF_ALLOC( ptr, sizeof( *ptr ) ); if ( !SDF_ALLOC( ptr, sizeof( *ptr ) ) )
if ( error == 0 )
{ {
*ptr = null_shape; *ptr = null_shape;
ptr->memory = memory; ptr->memory = memory;
@ -2669,8 +2695,7 @@
rows = bitmap->rows; rows = bitmap->rows;
buffer = (FT_Short*)bitmap->buffer; buffer = (FT_Short*)bitmap->buffer;
SDF_ALLOC( dists, width * rows * sizeof( *dists ) ); if ( SDF_ALLOC( dists, width * rows * sizeof( *dists ) ) )
if ( error != 0 )
goto Exit; goto Exit;
FT_MEM_ZERO( dists, width * rows * sizeof(*dists) ); FT_MEM_ZERO( dists, width * rows * sizeof(*dists) );
@ -3097,6 +3122,7 @@
{ {
FT_Error error = FT_Err_Ok; FT_Error error = FT_Err_Ok;
SDF_TRaster* raster = NULL; SDF_TRaster* raster = NULL;
FT_Int line = __LINE__;
*araster = 0; *araster = 0;
@ -3249,6 +3275,7 @@
sdf_raster_done( FT_Raster raster ) sdf_raster_done( FT_Raster raster )
{ {
FT_Memory memory = (FT_Memory)((SDF_TRaster*)raster)->memory; FT_Memory memory = (FT_Memory)((SDF_TRaster*)raster)->memory;
FT_Int line = __LINE__;
FT_FREE( raster ); FT_FREE( raster );