mirror of
https://github.com/samsonjs/lake.git
synced 2026-03-25 08:55:49 +00:00
74 lines
1.5 KiB
C
74 lines
1.5 KiB
C
/**
|
|
* dlist.c
|
|
* Lake Scheme
|
|
*
|
|
* Copyright 2011 Sami Samhuri
|
|
* MIT License
|
|
*
|
|
*/
|
|
|
|
#include "dlist.h"
|
|
#include "common.h"
|
|
#include "lake.h"
|
|
|
|
static LakeDottedList *dlist_alloc(void)
|
|
{
|
|
LakeDottedList *dlist = malloc(sizeof(LakeDottedList));
|
|
VAL(dlist)->type = TYPE_DLIST;
|
|
VAL(dlist)->size = sizeof(LakeDottedList);
|
|
return dlist;
|
|
}
|
|
|
|
LakeDottedList *dlist_make(LakeList *head, LakeVal *tail)
|
|
{
|
|
LakeDottedList *dlist = dlist_alloc();
|
|
dlist->head = head;
|
|
dlist->tail = tail;
|
|
return dlist;
|
|
}
|
|
|
|
LakeList *dlist_head(LakeDottedList *dlist)
|
|
{
|
|
return dlist->head;
|
|
}
|
|
|
|
LakeVal *dlist_tail(LakeDottedList *dlist)
|
|
{
|
|
return dlist->tail;
|
|
}
|
|
|
|
char *dlist_repr(LakeDottedList *dlist)
|
|
{
|
|
char *s = malloc(2);
|
|
s[0] = '(';
|
|
s[1] = '\0';
|
|
int i;
|
|
char *s2;
|
|
if (dlist->head && LIST_N(dlist->head)) {
|
|
for (i = 0; i < LIST_N(dlist->head); ++i) {
|
|
s2 = lake_repr(LIST_VAL(dlist->head, i));
|
|
s = lake_str_append(s, s2);
|
|
free(s2);
|
|
if (i != LIST_N(dlist->head) - 1) s = lake_str_append(s, " ");
|
|
}
|
|
}
|
|
else if (dlist->head) {
|
|
s2 = lake_repr(dlist->head);
|
|
s = lake_str_append(s, s2);
|
|
free(s2);
|
|
}
|
|
s = lake_str_append(s, " . ");
|
|
s2 = lake_repr(dlist->tail);
|
|
s = lake_str_append(s, s2);
|
|
free(s2);
|
|
return lake_str_append(s, ")");
|
|
}
|
|
|
|
bool dlist_equal(LakeDottedList *a, LakeDottedList *b)
|
|
{
|
|
LakeVal *headA = VAL(dlist_head(a));
|
|
LakeVal *tailA = dlist_tail(a);
|
|
LakeVal *headB = VAL(dlist_head(b));
|
|
LakeVal *tailB = dlist_tail(b);
|
|
return lake_equal(headA, headB) && lake_equal(tailA, tailB);
|
|
}
|