diff options
| author | Keith Packard <keithp@keithp.com> | 2016-11-01 21:14:45 -0700 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2017-02-20 11:16:49 -0800 | 
| commit | d2408e72d1e0d3459918601712b09860ab17e200 (patch) | |
| tree | 5405e41249373e4d174e61e157ee30d00f145c8d /src/lisp/ao_lisp_prim.c | |
| parent | e2f4d25cd6f6f3787d4ee99264732d5b2ce23d4c (diff) | |
altos/lisp: Change lisp objects to use ao_poly everywhere. Add const
This makes all lisp objects use 16-bit ints for references so we can
hold more stuff in small amounts of memory. Also adds a separate
constant pool of lisp objects for builtins, initial atoms and constant
lisp code.
Now builds (and runs!) on the nucleo-32 boards.
Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/lisp/ao_lisp_prim.c')
| -rw-r--r-- | src/lisp/ao_lisp_prim.c | 40 | 
1 files changed, 17 insertions, 23 deletions
| diff --git a/src/lisp/ao_lisp_prim.c b/src/lisp/ao_lisp_prim.c index ccfd2be4..38dcb961 100644 --- a/src/lisp/ao_lisp_prim.c +++ b/src/lisp/ao_lisp_prim.c @@ -14,31 +14,25 @@  #include "ao_lisp.h" -ao_lisp_poly -ao_lisp_poly_print(ao_lisp_poly p) +static void (*const ao_lisp_print_funcs[AO_LISP_NUM_TYPE])(ao_poly) = { +	[AO_LISP_CONS] = ao_lisp_cons_print, +	[AO_LISP_STRING] = ao_lisp_string_print, +	[AO_LISP_INT] = ao_lisp_int_print, +	[AO_LISP_ATOM] = ao_lisp_atom_print, +	[AO_LISP_BUILTIN] = ao_lisp_builtin_print +}; + +ao_poly +ao_lisp_poly_print(ao_poly p)  { -	switch (ao_lisp_poly_type(p)) { -	case AO_LISP_CONS: -		ao_lisp_cons_print(ao_lisp_poly_cons(p)); -		break; -	case AO_LISP_STRING: -		ao_lisp_string_print(ao_lisp_poly_string(p)); -		break; -	case AO_LISP_INT: -		ao_lisp_int_print(ao_lisp_poly_int(p)); -		break; -	case AO_LISP_ATOM: -		ao_lisp_atom_print(ao_lisp_poly_atom(p)); -		break; -	case AO_LISP_BUILTIN: -		ao_lisp_builtin_print(ao_lisp_poly_builtin(p)); -		break; -	} -	return AO_LISP_NIL; +	void (*print)(ao_poly) = ao_lisp_print_funcs[ao_lisp_poly_type(p)]; +	if (print) +		print(p); +	return p;  }  void -ao_lisp_poly_mark(ao_lisp_poly p) +ao_lisp_poly_mark(ao_poly p)  {  	switch (ao_lisp_poly_type(p)) {  	case AO_LISP_CONS: @@ -53,8 +47,8 @@ ao_lisp_poly_mark(ao_lisp_poly p)  	}  } -ao_lisp_poly -ao_lisp_poly_move(ao_lisp_poly p) +ao_poly +ao_lisp_poly_move(ao_poly p)  {  	switch (ao_lisp_poly_type(p)) {  	case AO_LISP_CONS: | 
