From 0f68afd9a040256939ddd082a380bd37b0a3996b Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Thu, 21 Aug 2025 14:54:57 +0100 Subject: Make nicer primitive functions for car/cdr If it isn't a CONS, we return NIL instead of failing. This way, we can use it in our general iteration functions. Eventually the actual runtime would use this as well. The macros are mostly for internal use to do assignment etc. --- sys.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) (limited to 'sys.c') diff --git a/sys.c b/sys.c index d3a9bb2..ac26a88 100644 --- a/sys.c +++ b/sys.c @@ -43,12 +43,13 @@ void sys_cleanup(sys_t *sys) return; // Iterate through each element of memory - for (lisp_t *cell = sys->memory, *next = CDR(cell); cell; - cell = next, next = CDR(cell)) + 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 - lisp_t *allocated = CAR(cell); + // 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: -- cgit v1.2.3-13-gbd6f