mirror of
https://github.com/CPunch/Cosmo.git
synced 2024-11-05 08:10:05 +00:00
82 lines
3.7 KiB
C
82 lines
3.7 KiB
C
#ifndef CMEME_C
|
|
#define CMEME_C // meme lol
|
|
|
|
#include "cosmo.h"
|
|
#include "cstate.h"
|
|
|
|
// #define GC_STRESS
|
|
// #define GC_DEBUG
|
|
// arrays *must* grow by a factor of 2
|
|
#define GROW_FACTOR 2
|
|
#define HEAP_GROW_FACTOR 2
|
|
#define ARRAY_START 8
|
|
|
|
#ifdef GC_DEBUG
|
|
# define cosmoM_freearray(state, type, buf, capacity) \
|
|
printf("freeing array %p [size %lu] at %s:%d\n", buf, sizeof(type) * capacity, __FILE__, \
|
|
__LINE__); \
|
|
cosmoM_reallocate(state, buf, sizeof(type) * capacity, 0)
|
|
#else
|
|
# define cosmoM_freearray(state, type, buf, capacity) \
|
|
cosmoM_reallocate(state, buf, sizeof(type) * capacity, 0)
|
|
#endif
|
|
|
|
#define cosmoM_growarray(state, type, buf, count, capacity) \
|
|
if (count >= capacity || buf == NULL) { \
|
|
int old = capacity; \
|
|
capacity = old * GROW_FACTOR; \
|
|
buf = (type *)cosmoM_reallocate(state, buf, sizeof(type) * old, sizeof(type) * capacity); \
|
|
}
|
|
|
|
#ifdef GC_DEBUG
|
|
# define cosmoM_free(state, type, x) \
|
|
printf("freeing %p [size %lu] at %s:%d\n", x, sizeof(type), __FILE__, __LINE__); \
|
|
cosmoM_reallocate(state, x, sizeof(type), 0)
|
|
#else
|
|
# define cosmoM_free(state, type, x) cosmoM_reallocate(state, x, sizeof(type), 0)
|
|
#endif
|
|
|
|
#define cosmoM_isFrozen(state) (state->freezeGC > 0)
|
|
|
|
// if debugging, print the locations of when the state is frozen/unfrozen
|
|
#ifdef GC_DEBUG
|
|
# define cosmoM_freezeGC(state) \
|
|
state->freezeGC++; \
|
|
printf("freezing state at %s:%d [%d]\n", __FILE__, __LINE__, state->freezeGC)
|
|
|
|
# define cosmoM_unfreezeGC(state) \
|
|
state->freezeGC--; \
|
|
printf("unfreezing state at %s:%d [%d]\n", __FILE__, __LINE__, state->freezeGC); \
|
|
cosmoM_checkGarbage(state, 0)
|
|
#else
|
|
|
|
// freeze's the garbage collector until cosmoM_unfreezeGC is called
|
|
# define cosmoM_freezeGC(state) state->freezeGC++
|
|
|
|
// unfreeze's the garbage collector and tries to run a garbage collection cycle
|
|
# define cosmoM_unfreezeGC(state) \
|
|
state->freezeGC--; \
|
|
cosmoM_checkGarbage(state, 0)
|
|
|
|
#endif
|
|
|
|
COSMO_API void *cosmoM_reallocate(CState *state, void *buf, size_t oldSize, size_t newSize);
|
|
COSMO_API bool cosmoM_checkGarbage(CState *state,
|
|
size_t needed); // returns true if GC event was triggered
|
|
COSMO_API void cosmoM_collectGarbage(CState *state);
|
|
COSMO_API void cosmoM_updateThreshhold(CState *state);
|
|
|
|
// lets the VM know you are holding a reference to a CObj and to not free it
|
|
COSMO_API void cosmoM_addRoot(CState *state, CObj *newRoot);
|
|
|
|
// lets the VM know this root is no longer held in a reference and is able to be freed
|
|
COSMO_API void cosmoM_removeRoot(CState *state, CObj *oldRoot);
|
|
|
|
// wrapper for cosmoM_reallocate so we can track our memory usage (it's also safer :P)
|
|
static inline void *cosmoM_xmalloc(CState *state, size_t sz)
|
|
{
|
|
return cosmoM_reallocate(state, NULL, 0, sz);
|
|
}
|
|
|
|
#endif
|