size_t realsize;
// updated each time the pool is displayed by memlist, shows change from previous time (unless pool was freed)
size_t lastchecksize;
- // name of the pool
- char name[POOLNAMESIZE];
// linked into global mempool list
struct mempool_s *next;
// parent object (used for nested memory pools)
// file name and line where Mem_AllocPool was called
const char *filename;
int fileline;
+ // name of the pool
+ char name[POOLNAMESIZE];
// should always be MEMHEADER_SENTINEL1
unsigned int sentinel2;
}
// if pool is NULL this searches ALL pools for the allocation
qboolean Mem_IsAllocated(mempool_t *pool, void *data);
+typedef struct memexpandablearray_array_s
+{
+ unsigned char *data;
+ unsigned char *allocflags;
+ size_t numflaggedrecords;
+}
+memexpandablearray_array_t;
+
+typedef struct memexpandablearray_s
+{
+ mempool_t *mempool;
+ size_t recordsize;
+ size_t numrecordsperarray;
+ size_t numarrays;
+ size_t maxarrays;
+ memexpandablearray_array_t *arrays;
+}
+memexpandablearray_t;
+
+void Mem_ExpandableArray_NewArray(memexpandablearray_t *l, mempool_t *mempool, size_t recordsize, int numrecordsperarray);
+void Mem_ExpandableArray_FreeArray(memexpandablearray_t *l);
+void *Mem_ExpandableArray_AllocRecord(memexpandablearray_t *l);
+void Mem_ExpandableArray_FreeRecord(memexpandablearray_t *l, void *record);
+size_t Mem_ExpandableArray_IndexRange(memexpandablearray_t *l);
+void *Mem_ExpandableArray_RecordAtIndex(memexpandablearray_t *l, size_t index);
+
// used for temporary allocations
extern mempool_t *tempmempool;