X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=functions%2Fstdlib%2Frealloc.c;h=099ad5dd170ea1251c4562d62bf70a295102bcc6;hb=17d539d4dad385b70e22c3611c7642e0a020d990;hp=c1ba38f4d1cd2b674aa0ae5013ff0ebf54070379;hpb=b08f4b52b1cd1f7a9553c0f357a7c90859fa3e73;p=pdclib diff --git a/functions/stdlib/realloc.c b/functions/stdlib/realloc.c index c1ba38f..099ad5d 100644 --- a/functions/stdlib/realloc.c +++ b/functions/stdlib/realloc.c @@ -16,25 +16,31 @@ void * realloc( void * ptr, size_t size ) { + void * newptr = NULL; if ( ptr == NULL ) { return malloc( size ); } + if ( size > 0 ) { - struct _PDCLIB_memnode_t * baseptr = (struct _PDCLIB_memnode_t *)( (char *)ptr - sizeof( struct _PDCLIB_memnode_t ) ); - if ( baseptr->size >= size ) - { - return ptr; - } - else - { - void * newptr = malloc( size ); - memcpy( newptr, ptr, baseptr->size ); - free( ptr ); - return newptr; + struct _PDCLIB_memnode_t * baseptr = (struct _PDCLIB_memnode_t *)( (char *)ptr - sizeof( struct _PDCLIB_memnode_t ) ); + if ( baseptr->size >= size ) + { + /* Current memnode is large enough; nothing to do. */ + return ptr; + } + else + { + /* Get larger memnode and copy over contents. */ + if ( ( newptr = malloc( size ) ) == NULL ) + { + return NULL; + } + memcpy( newptr, ptr, baseptr->size ); + } } - } - return NULL; + free( ptr ); + return newptr; } #endif @@ -49,3 +55,4 @@ int main( void ) } #endif +