aboutsummaryrefslogtreecommitdiff
path: root/sys.c
diff options
context:
space:
mode:
authorAryadev Chavali <aryadev@aryadevchavali.com>2025-09-01 21:26:01 +0100
committerAryadev Chavali <aryadev@aryadevchavali.com>2025-09-01 21:26:01 +0100
commit700c3b1d1b3ed835ffab3fd502ab91baba8e2d1f (patch)
tree69029747231d8fa60d3cb05f965e796d2211f021 /sys.c
parentcc56a2ee2b5703f9ea5ac63a86870af188845c30 (diff)
downloadalisp-700c3b1d1b3ed835ffab3fd502ab91baba8e2d1f.tar.gz
alisp-700c3b1d1b3ed835ffab3fd502ab91baba8e2d1f.tar.bz2
alisp-700c3b1d1b3ed835ffab3fd502ab91baba8e2d1f.zip
Move implementation files into their own folder
main.c and test.c generate binary executables so they can stay in the main folder, but the rest can go into their own dedicated folder to make it look nicer
Diffstat (limited to 'sys.c')
-rw-r--r--sys.c77
1 files changed, 0 insertions, 77 deletions
diff --git a/sys.c b/sys.c
deleted file mode 100644
index d01b493..0000000
--- a/sys.c
+++ /dev/null
@@ -1,77 +0,0 @@
-/* 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));
-}