From d28e140fd317ef3d63286ba6d87eb0418ee536c9 Mon Sep 17 00:00:00 2001 From: David Kerkeslager Date: Tue, 1 Oct 2019 01:34:04 -0400 Subject: [PATCH] Added booleans --- templates/program2.c | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/templates/program2.c b/templates/program2.c index 8602054..1610a54 100644 --- a/templates/program2.c +++ b/templates/program2.c @@ -8,6 +8,7 @@ enum Type; typedef enum Type Type; enum Type { + BOOLEAN, BUILTIN, INTEGER, STRING @@ -25,6 +26,7 @@ union Value; typedef union Value Value; union Value { Builtin builtin; + bool boolean; char* string; int32_t integer; }; @@ -111,6 +113,10 @@ void call(struct Thread* thread, Argument argument) { Object arg = Stack_pop(&(thread->stack)); switch(arg.type) { + case BOOLEAN: + if(arg.value.boolean) printf("true"); + else printf("false"); + break; case INTEGER: printf("%i", arg.value.integer); break; @@ -192,16 +198,20 @@ void pop(struct Thread* thread, Argument argument) { void push(struct Thread* thread, Argument argument) { char* argumentString = argument.string; - if(strcmp(argumentString, "print") == 0) { + if(strcmp(argumentString, "false") == 0) { + Stack_push(&(thread->stack), (Object){ BOOLEAN, false }); + }else if(strcmp(argumentString, "pow") == 0) { Object result; result.type = BUILTIN; - result.value.builtin = PRINT; + result.value.builtin = POW; Stack_push(&(thread->stack), result); - } else if(strcmp(argumentString, "pow") == 0) { + } else if(strcmp(argumentString, "print") == 0) { Object result; result.type = BUILTIN; - result.value.builtin = POW; + result.value.builtin = PRINT; Stack_push(&(thread->stack), result); + } else if(strcmp(argumentString, "true") == 0) { + Stack_push(&(thread->stack), (Object){ BOOLEAN, true }); } else { Environment_get_Result result = Environment_get(thread->environment, argumentString); if(!result.found) { -- 2.20.1