1
0
mirror of https://github.com/janet-lang/janet synced 2025-01-13 09:00:26 +00:00

Merge commit 'f4c9064b79d5b32fd74e5ddf25266356c22dd53b'

This commit is contained in:
Calvin Rose 2021-04-29 15:58:41 -05:00
commit 49f66a936c
30 changed files with 171 additions and 128 deletions

View File

@ -7,13 +7,13 @@ typedef struct {
} num_array; } num_array;
static num_array *num_array_init(num_array *array, size_t size) { static num_array *num_array_init(num_array *array, size_t size) {
array->data = (double *)calloc(size, sizeof(double)); array->data = (double *)janet_calloc(size, sizeof(double));
array->size = size; array->size = size;
return array; return array;
} }
static void num_array_deinit(num_array *array) { static void num_array_deinit(num_array *array) {
free(array->data); janet_free(array->data);
} }
static int num_array_gc(void *p, size_t s) { static int num_array_gc(void *p, size_t s) {

View File

@ -93,7 +93,7 @@ int main(int argc, const char **argv) {
fseek(boot_file, 0, SEEK_END); fseek(boot_file, 0, SEEK_END);
size_t boot_size = ftell(boot_file); size_t boot_size = ftell(boot_file);
fseek(boot_file, 0, SEEK_SET); fseek(boot_file, 0, SEEK_SET);
unsigned char *boot_buffer = malloc(boot_size); unsigned char *boot_buffer = janet_malloc(boot_size);
if (NULL == boot_buffer) { if (NULL == boot_buffer) {
fprintf(stderr, "Failed to allocate boot buffer\n"); fprintf(stderr, "Failed to allocate boot buffer\n");
exit(1); exit(1);
@ -105,7 +105,7 @@ int main(int argc, const char **argv) {
fclose(boot_file); fclose(boot_file);
status = janet_dobytes(env, boot_buffer, (int32_t) boot_size, boot_filename, NULL); status = janet_dobytes(env, boot_buffer, (int32_t) boot_size, boot_filename, NULL);
free(boot_buffer); janet_free(boot_buffer);
/* Deinitialize vm */ /* Deinitialize vm */
janet_deinit(); janet_deinit();

View File

@ -48,6 +48,13 @@
/* #define JANET_ARCH_NAME pdp-8 */ /* #define JANET_ARCH_NAME pdp-8 */
/* #define JANET_EV_EPOLL */ /* #define JANET_EV_EPOLL */
/* Custom vm allocator support */
/* #include <mimalloc.h> */
/* #define janet_malloc(X) mi_malloc((X)) */
/* #define janet_realloc(X, Y) mi_realloc((X), (Y)) */
/* #define janet_calloc(X, Y) mi_calloc((X), (Y)) */
/* #define janet_free(X) mi_free((X)) */
/* Main client settings, does not affect library code */ /* Main client settings, does not affect library code */
/* #define JANET_SIMPLE_GETLINE */ /* #define JANET_SIMPLE_GETLINE */

View File

@ -36,7 +36,7 @@ JanetArray *janet_array(int32_t capacity) {
Janet *data = NULL; Janet *data = NULL;
if (capacity > 0) { if (capacity > 0) {
janet_vm_next_collection += capacity * sizeof(Janet); janet_vm_next_collection += capacity * sizeof(Janet);
data = (Janet *) malloc(sizeof(Janet) * (size_t) capacity); data = (Janet *) janet_malloc(sizeof(Janet) * (size_t) capacity);
if (NULL == data) { if (NULL == data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -52,7 +52,7 @@ JanetArray *janet_array_n(const Janet *elements, int32_t n) {
JanetArray *array = janet_gcalloc(JANET_MEMORY_ARRAY, sizeof(JanetArray)); JanetArray *array = janet_gcalloc(JANET_MEMORY_ARRAY, sizeof(JanetArray));
array->capacity = n; array->capacity = n;
array->count = n; array->count = n;
array->data = malloc(sizeof(Janet) * (size_t) n); array->data = janet_malloc(sizeof(Janet) * (size_t) n);
if (!array->data) { if (!array->data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -68,7 +68,7 @@ void janet_array_ensure(JanetArray *array, int32_t capacity, int32_t growth) {
int64_t new_capacity = ((int64_t) capacity) * growth; int64_t new_capacity = ((int64_t) capacity) * growth;
if (new_capacity > INT32_MAX) new_capacity = INT32_MAX; if (new_capacity > INT32_MAX) new_capacity = INT32_MAX;
capacity = (int32_t) new_capacity; capacity = (int32_t) new_capacity;
newData = realloc(old, capacity * sizeof(Janet)); newData = janet_realloc(old, capacity * sizeof(Janet));
if (NULL == newData) { if (NULL == newData) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -275,7 +275,7 @@ static Janet cfun_array_trim(int32_t argc, Janet *argv) {
JanetArray *array = janet_getarray(argv, 0); JanetArray *array = janet_getarray(argv, 0);
if (array->count) { if (array->count) {
if (array->count < array->capacity) { if (array->count < array->capacity) {
Janet *newData = realloc(array->data, array->count * sizeof(Janet)); Janet *newData = janet_realloc(array->data, array->count * sizeof(Janet));
if (NULL == newData) { if (NULL == newData) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -284,7 +284,7 @@ static Janet cfun_array_trim(int32_t argc, Janet *argv) {
} }
} else { } else {
array->capacity = 0; array->capacity = 0;
free(array->data); janet_free(array->data);
array->data = NULL; array->data = NULL;
} }
return argv[0]; return argv[0];

View File

@ -224,7 +224,7 @@ static int32_t janet_asm_addenv(JanetAssembler *a, Janet envname) {
janet_table_put(&a->envs, envname, janet_wrap_number(envindex)); janet_table_put(&a->envs, envname, janet_wrap_number(envindex));
if (envindex >= a->environments_capacity) { if (envindex >= a->environments_capacity) {
int32_t newcap = 2 * envindex; int32_t newcap = 2 * envindex;
def->environments = realloc(def->environments, newcap * sizeof(int32_t)); def->environments = janet_realloc(def->environments, newcap * sizeof(int32_t));
if (NULL == def->environments) { if (NULL == def->environments) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -582,7 +582,7 @@ static JanetAssembleResult janet_asm1(JanetAssembler *parent, Janet source, int
x = janet_get1(s, janet_ckeywordv("constants")); x = janet_get1(s, janet_ckeywordv("constants"));
if (janet_indexed_view(x, &arr, &count)) { if (janet_indexed_view(x, &arr, &count)) {
def->constants_length = count; def->constants_length = count;
def->constants = malloc(sizeof(Janet) * (size_t) count); def->constants = janet_malloc(sizeof(Janet) * (size_t) count);
if (NULL == def->constants) { if (NULL == def->constants) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -614,7 +614,7 @@ static JanetAssembleResult janet_asm1(JanetAssembler *parent, Janet source, int
newlen = def->defs_length + 1; newlen = def->defs_length + 1;
if (a.defs_capacity < newlen) { if (a.defs_capacity < newlen) {
int32_t newcap = newlen; int32_t newcap = newlen;
def->defs = realloc(def->defs, newcap * sizeof(JanetFuncDef *)); def->defs = janet_realloc(def->defs, newcap * sizeof(JanetFuncDef *));
if (NULL == def->defs) { if (NULL == def->defs) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -643,7 +643,7 @@ static JanetAssembleResult janet_asm1(JanetAssembler *parent, Janet source, int
} }
/* Allocate bytecode array */ /* Allocate bytecode array */
def->bytecode_length = blength; def->bytecode_length = blength;
def->bytecode = malloc(sizeof(uint32_t) * (size_t) blength); def->bytecode = janet_malloc(sizeof(uint32_t) * (size_t) blength);
if (NULL == def->bytecode) { if (NULL == def->bytecode) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -685,7 +685,7 @@ static JanetAssembleResult janet_asm1(JanetAssembler *parent, Janet source, int
x = janet_get1(s, janet_ckeywordv("sourcemap")); x = janet_get1(s, janet_ckeywordv("sourcemap"));
if (janet_indexed_view(x, &arr, &count)) { if (janet_indexed_view(x, &arr, &count)) {
janet_asm_assert(&a, count == def->bytecode_length, "sourcemap must have the same length as the bytecode"); janet_asm_assert(&a, count == def->bytecode_length, "sourcemap must have the same length as the bytecode");
def->sourcemap = malloc(sizeof(JanetSourceMapping) * (size_t) count); def->sourcemap = janet_malloc(sizeof(JanetSourceMapping) * (size_t) count);
if (NULL == def->sourcemap) { if (NULL == def->sourcemap) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -711,7 +711,7 @@ static JanetAssembleResult janet_asm1(JanetAssembler *parent, Janet source, int
/* Set environments */ /* Set environments */
def->environments = def->environments =
realloc(def->environments, def->environments_length * sizeof(int32_t)); janet_realloc(def->environments, def->environments_length * sizeof(int32_t));
if (NULL == def->environments) { if (NULL == def->environments) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -33,7 +33,7 @@ JanetBuffer *janet_buffer_init(JanetBuffer *buffer, int32_t capacity) {
uint8_t *data = NULL; uint8_t *data = NULL;
if (capacity < 4) capacity = 4; if (capacity < 4) capacity = 4;
janet_gcpressure(capacity); janet_gcpressure(capacity);
data = malloc(sizeof(uint8_t) * (size_t) capacity); data = janet_malloc(sizeof(uint8_t) * (size_t) capacity);
if (NULL == data) { if (NULL == data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -45,7 +45,7 @@ JanetBuffer *janet_buffer_init(JanetBuffer *buffer, int32_t capacity) {
/* Deinitialize a buffer (free data memory) */ /* Deinitialize a buffer (free data memory) */
void janet_buffer_deinit(JanetBuffer *buffer) { void janet_buffer_deinit(JanetBuffer *buffer) {
free(buffer->data); janet_free(buffer->data);
} }
/* Initialize a buffer */ /* Initialize a buffer */
@ -62,7 +62,7 @@ void janet_buffer_ensure(JanetBuffer *buffer, int32_t capacity, int32_t growth)
int64_t big_capacity = ((int64_t) capacity) * growth; int64_t big_capacity = ((int64_t) capacity) * growth;
capacity = big_capacity > INT32_MAX ? INT32_MAX : (int32_t) big_capacity; capacity = big_capacity > INT32_MAX ? INT32_MAX : (int32_t) big_capacity;
janet_gcpressure(capacity - buffer->capacity); janet_gcpressure(capacity - buffer->capacity);
new_data = realloc(old, (size_t) capacity * sizeof(uint8_t)); new_data = janet_realloc(old, (size_t) capacity * sizeof(uint8_t));
if (NULL == new_data) { if (NULL == new_data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -92,7 +92,7 @@ void janet_buffer_extra(JanetBuffer *buffer, int32_t n) {
int32_t new_size = buffer->count + n; int32_t new_size = buffer->count + n;
if (new_size > buffer->capacity) { if (new_size > buffer->capacity) {
int32_t new_capacity = (new_size > (INT32_MAX / 2)) ? INT32_MAX : (new_size * 2); int32_t new_capacity = (new_size > (INT32_MAX / 2)) ? INT32_MAX : (new_size * 2);
uint8_t *new_data = realloc(buffer->data, new_capacity * sizeof(uint8_t)); uint8_t *new_data = janet_realloc(buffer->data, new_capacity * sizeof(uint8_t));
janet_gcpressure(new_capacity - buffer->capacity); janet_gcpressure(new_capacity - buffer->capacity);
if (NULL == new_data) { if (NULL == new_data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
@ -201,7 +201,7 @@ static Janet cfun_buffer_trim(int32_t argc, Janet *argv) {
JanetBuffer *buffer = janet_getbuffer(argv, 0); JanetBuffer *buffer = janet_getbuffer(argv, 0);
if (buffer->count < buffer->capacity) { if (buffer->count < buffer->capacity) {
int32_t newcap = buffer->count > 4 ? buffer->count : 4; int32_t newcap = buffer->count > 4 ? buffer->count : 4;
uint8_t *newData = realloc(buffer->data, newcap); uint8_t *newData = janet_realloc(buffer->data, newcap);
if (NULL == newData) { if (NULL == newData) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -775,7 +775,7 @@ JanetFuncDef *janetc_pop_funcdef(JanetCompiler *c) {
def->bytecode_length = janet_v_count(c->buffer) - scope->bytecode_start; def->bytecode_length = janet_v_count(c->buffer) - scope->bytecode_start;
if (def->bytecode_length) { if (def->bytecode_length) {
size_t s = sizeof(int32_t) * (size_t) def->bytecode_length; size_t s = sizeof(int32_t) * (size_t) def->bytecode_length;
def->bytecode = malloc(s); def->bytecode = janet_malloc(s);
if (NULL == def->bytecode) { if (NULL == def->bytecode) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -783,7 +783,7 @@ JanetFuncDef *janetc_pop_funcdef(JanetCompiler *c) {
janet_v__cnt(c->buffer) = scope->bytecode_start; janet_v__cnt(c->buffer) = scope->bytecode_start;
if (NULL != c->mapbuffer && c->source) { if (NULL != c->mapbuffer && c->source) {
size_t s = sizeof(JanetSourceMapping) * (size_t) def->bytecode_length; size_t s = sizeof(JanetSourceMapping) * (size_t) def->bytecode_length;
def->sourcemap = malloc(s); def->sourcemap = janet_malloc(s);
if (NULL == def->sourcemap) { if (NULL == def->sourcemap) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -808,7 +808,7 @@ JanetFuncDef *janetc_pop_funcdef(JanetCompiler *c) {
int32_t slotchunks = (def->slotcount + 31) >> 5; int32_t slotchunks = (def->slotcount + 31) >> 5;
/* numchunks is min of slotchunks and scope->ua.count */ /* numchunks is min of slotchunks and scope->ua.count */
int32_t numchunks = slotchunks > scope->ua.count ? scope->ua.count : slotchunks; int32_t numchunks = slotchunks > scope->ua.count ? scope->ua.count : slotchunks;
uint32_t *chunks = calloc(sizeof(uint32_t), slotchunks); uint32_t *chunks = janet_calloc(sizeof(uint32_t), slotchunks);
if (NULL == chunks) { if (NULL == chunks) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -70,7 +70,7 @@ static char *get_processed_name(const char *name) {
if (*c == '/') return (char *) name; if (*c == '/') return (char *) name;
} }
size_t l = (size_t)(c - name); size_t l = (size_t)(c - name);
char *ret = malloc(l + 3); char *ret = janet_malloc(l + 3);
if (NULL == ret) { if (NULL == ret) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -85,7 +85,7 @@ JanetModule janet_native(const char *name, const uint8_t **error) {
Clib lib = load_clib(processed_name); Clib lib = load_clib(processed_name);
JanetModule init; JanetModule init;
JanetModconf getter; JanetModconf getter;
if (name != processed_name) free(processed_name); if (name != processed_name) janet_free(processed_name);
if (!lib) { if (!lib) {
*error = janet_cstring(error_clib()); *error = janet_cstring(error_clib());
return NULL; return NULL;
@ -754,7 +754,7 @@ static void janet_quick_asm(
def->max_arity = max_arity; def->max_arity = max_arity;
def->flags = flags; def->flags = flags;
def->slotcount = slots; def->slotcount = slots;
def->bytecode = malloc(bytecode_size); def->bytecode = janet_malloc(bytecode_size);
def->bytecode_length = (int32_t)(bytecode_size / sizeof(uint32_t)); def->bytecode_length = (int32_t)(bytecode_size / sizeof(uint32_t));
def->name = janet_cstring(name); def->name = janet_cstring(name);
if (!def->bytecode) { if (!def->bytecode) {

View File

@ -90,7 +90,7 @@ static void janet_q_init(JanetQueue *q) {
} }
static void janet_q_deinit(JanetQueue *q) { static void janet_q_deinit(JanetQueue *q) {
free(q->data); janet_free(q->data);
} }
static int32_t janet_q_count(JanetQueue *q) { static int32_t janet_q_count(JanetQueue *q) {
@ -106,7 +106,7 @@ static int janet_q_push(JanetQueue *q, void *item, size_t itemsize) {
if (count + 1 >= JANET_MAX_Q_CAPACITY) return 1; if (count + 1 >= JANET_MAX_Q_CAPACITY) return 1;
int32_t newcap = (count + 2) * 2; int32_t newcap = (count + 2) * 2;
if (newcap > JANET_MAX_Q_CAPACITY) newcap = JANET_MAX_Q_CAPACITY; if (newcap > JANET_MAX_Q_CAPACITY) newcap = JANET_MAX_Q_CAPACITY;
q->data = realloc(q->data, itemsize * newcap); q->data = janet_realloc(q->data, itemsize * newcap);
if (NULL == q->data) { if (NULL == q->data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -213,7 +213,7 @@ static void add_timeout(JanetTimeout to) {
size_t newcount = oldcount + 1; size_t newcount = oldcount + 1;
if (newcount > janet_vm_tq_capacity) { if (newcount > janet_vm_tq_capacity) {
size_t newcap = 2 * newcount; size_t newcap = 2 * newcount;
JanetTimeout *tq = realloc(janet_vm_tq, newcap * sizeof(JanetTimeout)); JanetTimeout *tq = janet_realloc(janet_vm_tq, newcap * sizeof(JanetTimeout));
if (NULL == tq) { if (NULL == tq) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -247,7 +247,7 @@ static JanetListenerState *janet_listen_impl(JanetStream *stream, JanetListener
} }
if (size < sizeof(JanetListenerState)) if (size < sizeof(JanetListenerState))
size = sizeof(JanetListenerState); size = sizeof(JanetListenerState);
JanetListenerState *state = malloc(size); JanetListenerState *state = janet_malloc(size);
if (NULL == state) { if (NULL == state) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -264,7 +264,7 @@ static JanetListenerState *janet_listen_impl(JanetStream *stream, JanetListener
int resize = janet_vm_listener_cap == janet_vm_listener_count; int resize = janet_vm_listener_cap == janet_vm_listener_count;
if (resize) { if (resize) {
size_t newcap = janet_vm_listener_count ? janet_vm_listener_cap * 2 : 16; size_t newcap = janet_vm_listener_count ? janet_vm_listener_cap * 2 : 16;
janet_vm_listeners = realloc(janet_vm_listeners, newcap * sizeof(JanetListenerState *)); janet_vm_listeners = janet_realloc(janet_vm_listeners, newcap * sizeof(JanetListenerState *));
if (NULL == janet_vm_listeners) { if (NULL == janet_vm_listeners) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -301,7 +301,7 @@ static void janet_unlisten_impl(JanetListenerState *state) {
size_t index = state->_index; size_t index = state->_index;
janet_vm_listeners[index] = janet_vm_listeners[--janet_vm_listener_count]; janet_vm_listeners[index] = janet_vm_listeners[--janet_vm_listener_count];
janet_vm_listeners[index]->_index = index; janet_vm_listeners[index]->_index = index;
free(state); janet_free(state);
} }
static const JanetMethod ev_default_stream_methods[] = { static const JanetMethod ev_default_stream_methods[] = {
@ -557,8 +557,8 @@ void janet_ev_init_common(void) {
/* Common deinit code */ /* Common deinit code */
void janet_ev_deinit_common(void) { void janet_ev_deinit_common(void) {
janet_q_deinit(&janet_vm_spawn); janet_q_deinit(&janet_vm_spawn);
free(janet_vm_tq); janet_free(janet_vm_tq);
free(janet_vm_listeners); janet_free(janet_vm_listeners);
janet_vm_listeners = NULL; janet_vm_listeners = NULL;
} }
@ -1042,7 +1042,7 @@ void janet_loop1_impl(int has_timeout, JanetTimestamp to) {
/* Custom event */ /* Custom event */
JanetSelfPipeEvent *response = (JanetSelfPipeEvent *)(overlapped); JanetSelfPipeEvent *response = (JanetSelfPipeEvent *)(overlapped);
response->cb(response->msg); response->cb(response->msg);
free(response); janet_free(response);
janet_ev_dec_refcount(); janet_ev_dec_refcount();
} else { } else {
/* Normal event */ /* Normal event */
@ -1249,7 +1249,7 @@ JanetListenerState *janet_listen(JanetStream *stream, JanetListener behavior, in
JanetListenerState *state = janet_listen_impl(stream, behavior, mask, size, user); JanetListenerState *state = janet_listen_impl(stream, behavior, mask, size, user);
size_t newsize = janet_vm_listener_cap; size_t newsize = janet_vm_listener_cap;
if (newsize > oldsize) { if (newsize > oldsize) {
janet_vm_fds = realloc(janet_vm_fds, (newsize + 1) * sizeof(struct pollfd)); janet_vm_fds = janet_realloc(janet_vm_fds, (newsize + 1) * sizeof(struct pollfd));
if (NULL == janet_vm_fds) { if (NULL == janet_vm_fds) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -1320,7 +1320,7 @@ void janet_ev_init(void) {
janet_ev_init_common(); janet_ev_init_common();
janet_vm_fds = NULL; janet_vm_fds = NULL;
janet_ev_setup_selfpipe(); janet_ev_setup_selfpipe();
janet_vm_fds = malloc(sizeof(struct pollfd)); janet_vm_fds = janet_malloc(sizeof(struct pollfd));
if (NULL == janet_vm_fds) { if (NULL == janet_vm_fds) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -1333,7 +1333,7 @@ void janet_ev_init(void) {
void janet_ev_deinit(void) { void janet_ev_deinit(void) {
janet_ev_deinit_common(); janet_ev_deinit_common();
janet_ev_cleanup_selfpipe(); janet_ev_cleanup_selfpipe();
free(janet_vm_fds); janet_free(janet_vm_fds);
janet_vm_fds = NULL; janet_vm_fds = NULL;
} }
@ -1371,7 +1371,7 @@ static void *janet_thread_body(void *ptr) {
JanetThreadedSubroutine subr = init->subr; JanetThreadedSubroutine subr = init->subr;
JanetThreadedCallback cb = init->cb; JanetThreadedCallback cb = init->cb;
int fd = init->write_pipe; int fd = init->write_pipe;
free(init); janet_free(init);
JanetSelfPipeEvent response; JanetSelfPipeEvent response;
response.msg = subr(msg); response.msg = subr(msg);
response.cb = cb; response.cb = cb;
@ -1391,7 +1391,7 @@ static void *janet_thread_body(void *ptr) {
#endif #endif
void janet_ev_threaded_call(JanetThreadedSubroutine fp, JanetEVGenericMessage arguments, JanetThreadedCallback cb) { void janet_ev_threaded_call(JanetThreadedSubroutine fp, JanetEVGenericMessage arguments, JanetThreadedCallback cb) {
JanetEVThreadInit *init = malloc(sizeof(JanetEVThreadInit)); JanetEVThreadInit *init = janet_malloc(sizeof(JanetEVThreadInit));
if (NULL == init) { if (NULL == init) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -1403,7 +1403,7 @@ void janet_ev_threaded_call(JanetThreadedSubroutine fp, JanetEVGenericMessage ar
init->write_pipe = janet_vm_iocp; init->write_pipe = janet_vm_iocp;
HANDLE thread_handle = CreateThread(NULL, 0, janet_thread_body, init, 0, NULL); HANDLE thread_handle = CreateThread(NULL, 0, janet_thread_body, init, 0, NULL);
if (NULL == thread_handle) { if (NULL == thread_handle) {
free(init); janet_free(init);
janet_panic("failed to create thread"); janet_panic("failed to create thread");
} }
CloseHandle(thread_handle); /* detach from thread */ CloseHandle(thread_handle); /* detach from thread */
@ -1412,7 +1412,7 @@ void janet_ev_threaded_call(JanetThreadedSubroutine fp, JanetEVGenericMessage ar
pthread_t waiter_thread; pthread_t waiter_thread;
int err = pthread_create(&waiter_thread, NULL, janet_thread_body, init); int err = pthread_create(&waiter_thread, NULL, janet_thread_body, init);
if (err) { if (err) {
free(init); janet_free(init);
janet_panicf("%s", strerror(err)); janet_panicf("%s", strerror(err));
} }
pthread_detach(waiter_thread); pthread_detach(waiter_thread);
@ -1435,7 +1435,7 @@ void janet_ev_default_threaded_callback(JanetEVGenericMessage return_value) {
case JANET_EV_TCTAG_STRING: case JANET_EV_TCTAG_STRING:
case JANET_EV_TCTAG_STRINGF: case JANET_EV_TCTAG_STRINGF:
janet_schedule(return_value.fiber, janet_cstringv((const char *) return_value.argp)); janet_schedule(return_value.fiber, janet_cstringv((const char *) return_value.argp));
if (return_value.tag == JANET_EV_TCTAG_STRINGF) free(return_value.argp); if (return_value.tag == JANET_EV_TCTAG_STRINGF) janet_free(return_value.argp);
break; break;
case JANET_EV_TCTAG_KEYWORD: case JANET_EV_TCTAG_KEYWORD:
janet_schedule(return_value.fiber, janet_ckeywordv((const char *) return_value.argp)); janet_schedule(return_value.fiber, janet_ckeywordv((const char *) return_value.argp));
@ -1443,7 +1443,7 @@ void janet_ev_default_threaded_callback(JanetEVGenericMessage return_value) {
case JANET_EV_TCTAG_ERR_STRING: case JANET_EV_TCTAG_ERR_STRING:
case JANET_EV_TCTAG_ERR_STRINGF: case JANET_EV_TCTAG_ERR_STRINGF:
janet_cancel(return_value.fiber, janet_cstringv((const char *) return_value.argp)); janet_cancel(return_value.fiber, janet_cstringv((const char *) return_value.argp));
if (return_value.tag == JANET_EV_TCTAG_STRINGF) free(return_value.argp); if (return_value.tag == JANET_EV_TCTAG_STRINGF) janet_free(return_value.argp);
break; break;
case JANET_EV_TCTAG_ERR_KEYWORD: case JANET_EV_TCTAG_ERR_KEYWORD:
janet_cancel(return_value.fiber, janet_ckeywordv((const char *) return_value.argp)); janet_cancel(return_value.fiber, janet_ckeywordv((const char *) return_value.argp));
@ -2092,7 +2092,7 @@ static Janet cfun_ev_thread(int32_t argc, Janet *argv) {
janet_getfiber(argv, 0); janet_getfiber(argv, 0);
Janet value = argc == 2 ? argv[1] : janet_wrap_nil(); Janet value = argc == 2 ? argv[1] : janet_wrap_nil();
/* Marshal arguments for the new thread. */ /* Marshal arguments for the new thread. */
JanetBuffer *buffer = malloc(sizeof(JanetBuffer)); JanetBuffer *buffer = janet_malloc(sizeof(JanetBuffer));
if (NULL == buffer) { if (NULL == buffer) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -53,7 +53,7 @@ static JanetFiber *fiber_alloc(int32_t capacity) {
capacity = 32; capacity = 32;
} }
fiber->capacity = capacity; fiber->capacity = capacity;
data = malloc(sizeof(Janet) * (size_t) capacity); data = janet_malloc(sizeof(Janet) * (size_t) capacity);
if (NULL == data) { if (NULL == data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -100,12 +100,12 @@ JanetFiber *janet_fiber(JanetFunction *callee, int32_t capacity, int32_t argc, c
static void janet_fiber_refresh_memory(JanetFiber *fiber) { static void janet_fiber_refresh_memory(JanetFiber *fiber) {
int32_t n = fiber->capacity; int32_t n = fiber->capacity;
if (n) { if (n) {
Janet *newData = malloc(sizeof(Janet) * n); Janet *newData = janet_malloc(sizeof(Janet) * n);
if (NULL == newData) { if (NULL == newData) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
memcpy(newData, fiber->data, fiber->capacity * sizeof(Janet)); memcpy(newData, fiber->data, fiber->capacity * sizeof(Janet));
free(fiber->data); janet_free(fiber->data);
fiber->data = newData; fiber->data = newData;
} }
} }
@ -115,7 +115,7 @@ static void janet_fiber_refresh_memory(JanetFiber *fiber) {
void janet_fiber_setcapacity(JanetFiber *fiber, int32_t n) { void janet_fiber_setcapacity(JanetFiber *fiber, int32_t n) {
int32_t old_size = fiber->capacity; int32_t old_size = fiber->capacity;
int32_t diff = n - old_size; int32_t diff = n - old_size;
Janet *newData = realloc(fiber->data, sizeof(Janet) * n); Janet *newData = janet_realloc(fiber->data, sizeof(Janet) * n);
if (NULL == newData) { if (NULL == newData) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -254,7 +254,7 @@ static void janet_env_detach(JanetFuncEnv *env) {
janet_env_valid(env); janet_env_valid(env);
int32_t len = env->length; int32_t len = env->length;
size_t s = sizeof(Janet) * (size_t) len; size_t s = sizeof(Janet) * (size_t) len;
Janet *vmem = malloc(s); Janet *vmem = janet_malloc(s);
janet_vm_next_collection += (uint32_t) s; janet_vm_next_collection += (uint32_t) s;
if (NULL == vmem) { if (NULL == vmem) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;

View File

@ -290,13 +290,13 @@ static void janet_deinit_block(JanetGCObject *mem) {
janet_symbol_deinit(((JanetStringHead *) mem)->data); janet_symbol_deinit(((JanetStringHead *) mem)->data);
break; break;
case JANET_MEMORY_ARRAY: case JANET_MEMORY_ARRAY:
free(((JanetArray *) mem)->data); janet_free(((JanetArray *) mem)->data);
break; break;
case JANET_MEMORY_TABLE: case JANET_MEMORY_TABLE:
free(((JanetTable *) mem)->data); janet_free(((JanetTable *) mem)->data);
break; break;
case JANET_MEMORY_FIBER: case JANET_MEMORY_FIBER:
free(((JanetFiber *)mem)->data); janet_free(((JanetFiber *)mem)->data);
break; break;
case JANET_MEMORY_BUFFER: case JANET_MEMORY_BUFFER:
janet_buffer_deinit((JanetBuffer *) mem); janet_buffer_deinit((JanetBuffer *) mem);
@ -311,18 +311,18 @@ static void janet_deinit_block(JanetGCObject *mem) {
case JANET_MEMORY_FUNCENV: { case JANET_MEMORY_FUNCENV: {
JanetFuncEnv *env = (JanetFuncEnv *)mem; JanetFuncEnv *env = (JanetFuncEnv *)mem;
if (0 == env->offset) if (0 == env->offset)
free(env->as.values); janet_free(env->as.values);
} }
break; break;
case JANET_MEMORY_FUNCDEF: { case JANET_MEMORY_FUNCDEF: {
JanetFuncDef *def = (JanetFuncDef *)mem; JanetFuncDef *def = (JanetFuncDef *)mem;
/* TODO - get this all with one alloc and one free */ /* TODO - get this all with one alloc and one free */
free(def->defs); janet_free(def->defs);
free(def->environments); janet_free(def->environments);
free(def->constants); janet_free(def->constants);
free(def->bytecode); janet_free(def->bytecode);
free(def->sourcemap); janet_free(def->sourcemap);
free(def->closure_bitset); janet_free(def->closure_bitset);
} }
break; break;
} }
@ -347,7 +347,7 @@ void janet_sweep() {
} else { } else {
janet_vm_blocks = next; janet_vm_blocks = next;
} }
free(current); janet_free(current);
} }
current = next; current = next;
} }
@ -359,7 +359,7 @@ void *janet_gcalloc(enum JanetMemoryType type, size_t size) {
/* Make sure everything is inited */ /* Make sure everything is inited */
janet_assert(NULL != janet_vm_cache, "please initialize janet before use"); janet_assert(NULL != janet_vm_cache, "please initialize janet before use");
mem = malloc(size); mem = janet_malloc(size);
/* Check for bad malloc */ /* Check for bad malloc */
if (NULL == mem) { if (NULL == mem) {
@ -382,7 +382,7 @@ static void free_one_scratch(JanetScratch *s) {
if (NULL != s->finalize) { if (NULL != s->finalize) {
s->finalize((char *) s->mem); s->finalize((char *) s->mem);
} }
free(s); janet_free(s);
} }
/* Free all allocated scratch memory */ /* Free all allocated scratch memory */
@ -434,7 +434,7 @@ void janet_gcroot(Janet root) {
size_t newcount = janet_vm_root_count + 1; size_t newcount = janet_vm_root_count + 1;
if (newcount > janet_vm_root_capacity) { if (newcount > janet_vm_root_capacity) {
size_t newcap = 2 * newcount; size_t newcap = 2 * newcount;
janet_vm_roots = realloc(janet_vm_roots, sizeof(Janet) * newcap); janet_vm_roots = janet_realloc(janet_vm_roots, sizeof(Janet) * newcap);
if (NULL == janet_vm_roots) { if (NULL == janet_vm_roots) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -494,12 +494,12 @@ void janet_clear_memory(void) {
while (NULL != current) { while (NULL != current) {
janet_deinit_block(current); janet_deinit_block(current);
JanetGCObject *next = current->next; JanetGCObject *next = current->next;
free(current); janet_free(current);
current = next; current = next;
} }
janet_vm_blocks = NULL; janet_vm_blocks = NULL;
janet_free_all_scratch(); janet_free_all_scratch();
free(janet_scratch_mem); janet_free(janet_scratch_mem);
} }
/* Primitives for suspending GC. */ /* Primitives for suspending GC. */
@ -513,14 +513,14 @@ void janet_gcunlock(int handle) {
/* Scratch memory API */ /* Scratch memory API */
void *janet_smalloc(size_t size) { void *janet_smalloc(size_t size) {
JanetScratch *s = malloc(sizeof(JanetScratch) + size); JanetScratch *s = janet_malloc(sizeof(JanetScratch) + size);
if (NULL == s) { if (NULL == s) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
s->finalize = NULL; s->finalize = NULL;
if (janet_scratch_len == janet_scratch_cap) { if (janet_scratch_len == janet_scratch_cap) {
size_t newcap = 2 * janet_scratch_cap + 2; size_t newcap = 2 * janet_scratch_cap + 2;
JanetScratch **newmem = (JanetScratch **) realloc(janet_scratch_mem, newcap * sizeof(JanetScratch)); JanetScratch **newmem = (JanetScratch **) janet_realloc(janet_scratch_mem, newcap * sizeof(JanetScratch));
if (NULL == newmem) { if (NULL == newmem) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -547,7 +547,7 @@ void *janet_srealloc(void *mem, size_t size) {
if (janet_scratch_len) { if (janet_scratch_len) {
for (size_t i = janet_scratch_len - 1; ; i--) { for (size_t i = janet_scratch_len - 1; ; i--) {
if (janet_scratch_mem[i] == s) { if (janet_scratch_mem[i] == s) {
JanetScratch *news = realloc(s, size + sizeof(JanetScratch)); JanetScratch *news = janet_realloc(s, size + sizeof(JanetScratch));
if (NULL == news) { if (NULL == news) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -544,7 +544,7 @@ static Janet cfun_io_printf_impl_x(int32_t argc, Janet *argv, int newline,
/* Clear buffer to make things easier for GC */ /* Clear buffer to make things easier for GC */
buf->count = 0; buf->count = 0;
buf->capacity = 0; buf->capacity = 0;
free(buf->data); janet_free(buf->data);
buf->data = NULL; buf->data = NULL;
return janet_wrap_nil(); return janet_wrap_nil();
} }

View File

@ -738,7 +738,7 @@ static const uint8_t *unmarshal_one_env(
if (length == 0) { if (length == 0) {
janet_panic("invalid funcenv length"); janet_panic("invalid funcenv length");
} }
env->as.values = malloc(sizeof(Janet) * (size_t) length); env->as.values = janet_malloc(sizeof(Janet) * (size_t) length);
if (!env->as.values) { if (!env->as.values) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -834,7 +834,7 @@ static const uint8_t *unmarshal_one_def(
/* Unmarshal constants */ /* Unmarshal constants */
if (constants_length) { if (constants_length) {
def->constants = malloc(sizeof(Janet) * constants_length); def->constants = janet_malloc(sizeof(Janet) * constants_length);
if (!def->constants) { if (!def->constants) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -846,7 +846,7 @@ static const uint8_t *unmarshal_one_def(
def->constants_length = constants_length; def->constants_length = constants_length;
/* Unmarshal bytecode */ /* Unmarshal bytecode */
def->bytecode = malloc(sizeof(uint32_t) * bytecode_length); def->bytecode = janet_malloc(sizeof(uint32_t) * bytecode_length);
if (!def->bytecode) { if (!def->bytecode) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -855,7 +855,7 @@ static const uint8_t *unmarshal_one_def(
/* Unmarshal environments */ /* Unmarshal environments */
if (def->flags & JANET_FUNCDEF_FLAG_HASENVS) { if (def->flags & JANET_FUNCDEF_FLAG_HASENVS) {
def->environments = calloc(1, sizeof(int32_t) * (size_t) environments_length); def->environments = janet_calloc(1, sizeof(int32_t) * (size_t) environments_length);
if (!def->environments) { if (!def->environments) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -869,7 +869,7 @@ static const uint8_t *unmarshal_one_def(
/* Unmarshal sub funcdefs */ /* Unmarshal sub funcdefs */
if (def->flags & JANET_FUNCDEF_FLAG_HASDEFS) { if (def->flags & JANET_FUNCDEF_FLAG_HASDEFS) {
def->defs = calloc(1, sizeof(JanetFuncDef *) * (size_t) defs_length); def->defs = janet_calloc(1, sizeof(JanetFuncDef *) * (size_t) defs_length);
if (!def->defs) { if (!def->defs) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -884,7 +884,7 @@ static const uint8_t *unmarshal_one_def(
/* Unmarshal source maps if needed */ /* Unmarshal source maps if needed */
if (def->flags & JANET_FUNCDEF_FLAG_HASSOURCEMAP) { if (def->flags & JANET_FUNCDEF_FLAG_HASSOURCEMAP) {
int32_t current = 0; int32_t current = 0;
def->sourcemap = malloc(sizeof(JanetSourceMapping) * (size_t) bytecode_length); def->sourcemap = janet_malloc(sizeof(JanetSourceMapping) * (size_t) bytecode_length);
if (!def->sourcemap) { if (!def->sourcemap) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -900,7 +900,7 @@ static const uint8_t *unmarshal_one_def(
/* Unmarshal closure bitset if needed */ /* Unmarshal closure bitset if needed */
if (def->flags & JANET_FUNCDEF_FLAG_HASCLOBITSET) { if (def->flags & JANET_FUNCDEF_FLAG_HASCLOBITSET) {
int32_t n = (def->slotcount + 31) >> 5; int32_t n = (def->slotcount + 31) >> 5;
def->closure_bitset = malloc(sizeof(uint32_t) * (size_t) n); def->closure_bitset = janet_malloc(sizeof(uint32_t) * (size_t) n);
if (NULL == def->closure_bitset) { if (NULL == def->closure_bitset) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -961,7 +961,7 @@ static const uint8_t *unmarshal_one_fiber(
/* Allocate stack memory */ /* Allocate stack memory */
fiber->capacity = fiber_stacktop + 10; fiber->capacity = fiber_stacktop + 10;
fiber->data = malloc(sizeof(Janet) * fiber->capacity); fiber->data = janet_malloc(sizeof(Janet) * fiber->capacity);
if (!fiber->data) { if (!fiber->data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -265,7 +265,7 @@ static struct addrinfo *janet_get_addrinfo(Janet *argv, int32_t offset, int sock
#ifndef JANET_WINDOWS #ifndef JANET_WINDOWS
if (janet_keyeq(argv[offset], "unix")) { if (janet_keyeq(argv[offset], "unix")) {
const char *path = janet_getcstring(argv, offset + 1); const char *path = janet_getcstring(argv, offset + 1);
struct sockaddr_un *saddr = calloc(1, sizeof(struct sockaddr_un)); struct sockaddr_un *saddr = janet_calloc(1, sizeof(struct sockaddr_un));
if (saddr == NULL) { if (saddr == NULL) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -398,7 +398,7 @@ static Janet cfun_net_connect(int32_t argc, Janet *argv) {
#else #else
int status = connect(sock, addr, addrlen); int status = connect(sock, addr, addrlen);
if (is_unix) { if (is_unix) {
free(ai); janet_free(ai);
} else { } else {
freeaddrinfo(ai); freeaddrinfo(ai);
} }
@ -486,20 +486,20 @@ static Janet cfun_net_listen(int32_t argc, Janet *argv) {
if (is_unix) { if (is_unix) {
sfd = socket(AF_UNIX, socktype | JSOCKFLAGS, 0); sfd = socket(AF_UNIX, socktype | JSOCKFLAGS, 0);
if (!JSOCKVALID(sfd)) { if (!JSOCKVALID(sfd)) {
free(ai); janet_free(ai);
janet_panicf("could not create socket: %V", janet_ev_lasterr()); janet_panicf("could not create socket: %V", janet_ev_lasterr());
} }
const char *err = serverify_socket(sfd); const char *err = serverify_socket(sfd);
if (NULL != err || bind(sfd, (struct sockaddr *)ai, sizeof(struct sockaddr_un))) { if (NULL != err || bind(sfd, (struct sockaddr *)ai, sizeof(struct sockaddr_un))) {
JSOCKCLOSE(sfd); JSOCKCLOSE(sfd);
free(ai); janet_free(ai);
if (err) { if (err) {
janet_panic(err); janet_panic(err);
} else { } else {
janet_panicf("could not bind socket: %V", janet_ev_lasterr()); janet_panicf("could not bind socket: %V", janet_ev_lasterr());
} }
} }
free(ai); janet_free(ai);
} else } else
#endif #endif
{ {

View File

@ -1003,7 +1003,7 @@ static Janet os_spawn(int32_t argc, Janet *argv) {
/* Runs in a separate thread */ /* Runs in a separate thread */
static JanetEVGenericMessage os_shell_subr(JanetEVGenericMessage args) { static JanetEVGenericMessage os_shell_subr(JanetEVGenericMessage args) {
int stat = system((const char *) args.argp); int stat = system((const char *) args.argp);
free(args.argp); janet_free(args.argp);
if (args.argi) { if (args.argi) {
args.tag = JANET_EV_TCTAG_INTEGER; args.tag = JANET_EV_TCTAG_INTEGER;
} else { } else {
@ -1766,7 +1766,7 @@ static Janet os_realpath(int32_t argc, Janet *argv) {
#endif #endif
if (NULL == dest) janet_panicf("%s: %s", strerror(errno), src); if (NULL == dest) janet_panicf("%s: %s", strerror(errno), src);
Janet ret = janet_cstringv(dest); Janet ret = janet_cstringv(dest);
free(dest); janet_free(dest);
return ret; return ret;
#endif #endif
} }

View File

@ -123,7 +123,7 @@ static void NAME(JanetParser *p, T x) { \
if (newcount > p->STACKCAP) { \ if (newcount > p->STACKCAP) { \
T *next; \ T *next; \
size_t newcap = 2 * newcount; \ size_t newcap = 2 * newcount; \
next = realloc(p->STACK, sizeof(T) * newcap); \ next = janet_realloc(p->STACK, sizeof(T) * newcap); \
if (NULL == next) { \ if (NULL == next) { \
JANET_OUT_OF_MEMORY; \ JANET_OUT_OF_MEMORY; \
} \ } \
@ -783,9 +783,9 @@ void janet_parser_init(JanetParser *parser) {
} }
void janet_parser_deinit(JanetParser *parser) { void janet_parser_deinit(JanetParser *parser) {
free(parser->args); janet_free(parser->args);
free(parser->buf); janet_free(parser->buf);
free(parser->states); janet_free(parser->states);
} }
void janet_parser_clone(const JanetParser *src, JanetParser *dest) { void janet_parser_clone(const JanetParser *src, JanetParser *dest) {
@ -812,17 +812,17 @@ void janet_parser_clone(const JanetParser *src, JanetParser *dest) {
dest->states = NULL; dest->states = NULL;
dest->buf = NULL; dest->buf = NULL;
if (dest->bufcap) { if (dest->bufcap) {
dest->buf = malloc(dest->bufcap); dest->buf = janet_malloc(dest->bufcap);
if (!dest->buf) goto nomem; if (!dest->buf) goto nomem;
memcpy(dest->buf, src->buf, dest->bufcap); memcpy(dest->buf, src->buf, dest->bufcap);
} }
if (dest->argcap) { if (dest->argcap) {
dest->args = malloc(sizeof(Janet) * dest->argcap); dest->args = janet_malloc(sizeof(Janet) * dest->argcap);
if (!dest->args) goto nomem; if (!dest->args) goto nomem;
memcpy(dest->args, src->args, dest->argcap * sizeof(Janet)); memcpy(dest->args, src->args, dest->argcap * sizeof(Janet));
} }
if (dest->statecap) { if (dest->statecap) {
dest->states = malloc(sizeof(JanetParseState) * dest->statecap); dest->states = janet_malloc(sizeof(JanetParseState) * dest->statecap);
if (!dest->states) goto nomem; if (!dest->states) goto nomem;
memcpy(dest->states, src->states, dest->statecap * sizeof(JanetParseState)); memcpy(dest->states, src->states, dest->statecap * sizeof(JanetParseState));
} }
@ -943,7 +943,7 @@ static Janet cfun_parse_insert(int32_t argc, Janet *argv) {
size_t newcount = p->bufcount + slen; size_t newcount = p->bufcount + slen;
if (p->bufcap < newcount) { if (p->bufcap < newcount) {
size_t newcap = 2 * newcount; size_t newcap = 2 * newcount;
p->buf = realloc(p->buf, newcap); p->buf = janet_realloc(p->buf, newcap);
if (p->buf == NULL) { if (p->buf == NULL) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -1335,7 +1335,7 @@ static void *peg_unmarshal(JanetMarshalContext *ctx) {
* bytecode. */ * bytecode. */
uint32_t blen = (int32_t) peg->bytecode_len; uint32_t blen = (int32_t) peg->bytecode_len;
uint32_t clen = peg->num_constants; uint32_t clen = peg->num_constants;
uint8_t *op_flags = calloc(1, blen); uint8_t *op_flags = janet_calloc(1, blen);
if (NULL == op_flags) { if (NULL == op_flags) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -1466,11 +1466,11 @@ static void *peg_unmarshal(JanetMarshalContext *ctx) {
peg->bytecode = bytecode; peg->bytecode = bytecode;
peg->constants = constants; peg->constants = constants;
peg->has_backref = has_backref; peg->has_backref = has_backref;
free(op_flags); janet_free(op_flags);
return peg; return peg;
bad: bad:
free(op_flags); janet_free(op_flags);
janet_panic("invalid peg bytecode"); janet_panic("invalid peg bytecode");
} }

View File

@ -36,7 +36,7 @@ void janetc_regalloc_init(JanetcRegisterAllocator *ra) {
} }
void janetc_regalloc_deinit(JanetcRegisterAllocator *ra) { void janetc_regalloc_deinit(JanetcRegisterAllocator *ra) {
free(ra->chunks); janet_free(ra->chunks);
} }
/* Fallbacks for when ctz not available */ /* Fallbacks for when ctz not available */
@ -70,7 +70,7 @@ void janetc_regalloc_clone(JanetcRegisterAllocator *dest, JanetcRegisterAllocato
size = sizeof(uint32_t) * (size_t) dest->capacity; size = sizeof(uint32_t) * (size_t) dest->capacity;
dest->regtemps = 0; dest->regtemps = 0;
if (size) { if (size) {
dest->chunks = malloc(size); dest->chunks = janet_malloc(size);
if (!dest->chunks) { if (!dest->chunks) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -87,7 +87,7 @@ static void pushchunk(JanetcRegisterAllocator *ra) {
int32_t newcount = ra->count + 1; int32_t newcount = ra->count + 1;
if (newcount > ra->capacity) { if (newcount > ra->capacity) {
int32_t newcapacity = newcount * 2; int32_t newcapacity = newcount * 2;
ra->chunks = realloc(ra->chunks, (size_t) newcapacity * sizeof(uint32_t)); ra->chunks = janet_realloc(ra->chunks, (size_t) newcapacity * sizeof(uint32_t));
if (!ra->chunks) { if (!ra->chunks) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -108,7 +108,7 @@ static void kmp_init(
if (patlen == 0) { if (patlen == 0) {
janet_panic("expected non-empty pattern"); janet_panic("expected non-empty pattern");
} }
int32_t *lookup = calloc(patlen, sizeof(int32_t)); int32_t *lookup = janet_calloc(patlen, sizeof(int32_t));
if (!lookup) { if (!lookup) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -131,7 +131,7 @@ static void kmp_init(
} }
static void kmp_deinit(struct kmp_state *state) { static void kmp_deinit(struct kmp_state *state) {
free(state->lookup); janet_free(state->lookup);
} }
static void kmp_seti(struct kmp_state *state, int32_t i) { static void kmp_seti(struct kmp_state *state, int32_t i) {

View File

@ -87,7 +87,7 @@ static uint32_t *bignat_extra(struct BigNat *mant, int32_t n) {
int32_t newn = oldn + n; int32_t newn = oldn + n;
if (mant->cap < newn) { if (mant->cap < newn) {
int32_t newcap = 2 * newn; int32_t newcap = 2 * newn;
uint32_t *mem = realloc(mant->digits, (size_t) newcap * sizeof(uint32_t)); uint32_t *mem = janet_realloc(mant->digits, (size_t) newcap * sizeof(uint32_t));
if (NULL == mem) { if (NULL == mem) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -368,11 +368,11 @@ int janet_scan_number(
goto error; goto error;
*out = convert(neg, &mant, base, ex); *out = convert(neg, &mant, base, ex);
free(mant.digits); janet_free(mant.digits);
return 0; return 0;
error: error:
free(mant.digits); janet_free(mant.digits);
return 1; return 1;
} }

View File

@ -45,7 +45,7 @@ JANET_THREAD_LOCAL uint32_t janet_vm_cache_deleted = 0;
/* Initialize the cache (allocate cache memory) */ /* Initialize the cache (allocate cache memory) */
void janet_symcache_init() { void janet_symcache_init() {
janet_vm_cache_capacity = 1024; janet_vm_cache_capacity = 1024;
janet_vm_cache = calloc(1, (size_t) janet_vm_cache_capacity * sizeof(const uint8_t *)); janet_vm_cache = janet_calloc(1, (size_t) janet_vm_cache_capacity * sizeof(const uint8_t *));
if (NULL == janet_vm_cache) { if (NULL == janet_vm_cache) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -55,7 +55,7 @@ void janet_symcache_init() {
/* Deinitialize the cache (free the cache memory) */ /* Deinitialize the cache (free the cache memory) */
void janet_symcache_deinit() { void janet_symcache_deinit() {
free((void *)janet_vm_cache); janet_free((void *)janet_vm_cache);
janet_vm_cache = NULL; janet_vm_cache = NULL;
janet_vm_cache_capacity = 0; janet_vm_cache_capacity = 0;
janet_vm_cache_count = 0; janet_vm_cache_count = 0;
@ -122,7 +122,7 @@ notfound:
static void janet_cache_resize(uint32_t newCapacity) { static void janet_cache_resize(uint32_t newCapacity) {
uint32_t i, oldCapacity; uint32_t i, oldCapacity;
const uint8_t **oldCache = janet_vm_cache; const uint8_t **oldCache = janet_vm_cache;
const uint8_t **newCache = calloc(1, (size_t) newCapacity * sizeof(const uint8_t *)); const uint8_t **newCache = janet_calloc(1, (size_t) newCapacity * sizeof(const uint8_t *));
if (newCache == NULL) { if (newCache == NULL) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -145,7 +145,7 @@ static void janet_cache_resize(uint32_t newCapacity) {
} }
} }
/* Free the old cache */ /* Free the old cache */
free((void *)oldCache); janet_free((void *)oldCache);
} }
/* Add an item to the cache */ /* Add an item to the cache */

View File

@ -117,7 +117,7 @@ static void janet_table_rehash(JanetTable *t, int32_t size) {
if (islocal) { if (islocal) {
janet_sfree(olddata); janet_sfree(olddata);
} else { } else {
free(olddata); janet_free(olddata);
} }
} }
@ -237,7 +237,7 @@ JanetTable *janet_table_clone(JanetTable *table) {
newTable->capacity = table->capacity; newTable->capacity = table->capacity;
newTable->deleted = table->deleted; newTable->deleted = table->deleted;
newTable->proto = table->proto; newTable->proto = table->proto;
newTable->data = malloc(newTable->capacity * sizeof(JanetKV)); newTable->data = janet_malloc(newTable->capacity * sizeof(JanetKV));
if (NULL == newTable->data) { if (NULL == newTable->data) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -93,7 +93,7 @@ static JanetTable *janet_thread_get_decode(void) {
} }
static JanetMailbox *janet_mailbox_create(int refCount, uint16_t capacity) { static JanetMailbox *janet_mailbox_create(int refCount, uint16_t capacity) {
JanetMailbox *mailbox = malloc(sizeof(JanetMailbox) + sizeof(JanetBuffer) * (size_t) capacity); JanetMailbox *mailbox = janet_malloc(sizeof(JanetMailbox) + sizeof(JanetBuffer) * (size_t) capacity);
if (NULL == mailbox) { if (NULL == mailbox) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -126,7 +126,7 @@ static void janet_mailbox_destroy(JanetMailbox *mailbox) {
for (uint16_t i = 0; i < mailbox->messageCapacity; i++) { for (uint16_t i = 0; i < mailbox->messageCapacity; i++) {
janet_buffer_deinit(mailbox->messages + i); janet_buffer_deinit(mailbox->messages + i);
} }
free(mailbox); janet_free(mailbox);
} }
static void janet_mailbox_lock(JanetMailbox *mailbox) { static void janet_mailbox_lock(JanetMailbox *mailbox) {
@ -185,7 +185,7 @@ static int thread_mark(void *p, size_t size) {
} }
static JanetMailboxPair *make_mailbox_pair(JanetMailbox *original, uint64_t flags) { static JanetMailboxPair *make_mailbox_pair(JanetMailbox *original, uint64_t flags) {
JanetMailboxPair *pair = malloc(sizeof(JanetMailboxPair)); JanetMailboxPair *pair = janet_malloc(sizeof(JanetMailboxPair));
if (NULL == pair) { if (NULL == pair) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -199,7 +199,7 @@ static JanetMailboxPair *make_mailbox_pair(JanetMailbox *original, uint64_t flag
static void destroy_mailbox_pair(JanetMailboxPair *pair) { static void destroy_mailbox_pair(JanetMailboxPair *pair) {
janet_mailbox_ref(pair->original, -1); janet_mailbox_ref(pair->original, -1);
janet_mailbox_ref(pair->newbox, -1); janet_mailbox_ref(pair->newbox, -1);
free(pair); janet_free(pair);
} }
/* Abstract waiting for timeout across windows/posix */ /* Abstract waiting for timeout across windows/posix */

View File

@ -397,7 +397,7 @@ static void _janet_cfuns_prefix(JanetTable *env, const char *regprefix, const Ja
if (NULL != regprefix) { if (NULL != regprefix) {
prefixlen = strlen(regprefix); prefixlen = strlen(regprefix);
bufsize = prefixlen + 256; bufsize = prefixlen + 256;
longname_buffer = malloc(bufsize); longname_buffer = janet_malloc(bufsize);
if (NULL == longname_buffer) { if (NULL == longname_buffer) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -413,7 +413,7 @@ static void _janet_cfuns_prefix(JanetTable *env, const char *regprefix, const Ja
int32_t totallen = (int32_t) prefixlen + nmlen; int32_t totallen = (int32_t) prefixlen + nmlen;
if ((size_t) totallen > bufsize) { if ((size_t) totallen > bufsize) {
bufsize = (size_t)(totallen) + 128; bufsize = (size_t)(totallen) + 128;
longname_buffer = realloc(longname_buffer, bufsize); longname_buffer = janet_realloc(longname_buffer, bufsize);
if (NULL == longname_buffer) { if (NULL == longname_buffer) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }
@ -436,7 +436,7 @@ static void _janet_cfuns_prefix(JanetTable *env, const char *regprefix, const Ja
janet_table_put(janet_vm_registry, fun, name); janet_table_put(janet_vm_registry, fun, name);
cfuns++; cfuns++;
} }
free(longname_buffer); janet_free(longname_buffer);
} }
void janet_cfuns_prefix(JanetTable *env, const char *regprefix, const JanetReg *cfuns) { void janet_cfuns_prefix(JanetTable *env, const char *regprefix, const JanetReg *cfuns) {
@ -720,3 +720,21 @@ int janet_cryptorand(uint8_t *out, size_t n) {
return -1; return -1;
#endif #endif
} }
/* Alloc function macro fills */
void *(janet_malloc)(size_t size) {
return janet_malloc(size);
}
void (janet_free)(void *ptr) {
return janet_free(ptr);
}
void *(janet_calloc)(size_t nmemb, size_t size) {
return janet_calloc(nmemb, size);
}
void *(janet_realloc)(void *ptr, size_t size) {
return janet_realloc(ptr, size);
}

View File

@ -47,7 +47,7 @@ static void push_traversal_node(void *lhs, void *rhs, int32_t index2) {
if (newsize < 128) { if (newsize < 128) {
newsize = 128; newsize = 128;
} }
JanetTraversalNode *tn = realloc(janet_vm_traversal_base, newsize * sizeof(JanetTraversalNode)); JanetTraversalNode *tn = janet_realloc(janet_vm_traversal_base, newsize * sizeof(JanetTraversalNode));
if (tn == NULL) { if (tn == NULL) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;
} }

View File

@ -43,7 +43,7 @@ void *janet_v_flattenmem(void *v, int32_t itemsize) {
int32_t *p; int32_t *p;
if (NULL == v) return NULL; if (NULL == v) return NULL;
size_t size = (size_t) itemsize * janet_v__cnt(v); size_t size = (size_t) itemsize * janet_v__cnt(v);
p = malloc(size); p = janet_malloc(size);
if (NULL != p) { if (NULL != p) {
safe_memcpy(p, v, size); safe_memcpy(p, v, size);
return p; return p;

View File

@ -1546,7 +1546,7 @@ int janet_init(void) {
void janet_deinit(void) { void janet_deinit(void) {
janet_clear_memory(); janet_clear_memory();
janet_symcache_deinit(); janet_symcache_deinit();
free(janet_vm_roots); janet_free(janet_vm_roots);
janet_vm_roots = NULL; janet_vm_roots = NULL;
janet_vm_root_count = 0; janet_vm_root_count = 0;
janet_vm_root_capacity = 0; janet_vm_root_capacity = 0;
@ -1554,7 +1554,7 @@ void janet_deinit(void) {
janet_vm_abstract_registry = NULL; janet_vm_abstract_registry = NULL;
janet_vm_core_env = NULL; janet_vm_core_env = NULL;
janet_vm_top_dyns = NULL; janet_vm_top_dyns = NULL;
free(janet_vm_traversal_base); janet_free(janet_vm_traversal_base);
janet_vm_fiber = NULL; janet_vm_fiber = NULL;
janet_vm_root_fiber = NULL; janet_vm_root_fiber = NULL;
#ifdef JANET_THREADS #ifdef JANET_THREADS

View File

@ -162,7 +162,7 @@ Janet(janet_wrap_number)(double x) {
void *janet_memalloc_empty(int32_t count) { void *janet_memalloc_empty(int32_t count) {
int32_t i; int32_t i;
void *mem = malloc((size_t) count * sizeof(JanetKV)); void *mem = janet_malloc((size_t) count * sizeof(JanetKV));
janet_vm_next_collection += (size_t) count * sizeof(JanetKV); janet_vm_next_collection += (size_t) count * sizeof(JanetKV);
if (NULL == mem) { if (NULL == mem) {
JANET_OUT_OF_MEMORY; JANET_OUT_OF_MEMORY;

View File

@ -1892,6 +1892,24 @@ JANET_API JanetThread *janet_thread_current(void);
#endif #endif
/* Custom allocator support */
JANET_API void *(janet_malloc)(size_t);
JANET_API void *(janet_realloc)(void *, size_t);
JANET_API void *(janet_calloc)(size_t, size_t);
JANET_API void (janet_free)(void *);
#ifndef janet_malloc
#define janet_malloc(X) malloc((X))
#endif
#ifndef janet_realloc
#define janet_realloc(X, Y) realloc((X), (Y))
#endif
#ifndef janet_calloc
#define janet_calloc(X, Y) calloc((X), (Y))
#endif
#ifndef janet_free
#define janet_free(X) free((X))
#endif
/***** END SECTION MAIN *****/ /***** END SECTION MAIN *****/
/* Re-enable popped variable length array warnings */ /* Re-enable popped variable length array warnings */

View File

@ -152,7 +152,7 @@ static const char *badterms[] = {
static char *sdup(const char *s) { static char *sdup(const char *s) {
size_t len = strlen(s) + 1; size_t len = strlen(s) + 1;
char *mem = malloc(len); char *mem = janet_malloc(len);
if (!mem) { if (!mem) {
return NULL; return NULL;
} }
@ -300,7 +300,7 @@ static int insert(char c, int draw) {
static void historymove(int delta) { static void historymove(int delta) {
if (gbl_history_count > 1) { if (gbl_history_count > 1) {
free(gbl_history[gbl_historyi]); janet_free(gbl_history[gbl_historyi]);
gbl_history[gbl_historyi] = sdup(gbl_buf); gbl_history[gbl_historyi] = sdup(gbl_buf);
gbl_historyi += delta; gbl_historyi += delta;
@ -326,7 +326,7 @@ static void addhistory(void) {
gbl_history[gbl_history_count++] = newline; gbl_history[gbl_history_count++] = newline;
len++; len++;
} else { } else {
free(gbl_history[JANET_HISTORY_MAX - 1]); janet_free(gbl_history[JANET_HISTORY_MAX - 1]);
} }
for (i = len - 1; i > 0; i--) { for (i = len - 1; i > 0; i--) {
gbl_history[i] = gbl_history[i - 1]; gbl_history[i] = gbl_history[i - 1];
@ -338,7 +338,7 @@ static void replacehistory(void) {
/* History count is always > 0 here */ /* History count is always > 0 here */
if (gbl_len == 0 || (gbl_history_count > 1 && !strcmp(gbl_buf, gbl_history[1]))) { if (gbl_len == 0 || (gbl_history_count > 1 && !strcmp(gbl_buf, gbl_history[1]))) {
/* Delete history */ /* Delete history */
free(gbl_history[0]); janet_free(gbl_history[0]);
for (int i = 1; i < gbl_history_count; i++) { for (int i = 1; i < gbl_history_count; i++) {
gbl_history[i - 1] = gbl_history[i]; gbl_history[i - 1] = gbl_history[i];
} }
@ -346,7 +346,7 @@ static void replacehistory(void) {
} else { } else {
char *newline = sdup(gbl_buf); char *newline = sdup(gbl_buf);
if (!newline) return; if (!newline) return;
free(gbl_history[0]); janet_free(gbl_history[0]);
gbl_history[0] = newline; gbl_history[0] = newline;
} }
} }
@ -934,7 +934,7 @@ void janet_line_deinit() {
int i; int i;
norawmode(); norawmode();
for (i = 0; i < gbl_history_count; i++) for (i = 0; i < gbl_history_count; i++)
free(gbl_history[i]); janet_free(gbl_history[i]);
gbl_historyi = 0; gbl_historyi = 0;
} }