X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/mLib/blobdiff_plain/34f655c10412ca059d43c78d1e137ab577acdd17..e7d93da8951557085bf18daac69e7b226203988e:/arena.c diff --git a/arena.c b/arena.c index 20d286c..30df2ee 100644 --- a/arena.c +++ b/arena.c @@ -1,6 +1,6 @@ /* -*-c-*- * - * $Id: arena.c,v 1.1 2000/06/17 10:37:53 mdw Exp $ + * $Id: arena.c,v 1.4 2001/06/22 19:32:59 mdw Exp $ * * Abstraction for memory allocation arenas * @@ -30,6 +30,15 @@ /*----- Revision history --------------------------------------------------* * * $Log: arena.c,v $ + * Revision 1.4 2001/06/22 19:32:59 mdw + * Remove a space. + * + * Revision 1.3 2000/08/06 11:00:18 mdw + * Daft bug fix. Include . + * + * Revision 1.2 2000/07/16 12:29:16 mdw + * Change to arena `realloc' interface, to fix a design bug. + * * Revision 1.1 2000/06/17 10:37:53 mdw * Basic arena management. * @@ -38,14 +47,16 @@ /*----- Header files ------------------------------------------------------*/ #include +#include #include "arena.h" /*----- The standard arena ------------------------------------------------*/ static void *_alloc(arena *a, size_t sz) { return malloc(sz); } -static void *_realloc(arena *a, void *p, size_t sz){ return realloc(p, sz); } -static void _free(arena *a, void *p) { free (p); } +static void *_realloc(arena *a, void *p, size_t sz, size_t osz) + { return realloc(p, sz); } +static void _free(arena *a, void *p) { free(p); } static arena_ops stdlib_ops = { _alloc, _realloc, _free, 0 }; arena arena_stdlib = { &stdlib_ops }; @@ -61,6 +72,7 @@ arena *arena_global = &arena_stdlib; * Arguments: @arena *a@ = pointer to arena block * @void *p@ = pointer to memory block to resize * @size_t sz@ = size desired for the block + * @size_t osz@ = size of the old block * * Returns: --- * @@ -68,12 +80,12 @@ arena *arena_global = &arena_stdlib; * support @realloc@ properly. */ -void *arena_fakerealloc(arena *a, void *p, size_t sz) +void *arena_fakerealloc(arena *a, void *p, size_t sz, size_t osz) { void *q = A_ALLOC(a, sz); if (!q) return (0); - memcpy(q, p, sz); + memcpy(q, p, sz > osz ? osz : sz); A_FREE(a, p); return (q); } @@ -81,7 +93,8 @@ void *arena_fakerealloc(arena *a, void *p, size_t sz) /* --- Function equivalents of the macros --- */ void *a_alloc(arena *a, size_t sz) { return (A_ALLOC(a, sz)); } -void *a_realloc(arena *a, void *p, size_t sz) { return A_REALLOC(a, p, sz); } +void *a_realloc(arena *a, void *p, size_t sz, size_t osz) +{ return A_REALLOC(a, p, sz, osz); } void a_free(arena *a, void *p) { A_FREE(a, p); } /*----- That's all, folks -------------------------------------------------*/