Still making progress. Dropped the archive because it was causing problems.
This commit is contained in:
parent
eed4711fee
commit
8d2acbeb0f
97 changed files with 490 additions and 13322 deletions
|
|
@ -31,14 +31,7 @@
|
|||
*
|
||||
* * (apply fn args)
|
||||
*/
|
||||
struct pso_pointer apply(
|
||||
#ifndef MANAGED_POINTER_ONLY
|
||||
struct pso4 *frame,
|
||||
#endif
|
||||
struct pso_pointer frame_pointer) {
|
||||
#ifdef MANAGED_POINTER_ONLY
|
||||
struct pso4 *frame = pointer_to_pso4( frame_pointer );
|
||||
#endif
|
||||
struct pso_pointer apply( struct pso_pointer frame_pointer ) {
|
||||
|
||||
// TODO.
|
||||
|
||||
|
|
@ -49,16 +42,11 @@ struct pso_pointer apply(
|
|||
*
|
||||
* * (eval form)
|
||||
*/
|
||||
struct pso_pointer eval(
|
||||
#ifndef MANAGED_POINTER_ONLY
|
||||
struct pso4 *frame,
|
||||
#endif
|
||||
struct pso_pointer frame_pointer) {
|
||||
#ifdef MANAGED_POINTER_ONLY
|
||||
struct pso_pointer eval( struct pso_pointer frame_pointer ) {
|
||||
struct pso4 *frame = pointer_to_pso4( frame_pointer );
|
||||
#endif
|
||||
|
||||
struct pso_pointer arg = fetch_arg( frame, 0 );
|
||||
struct pso_pointer result = nil;
|
||||
struct pso_pointer result = nil;
|
||||
|
||||
switch ( get_tag_value( arg ) ) {
|
||||
// case CONSTV:
|
||||
|
|
@ -68,10 +56,10 @@ struct pso_pointer eval(
|
|||
case KEYTV:
|
||||
case STRINGTV:
|
||||
// self evaluating
|
||||
result = nil;
|
||||
result = nil;
|
||||
break;
|
||||
case SYMBOLTV:
|
||||
arg = c_assoc( arg, fetch_env(frame_pointer) );
|
||||
arg = c_assoc( arg, fetch_env( frame_pointer ) );
|
||||
break;
|
||||
// case LAMBDATV:
|
||||
// result = eval_lambda( frame, frame_pointer, env);
|
||||
|
|
@ -84,22 +72,22 @@ struct pso_pointer eval(
|
|||
// break;
|
||||
default:
|
||||
arg =
|
||||
make_exception(
|
||||
make_frame(1, frame_pointer,
|
||||
make_cons( frame_pointer,
|
||||
c_string_to_lisp_string( frame_pointer,
|
||||
L"Can't yet evaluate things of this type: " ),
|
||||
arg ),
|
||||
make_cons( frame_pointer,
|
||||
make_cons
|
||||
( frame_pointer,
|
||||
c_string_to_lisp_keyword
|
||||
( frame_pointer,
|
||||
L"tag" ),
|
||||
get_tag_string
|
||||
( arg ) ),
|
||||
nil ),
|
||||
nil ));
|
||||
make_exception( make_frame( 1, frame_pointer,
|
||||
make_cons( frame_pointer,
|
||||
c_string_to_lisp_string
|
||||
( frame_pointer,
|
||||
L"Can't yet evaluate things of this type: " ),
|
||||
arg ),
|
||||
make_cons( frame_pointer,
|
||||
make_cons
|
||||
( frame_pointer,
|
||||
c_string_to_lisp_keyword
|
||||
( frame_pointer,
|
||||
L"tag" ),
|
||||
get_tag_string
|
||||
( frame_pointer,
|
||||
arg ) ), nil ),
|
||||
nil ) );
|
||||
}
|
||||
|
||||
if ( exceptionp( arg ) ) {
|
||||
|
|
@ -108,7 +96,7 @@ struct pso_pointer eval(
|
|||
EXCEPTIONTV );
|
||||
|
||||
if ( c_nilp( x->payload.exception.stack ) ) {
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue