[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:
parent
f41ee8f0c3
commit
ddfa07c5da
|
@ -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'.
|
||||||
|
|
105
src/sdf/ftsdf.c
105
src/sdf/ftsdf.c
|
@ -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 );
|
||||||
|
|
Loading…
Reference in New Issue