picrin/src/state.c

77 lines
1.8 KiB
C
Raw Normal View History

2013-10-10 03:15:41 -04:00
#include <stdlib.h>
#include "picrin.h"
#include "picrin/gc.h"
2013-10-15 08:53:45 -04:00
#include "picrin/proc.h"
2013-10-10 03:15:41 -04:00
2013-10-11 04:36:51 -04:00
static struct pic_env *
pic_new_empty_env()
{
struct pic_env *env;
env = (struct pic_env *)malloc(sizeof(struct pic_env));
env->assoc = pic_nil_value();
env->parent = NULL;
return env;
}
2013-10-15 08:14:33 -04:00
void pic_init_core(pic_state *);
2013-10-10 03:15:41 -04:00
pic_state *
pic_open()
{
pic_state *pic;
2013-10-11 04:36:51 -04:00
pic = (pic_state *)malloc(sizeof(pic_state));
2013-10-11 11:20:53 -04:00
/* prepare VM stack */
2013-10-15 10:28:23 -04:00
pic->stbase = pic->sp = (pic_value *)malloc(sizeof(pic_value) * PIC_STACK_SIZE);
pic->stend = pic->stbase + PIC_STACK_SIZE;
2013-10-11 11:20:53 -04:00
2013-10-15 10:29:34 -04:00
/* callinfo */
pic->cibase = pic->ci = (pic_callinfo *)malloc(sizeof(pic_callinfo) * PIC_STACK_SIZE);
pic->ciend = pic->ciend + PIC_STACK_SIZE;
/* memory heap */
pic->heap = (struct heap_page *)malloc(sizeof(struct heap_page));
init_heap_page(pic->heap);
/* irep */
pic->irep = (struct pic_irep **)malloc(sizeof(struct pic_irep *) * PIC_IREP_SIZE);
pic->ilen = 0;
pic->icapa = PIC_IREP_SIZE;
/* globals */
2013-10-19 14:05:42 -04:00
pic->globals = (pic_value *)malloc(sizeof(pic_value) * PIC_GLOBALS_SIZE);
pic->glen = 0;
pic->gcapa = PIC_GLOBALS_SIZE;
2013-10-13 04:02:29 -04:00
/* GC arena */
pic->arena_idx = 0;
pic->sDEFINE = pic_intern_cstr(pic, "define");
2013-10-15 22:32:30 -04:00
pic->sLAMBDA = pic_intern_cstr(pic, "lambda");
2013-10-16 04:42:47 -04:00
pic->sIF = pic_intern_cstr(pic, "if");
2013-10-17 04:54:28 -04:00
pic->sBEGIN = pic_intern_cstr(pic, "begin");
pic->sCONS = pic_intern_cstr(pic, "cons");
2013-10-19 14:48:06 -04:00
pic->sCAR = pic_intern_cstr(pic, "car");
pic->sCDR = pic_intern_cstr(pic, "cdr");
2013-10-15 08:29:07 -04:00
pic->sADD = pic_intern_cstr(pic, "+");
pic->sSUB = pic_intern_cstr(pic, "-");
pic->sMUL = pic_intern_cstr(pic, "*");
pic->sDIV = pic_intern_cstr(pic, "/");
2013-10-10 03:15:41 -04:00
2013-10-15 08:14:33 -04:00
/* global environment */
pic->global_env = pic_new_empty_env();
pic_init_core(pic);
2013-10-10 03:15:41 -04:00
return pic;
}
void
pic_close(pic_state *pic)
{
free(pic);
}