--- stack/stack.c 2002/02/08 03:45:00 1.58 +++ stack/stack.c 2002/02/08 13:01:16 1.63 @@ -347,9 +347,6 @@ case list: push_sym(env, "list"); break; - default: - push_sym(env, "unknown"); - break; } } @@ -380,9 +377,6 @@ } printf("]"); break; - default: - printf("#", (stack_head->item->content.ptr)); - break; } } @@ -508,18 +502,16 @@ rcl(env); /* get its contents */ if(env->err) return; if(env->head->item->type!=symb){ /* don't recurse symbols */ - eval(env); /* evaluate the value */ - return; + return eval(env); /* evaluate the value */ } - break; + return; /* If it's a lone function value, run it */ case func: in_func= (funcp)(env->head->item->content.ptr); toss(env); if(env->err) return; - (*in_func)(env); - break; + return (*in_func)(env); /* If it's a list */ case list: @@ -528,19 +520,23 @@ toss(env); if(env->err) return; iterator= (stackitem*)temp_val->content.ptr; - while(iterator!=NULL && iterator->item!=NULL) { + while(iterator!=NULL) { push_val(&(env->head), iterator->item); if(env->head->item->type==symb && strcmp(";", ((symbol*)(env->head->item->content.ptr))->id)==0) { toss(env); if(env->err) return; + if(iterator->next == NULL){ + free_val(temp_val); + return eval(env); + } eval(env); if(env->err) return; } iterator= iterator->next; } free_val(temp_val); - break; + return; /* If it's a string */ case string: @@ -550,17 +546,15 @@ if(env->err) return; temp_string= malloc(strlen((char*)temp_val->content.ptr)+5); strcpy(temp_string, "[ "); - strcat(temp_string, (char*)temp_val->content.ptr); + strcpy(temp_string+2, (char*)temp_val->content.ptr); + free_val(temp_val); strcat(temp_string, " ]"); stack_read(env, temp_string); - eval(env); - if(env->err) return; - free_val(temp_val); free(temp_string); - break; + return eval(env); case integer: - break; + return; } } @@ -961,10 +955,72 @@ a=env->head->item->content.val; toss(env); if(env->err) return; - b=env->head->item->content.val; + if(env->head->item->refcount == 1) + env->head->item->content.val += a; + else { + b=env->head->item->content.val; + toss(env); + if(env->err) return; + push_int(&(env->head), a+b); + } +} + +/* - */ +extern void sx_2d(environment *env) { + int a, b; + + if((env->head)==NULL || env->head->next==NULL) { + printerr("Too Few Arguments"); + env->err=1; + return; + } + + if(env->head->item->type!=integer + || env->head->next->item->type!=integer) { + printerr("Bad Argument Type"); + env->err=2; + return; + } + a=env->head->item->content.val; + toss(env); + if(env->err) return; + if(env->head->item->refcount == 1) + env->head->item->content.val -= a; + else { + b=env->head->item->content.val; + toss(env); + if(env->err) return; + push_int(&(env->head), b-a); + } +} + +/* > */ +extern void sx_3e(environment *env) { + int a, b; + + if((env->head)==NULL || env->head->next==NULL) { + printerr("Too Few Arguments"); + env->err=1; + return; + } + + if(env->head->item->type!=integer + || env->head->next->item->type!=integer) { + printerr("Bad Argument Type"); + env->err=2; + return; + } + a=env->head->item->content.val; toss(env); if(env->err) return; - push_int(&(env->head), a+b); + if(env->head->item->refcount == 1) + env->head->item->content.val = (env->head->item->content.val > a); + else { + b=env->head->item->content.val; + toss(env); + if(env->err) return; + push_int(&(env->head), b>a); + } } /* Return copy of a value */ @@ -1022,7 +1078,7 @@ push_val(&(env->head), copy_val(env->head->item)); } -/* If-Then */ +/* "if", If-Then */ extern void sx_6966(environment *env) { int truth; @@ -1093,6 +1149,7 @@ extern void sx_7768696c65(environment *env) { int truth; + value *loop, *test; if((env->head)==NULL || env->head->next==NULL) { printerr("Too Few Arguments"); @@ -1100,10 +1157,17 @@ return; } + loop= env->head->item; + loop->refcount++; + toss(env); if(env->err) return; + + test= env->head->item; + test->refcount++; + toss(env); if(env->err) return; + do { - swap(env); if(env->err) return; - dup(env); if(env->err) return; - eval(env); if(env->err) return; + push_val(&(env->head), test); + eval(env); if(env->head->item->type != integer) { printerr("Bad Argument Type"); @@ -1112,17 +1176,17 @@ } truth= env->head->item->content.val; - toss(env); if(env->err) return; - swap(env); if(env->err) return; if(truth) { - dup(env); + push_val(&(env->head), loop); eval(env); } else { toss(env); - toss(env); } } while(truth); + + free_val(test); + free_val(loop); }