X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/mLib/blobdiff_plain/d94be36654214c09fa6510611658325a84d5cfa7..b5ea4de3ac1c61ef84c21f4e3ceff2181d23e456:/arena.c diff --git a/arena.c b/arena.c index 20d286c..3e13bf2 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.2 2000/07/16 12:29:16 mdw Exp $ * * Abstraction for memory allocation arenas * @@ -30,6 +30,9 @@ /*----- Revision history --------------------------------------------------* * * $Log: arena.c,v $ + * 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. * @@ -44,7 +47,8 @@ /*----- 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 *_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 }; @@ -61,6 +65,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 +73,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 +86,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 -------------------------------------------------*/