--- stack/stack.c 2002/02/06 00:52:31 1.36 +++ stack/stack.c 2002/02/06 01:51:08 1.37 @@ -218,6 +218,7 @@ switch (val->type){ /* and free the contents if necessary */ case string: free(val->content.ptr); + break; case list: /* lists needs to be freed recursively */ item=val->content.ptr; while(item != NULL) { /* for all stack items */ @@ -256,6 +257,39 @@ printf("\n"); } +/* Gets the type of a value */ +extern void type(environment *env){ + int typenum; + + if((env->head)==NULL) { + printerr("Too Few Arguments"); + env->err=1; + return; + } + typenum=env->head->item->type; + toss(env); + switch(typenum){ + case integer: + push_sym(env, "integer"); + break; + case string: + push_sym(env, "string"); + break; + case symb: + push_sym(env, "symbol"); + break; + case func: + push_sym(env, "function"); + break; + case list: + push_sym(env, "list"); + break; + default: + push_sym(env, "unknown"); + break; + } +} + /* Prints the top element of the stack. */ void print_h(stackitem *stack_head) { @@ -314,8 +348,6 @@ extern void printstack(environment *env) { if(env->head == NULL) { - printerr("Too Few Arguments"); - env->err=1; return; } print_st(env->head, 1); @@ -457,7 +489,7 @@ } /* Parse input. */ -int stack_read(environment *env, char *in_line) +void stack_read(environment *env, char *in_line) { char *temp, *rest; int itemp; @@ -518,18 +550,16 @@ } } while(0); - free(temp); if(convert<2) { free(rest); - return 0; + return; } stack_read(env, rest); free(rest); - return 1; } /* Relocate elements of the list on the stack. */