/* $Cambridge: exim/exim-src/src/store.h,v 1.4 2007/01/08 10:50:18 ph10 Exp $ */
/*************************************************
* Exim - an Internet mail transport agent *
*************************************************/
/* Copyright (c) University of Cambridge 1995 - 2007 */
/* See the file NOTICE for conditions of use and distribution. */
/* Header for Exim's memory allocation functions */
#ifndef STORE_H
#define STORE_H
/* Define symbols for identifying the store pools. */
enum { POOL_MAIN, POOL_PERM, POOL_SEARCH };
/* This variable (the one for the current pool) is set by store_get() to its
yield, and by store_reset() to NULL. This allows string_cat() to optimize its
store handling. */
extern void *store_last_get[3];
/* This variable contains the current store pool number. */
extern int store_pool;
/* Macros for calling the memory allocation routines with
tracing information for debugging. */
#define store_extend(addr,old,new) \
store_extend_3(addr, old, new, __FILE__, __LINE__)
#define store_free(addr) store_free_3(addr, __FILE__, __LINE__)
#define store_get(size) store_get_3(size, __FILE__, __LINE__)
#define store_get_perm(size) store_get_perm_3(size, __FILE__, __LINE__)
#define store_malloc(size) store_malloc_3(size, __FILE__, __LINE__)
#define store_release(addr) store_release_3(addr, __FILE__, __LINE__)
#define store_reset(addr) store_reset_3(addr, __FILE__, __LINE__)
/* The real functions */
extern BOOL store_extend_3(void *, int, int, const char *, int); /* The */
extern void store_free_3(void *, const char *, int); /* value of the */
extern void *store_get_3(int, const char *, int); /* 2nd arg is */
extern void *store_get_perm_3(int, const char *, int); /* __FILE__ in */
extern void *store_malloc_3(int, const char *, int); /* every call, */
extern void store_release_3(void *, const char *, int); /* so give its */
extern void store_reset_3(void *, const char *, int); /* correct type */
#endif /* STORE_H */
/* End of store.h */
syntax highlighted by Code2HTML, v. 0.9.1