diff options
author | Aryadev Chavali <aryadev@aryadevchavali.com> | 2025-09-01 21:45:18 +0100 |
---|---|---|
committer | Aryadev Chavali <aryadev@aryadevchavali.com> | 2025-09-01 21:45:18 +0100 |
commit | 1aa01d2a893350d979f1c763f0216ba2dcf501bc (patch) | |
tree | ce3a8799c08f36d36c64f52d5ea75bfee259ab7a /impl/sys.c | |
parent | a9b08d3a1158042d36ee07a2513d5c8b654b8f85 (diff) | |
parent | 700c3b1d1b3ed835ffab3fd502ab91baba8e2d1f (diff) | |
download | alisp-1aa01d2a893350d979f1c763f0216ba2dcf501bc.tar.gz alisp-1aa01d2a893350d979f1c763f0216ba2dcf501bc.tar.bz2 alisp-1aa01d2a893350d979f1c763f0216ba2dcf501bc.zip |
Merge remote-tracking branch 'origin/master'
Diffstat (limited to 'impl/sys.c')
-rw-r--r-- | impl/sys.c | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/impl/sys.c b/impl/sys.c new file mode 100644 index 0000000..4dcd664 --- /dev/null +++ b/impl/sys.c @@ -0,0 +1,77 @@ +/* Copyright (C) 2025 Aryadev Chavali + + * This program is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + * FOR A PARTICULAR PURPOSE. See the Unlicense for details. + + * You may distribute and modify this code under the terms of the Unlicense, + * which you should have received a copy of along with this program. If not, + * please go to <https://unlicense.org/>. + + * Created: 2025-08-20 + * Description: System management + */ + +#include <alisp.h> + +#include <assert.h> +#include <malloc.h> +#include <string.h> + +void sys_init(sys_t *sys) +{ + memset(sys, 0, sizeof(*sys)); +} + +void sys_register(sys_t *sys, lisp_t *ptr) +{ + // Generate an unmanaged cons + cons_t *cons = calloc(1, sizeof(*cons)); + cons->car = ptr; + cons->cdr = sys->memory; + sys->memory = tag_cons(cons); +} + +void sys_cleanup(sys_t *sys) +{ + static_assert(NUM_TAGS == 5); + + sym_table_cleanup(&sys->symtable); + + if (!sys->memory) + return; + + // Iterate through each element of memory + for (lisp_t *cell = sys->memory, *next = cdr(cell); cell; + cell = next, next = cdr(next)) + { + // Only reason allocated exists is because we had to allocate memory on the + // heap for it. It's therefore enough to deal with only the allocated + // types. + lisp_t *allocated = car(cell); + switch (get_tag(allocated)) + { + case TAG_CONS: + // Delete the cons + free(as_cons(allocated)); + break; + case TAG_VEC: + { + vec_t *vec = as_vec(allocated); + vec_free(vec); + free(vec); + break; + } + case TAG_NIL: + case TAG_INT: + case TAG_SYM: + case NUM_TAGS: + // shouldn't be dealt with (either constant or dealt with elsewhere) + break; + } + + // Then free the current cell + free(as_cons(cell)); + } + memset(sys, 0, sizeof(*sys)); +} |