summaryrefslogtreecommitdiff
path: root/src/lisp/ao_lisp.h
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2016-11-09 11:13:58 -0800
committerKeith Packard <keithp@keithp.com>2016-11-17 22:18:39 -0800
commite503e46f5e9ca57b7a7d976b2ee02a3d7812bc92 (patch)
treee4a6e48af62ec4b87fd29b99f087d76cb873c2a4 /src/lisp/ao_lisp.h
parent71796f4407ebf11251c150dfa368f571ba12db8d (diff)
altos/lisp: macros appear to work now
Needed an extra stack frame to stash the pre-macro state. This simplified macro processing quite a bit; a macro now just evaluates the function and then sends that result to be evaluated again. Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/lisp/ao_lisp.h')
-rw-r--r--src/lisp/ao_lisp.h37
1 files changed, 23 insertions, 14 deletions
diff --git a/src/lisp/ao_lisp.h b/src/lisp/ao_lisp.h
index 6a35d8ce..82ba5a20 100644
--- a/src/lisp/ao_lisp.h
+++ b/src/lisp/ao_lisp.h
@@ -78,6 +78,7 @@ extern uint16_t ao_lisp_top;
#define AO_LISP_OOM 0x01
#define AO_LISP_DIVIDE_BY_ZERO 0x02
#define AO_LISP_INVALID 0x04
+#define AO_LISP_UNDEFINED 0x08
extern uint8_t ao_lisp_exception;
@@ -156,28 +157,25 @@ ao_lisp_frame_poly(struct ao_lisp_frame *frame) {
return ao_lisp_poly(frame, AO_LISP_OTHER);
}
-struct ao_lisp_stack {
- ao_poly prev;
- uint8_t state;
- uint8_t macro;
- ao_poly sexprs;
- ao_poly values;
- ao_poly values_tail;
- ao_poly frame;
- ao_poly macro_frame;
- ao_poly list;
-};
-
enum eval_state {
- eval_sexpr,
+ eval_sexpr, /* Evaluate an sexpr */
eval_val,
eval_formal,
eval_exec,
- eval_lambda_done,
eval_cond,
eval_cond_test
};
+struct ao_lisp_stack {
+ uint8_t state; /* enum eval_state */
+ ao_poly prev; /* previous stack frame */
+ ao_poly sexprs; /* expressions to evaluate */
+ ao_poly values; /* values computed */
+ ao_poly values_tail; /* end of the values list for easy appending */
+ ao_poly frame; /* current lookup frame */
+ ao_poly list; /* most recent function call */
+};
+
static inline struct ao_lisp_stack *
ao_lisp_poly_stack(ao_poly p)
{
@@ -559,6 +557,16 @@ int ao_lisp_stack_depth;
#define DBG_POLY(a) ao_lisp_poly_print(a)
#define OFFSET(a) ((a) ? (int) ((uint8_t *) a - ao_lisp_pool) : -1)
#define DBG_STACK() ao_lisp_stack_print()
+static inline void
+ao_lisp_frames_dump(void)
+{
+ struct ao_lisp_stack *s;
+ DBGI(".. current frame: "); DBG_POLY(ao_lisp_frame_poly(ao_lisp_frame_current)); DBG("\n");
+ for (s = ao_lisp_stack; s; s = ao_lisp_poly_stack(s->prev)) {
+ DBGI(".. stack frame: "); DBG_POLY(s->frame); DBG("\n");
+ }
+}
+#define DBG_FRAMES() ao_lisp_frames_dump()
#else
#define DBG_DO(a)
#define DBG_INDENT()
@@ -570,6 +578,7 @@ int ao_lisp_stack_depth;
#define DBG_POLY(a)
#define DBG_RESET()
#define DBG_STACK()
+#define DBG_FRAMES()
#endif
#endif /* _AO_LISP_H_ */