/* Copyright (C) 1997, 1998, 1999 Aladdin Enterprises. All rights reserved. This software is provided AS-IS with no warranty, either express or implied. This software is distributed under license and may not be copied, modified or distributed except as expressly authorized under the terms of the license contained in the file LICENSE in this distribution. For more information about licensing, please refer to http://www.ghostscript.com/licensing/. For information on commercial licensing, go to http://www.artifex.com/licensing/ or contact Artifex Software, Inc., 101 Lucas Valley Road #110, San Rafael, CA 94903, U.S.A., +1(415)492-9861. */ /* $Id: gsmalloc.h,v 1.6 2004/08/04 19:36:12 stefan Exp $ */ /* Client interface to default (C heap) allocator */ /* Requires gsmemory.h */ #ifndef gsmalloc_INCLUDED # define gsmalloc_INCLUDED /* Define a memory manager that allocates directly from the C heap. */ typedef struct gs_malloc_block_s gs_malloc_block_t; typedef struct gs_malloc_memory_s { gs_memory_common; gs_malloc_block_t *allocated; long limit; long used; long max_used; } gs_malloc_memory_t; /* Allocate and initialize a malloc memory manager. */ gs_malloc_memory_t *gs_malloc_memory_init(void); /* Release all the allocated blocks, and free the memory manager. */ /* The cast is unfortunate, but unavoidable. */ #define gs_malloc_memory_release(mem)\ gs_memory_free_all((gs_memory_t *)mem, FREE_ALL_EVERYTHING,\ "gs_malloc_memory_release") gs_memory_t * gs_malloc_init(const gs_memory_t *parent); void gs_malloc_release(gs_memory_t *mem); #define gs_malloc(mem, nelts, esize, cname)\ (void *)gs_alloc_byte_array(mem->non_gc_memory, nelts, esize, cname) #define gs_free(mem, data, nelts, esize, cname)\ gs_free_object(mem->non_gc_memory, data, cname) /* ---------------- Locking ---------------- */ /* Create a locked wrapper for a heap allocator. */ int gs_malloc_wrap(gs_memory_t **wrapped, gs_malloc_memory_t *contents); /* Get the wrapped contents. */ gs_malloc_memory_t *gs_malloc_wrapped_contents(gs_memory_t *wrapped); /* Free the wrapper, and return the wrapped contents. */ gs_malloc_memory_t *gs_malloc_unwrap(gs_memory_t *wrapped); #endif /* gsmalloc_INCLUDED */