2013-10-10 03:15:41 -04:00
|
|
|
#ifndef PICRIN_H__
|
|
|
|
#define PICRIN_H__
|
|
|
|
|
2013-10-10 04:54:35 -04:00
|
|
|
#include <stddef.h>
|
2013-10-11 04:36:51 -04:00
|
|
|
#include <stdbool.h>
|
2013-10-20 05:17:12 -04:00
|
|
|
#include <setjmp.h>
|
2013-10-27 05:38:41 -04:00
|
|
|
#include <stdio.h>
|
2013-10-10 04:54:35 -04:00
|
|
|
|
2013-10-14 20:05:44 -04:00
|
|
|
#include "picconf.h"
|
2013-10-10 03:34:24 -04:00
|
|
|
#include "picrin/value.h"
|
|
|
|
|
2013-10-16 02:30:52 -04:00
|
|
|
struct pic_code;
|
|
|
|
|
2013-10-15 10:29:34 -04:00
|
|
|
typedef struct pic_callinfo {
|
|
|
|
int argc;
|
2013-10-16 02:30:52 -04:00
|
|
|
struct pic_code *pc;
|
2013-10-23 02:55:42 -04:00
|
|
|
pic_value *fp;
|
2013-10-28 21:16:56 -04:00
|
|
|
struct pic_env *env;
|
2013-10-15 10:29:34 -04:00
|
|
|
} pic_callinfo;
|
|
|
|
|
2013-10-10 03:15:41 -04:00
|
|
|
typedef struct {
|
2013-10-20 22:51:02 -04:00
|
|
|
int argc;
|
|
|
|
char **argv, **envp;
|
|
|
|
|
2013-10-11 11:16:19 -04:00
|
|
|
pic_value *sp;
|
2013-10-11 11:20:53 -04:00
|
|
|
pic_value *stbase, *stend;
|
|
|
|
|
2013-10-15 10:29:34 -04:00
|
|
|
pic_callinfo *ci;
|
|
|
|
pic_callinfo *cibase, *ciend;
|
|
|
|
|
2013-10-28 13:11:31 -04:00
|
|
|
pic_sym sDEFINE, sLAMBDA, sIF, sBEGIN, sQUOTE, sSETBANG;
|
|
|
|
pic_sym sQUASIQUOTE, sUNQUOTE, sUNQUOTE_SPLICING;
|
2013-10-30 03:37:43 -04:00
|
|
|
pic_sym sDEFINE_SYNTAX, sDEFINE_MACRO;
|
2013-10-28 13:11:31 -04:00
|
|
|
pic_sym sCONS, sCAR, sCDR, sNILP;
|
|
|
|
pic_sym sADD, sSUB, sMUL, sDIV;
|
|
|
|
pic_sym sEQ, sLT, sLE, sGT, sGE;
|
2013-10-13 02:14:15 -04:00
|
|
|
|
2013-10-28 13:11:31 -04:00
|
|
|
struct xhash *sym_tbl;
|
|
|
|
const char **sym_pool;
|
|
|
|
size_t slen, scapa;
|
2013-10-20 01:05:35 -04:00
|
|
|
|
2013-10-30 03:37:43 -04:00
|
|
|
/* positive for variables, negative for macros (bitnot) */
|
2013-10-22 09:22:35 -04:00
|
|
|
struct xhash *global_tbl;
|
2013-10-17 11:15:15 -04:00
|
|
|
pic_value *globals;
|
|
|
|
size_t glen, gcapa;
|
2013-10-30 03:37:43 -04:00
|
|
|
struct pic_proc **macros;
|
|
|
|
size_t mlen, mcapa;
|
2013-10-22 09:22:35 -04:00
|
|
|
|
2013-10-15 22:53:25 -04:00
|
|
|
struct pic_irep **irep;
|
|
|
|
size_t ilen, icapa;
|
2013-10-20 20:29:56 -04:00
|
|
|
pic_value *pool;
|
|
|
|
size_t plen, pcapa;
|
2013-10-15 22:53:25 -04:00
|
|
|
|
2013-10-20 05:17:12 -04:00
|
|
|
jmp_buf *jmp;
|
|
|
|
const char *errmsg;
|
|
|
|
|
2013-10-13 02:14:15 -04:00
|
|
|
struct heap_page *heap;
|
2013-10-13 04:02:29 -04:00
|
|
|
struct pic_object *arena[PIC_ARENA_SIZE];
|
|
|
|
int arena_idx;
|
2013-10-10 03:15:41 -04:00
|
|
|
} pic_state;
|
|
|
|
|
2013-10-15 06:19:34 -04:00
|
|
|
typedef pic_value (*pic_func_t)(pic_state *);
|
|
|
|
|
2013-10-10 03:44:51 -04:00
|
|
|
void *pic_alloc(pic_state *, size_t);
|
2013-10-15 22:21:41 -04:00
|
|
|
void *pic_realloc(pic_state *, void *, size_t);
|
2013-10-23 11:32:03 -04:00
|
|
|
void *pic_calloc(pic_state *, unsigned, size_t);
|
2013-10-13 03:55:07 -04:00
|
|
|
struct pic_object *pic_obj_alloc(pic_state *, size_t, enum pic_tt);
|
2013-10-10 03:44:51 -04:00
|
|
|
void pic_free(pic_state *, void *);
|
|
|
|
|
2013-10-13 04:25:36 -04:00
|
|
|
void pic_gc_protect(pic_state *, pic_value);
|
|
|
|
int pic_gc_arena_preserve(pic_state *);
|
|
|
|
void pic_gc_arena_restore(pic_state *, int);
|
|
|
|
|
2013-10-20 22:51:02 -04:00
|
|
|
pic_state *pic_open(int argc, char *argv[], char **envp);
|
2013-10-10 03:19:10 -04:00
|
|
|
void pic_close(pic_state *);
|
2013-10-10 03:15:41 -04:00
|
|
|
|
2013-10-21 00:57:02 -04:00
|
|
|
int pic_get_args(pic_state *, const char *, ...);
|
2013-10-15 06:19:34 -04:00
|
|
|
void pic_defun(pic_state *, const char *, pic_func_t);
|
|
|
|
|
2013-10-11 04:36:51 -04:00
|
|
|
bool pic_eq_p(pic_state *, pic_value, pic_value);
|
2013-10-28 13:11:31 -04:00
|
|
|
bool pic_eqv_p(pic_state *, pic_value, pic_value);
|
2013-10-28 13:12:37 -04:00
|
|
|
bool pic_equal_p(pic_state *, pic_value, pic_value);
|
2013-10-11 04:36:51 -04:00
|
|
|
|
2013-10-28 13:11:31 -04:00
|
|
|
pic_sym pic_intern_cstr(pic_state *, const char *);
|
|
|
|
const char *pic_symbol_name(pic_state *, pic_sym);
|
2013-10-10 04:06:26 -04:00
|
|
|
|
2013-10-20 22:12:34 -04:00
|
|
|
pic_value pic_str_new(pic_state *, const char *, size_t);
|
2013-10-20 21:48:03 -04:00
|
|
|
pic_value pic_str_new_cstr(pic_state *, const char *);
|
|
|
|
|
2013-10-29 02:51:37 -04:00
|
|
|
struct pic_vector *pic_vec_new(pic_state *, size_t);
|
|
|
|
struct pic_vector *pic_vec_new_from_list(pic_state *, pic_value);
|
|
|
|
|
2013-10-30 04:06:01 -04:00
|
|
|
int pic_parse_file(pic_state *, FILE *file, pic_value *);
|
|
|
|
int pic_parse_cstr(pic_state *, const char *, pic_value *);
|
2013-10-11 02:18:37 -04:00
|
|
|
|
2013-10-28 04:45:13 -04:00
|
|
|
pic_value pic_apply(pic_state *pic, struct pic_proc *, pic_value);
|
|
|
|
pic_value pic_apply_argv(pic_state *pic, struct pic_proc *, size_t, ...);
|
2013-10-22 09:22:35 -04:00
|
|
|
struct pic_proc *pic_codegen(pic_state *, pic_value);
|
2013-10-30 03:37:43 -04:00
|
|
|
pic_value pic_expand(pic_state *, pic_value);
|
2013-10-11 04:36:51 -04:00
|
|
|
|
2013-10-20 04:41:48 -04:00
|
|
|
void pic_abort(pic_state *, const char *);
|
|
|
|
void pic_raise(pic_state *, pic_value);
|
2013-10-20 05:17:12 -04:00
|
|
|
void pic_error(pic_state *, const char *);
|
2013-10-24 09:29:40 -04:00
|
|
|
void pic_warn(pic_state *, const char *);
|
2013-10-12 01:40:27 -04:00
|
|
|
|
2013-10-10 04:48:01 -04:00
|
|
|
void pic_debug(pic_state *, pic_value);
|
|
|
|
|
2013-10-10 03:15:41 -04:00
|
|
|
#endif
|