From e6c4c5038902b98c6969d3b5a3c28ee149917bb8 Mon Sep 17 00:00:00 2001 From: Leo Tenenbaum Date: Sun, 25 Aug 2019 13:03:00 -0400 Subject: parsing function types --- out.c | 9 +-------- out.h | 2 -- parse.c | 57 ++++++++++++++++++++++++++++++++++++++++++++++++++++++--- test.toc | 12 ++---------- 4 files changed, 57 insertions(+), 23 deletions(-) diff --git a/out.c b/out.c index dfdc298..f839a20 100644 --- a/out.c +++ b/out.c @@ -1,15 +1,8 @@ #include "out.h" /* toc */ -static void bar(); -void asfdhjfdsaf() { -} void main__(void) { - int64_t x = ((12+(-(-3)))+3); -} -int8_t foo(int64_t x, float y, double z) { -} -void bar() { +printf ("\x48\x65\x6c\x6c\x6f\x2c\x20\x57\x6f\x72\x6c\x64\x21\x0a\x00"); } int main(void) { diff --git a/out.h b/out.h index 6479cc4..4cc08ee 100644 --- a/out.h +++ b/out.h @@ -1,4 +1,2 @@ #include -void asfdhjfdsaf(); void main__(void); -static int8_t foo(int64_t x, float y, double z); diff --git a/parse.c b/parse.c index e9d049e..4972cb9 100644 --- a/parse.c +++ b/parse.c @@ -1,7 +1,8 @@ /* TODO: stmt_parse -> parse_stmt, etc. */ typedef enum { TYPE_VOID, - TYPE_BUILTIN + TYPE_BUILTIN, + TYPE_FN } TypeKind; typedef enum { @@ -25,6 +26,9 @@ typedef struct { TypeKind kind; union { BuiltinType builtin; + struct { + Array types; /* [0] = ret_type, [1..] = param_types */ + } fn; }; } Type; @@ -184,8 +188,45 @@ static bool parse_type(Parser *p, Type *type) { type->kind = TYPE_BUILTIN; type->builtin = kw_to_builtin_type(t->token->kw); if (type->builtin == BUILTIN_TYPE_COUNT) { - tokr_err(t, "Expected type."); - return false; + /* Not a builtin */ + if (t->token->kw == KW_FN) { + /* function type */ + type->kind = TYPE_FN; + arr_create(&type->fn.types, sizeof(Type)); + t->token++; + if (!token_is_kw(t->token, KW_LPAREN)) { + tokr_err(t, "Expected ( for function type."); + return false; + } + Type *ret_type = arr_add(&type->fn.types); + t->token++; + if (!token_is_kw(t->token, KW_RPAREN)) { + while (1) { + Type *param_type = arr_add(&type->fn.types); + if (!parse_type(p, param_type)) return false; + if (token_is_kw(t->token, KW_RPAREN)) + break; + if (!token_is_kw(t->token, KW_COMMA)) { + tokr_err(t, "Expected , to continue function type parameter list."); + return false; + } + t->token++; /* move past , */ + } + } + t->token++; /* move past ) */ + + /* if there's a symbol, that can't be the start of a type */ + if (t->token->kind == TOKEN_KW + && t->token->kw <= KW_LAST_SYMBOL) { + ret_type->kind = TYPE_VOID; + } else { + if (!parse_type(p, ret_type)) + return false; + } + return true; + } + + break; } else { t->token++; return true; @@ -807,6 +848,16 @@ static void fprint_type(FILE *out, Type *t) { case TYPE_VOID: fprintf(out, "void"); break; + case TYPE_FN: { + Type *types = t->fn.types.data; + fprintf(out, "fn ("); + for (size_t i = 1; i < t->fn.types.len; i++){ + fprint_type(out, &types[i]); + fprintf(out, ","); + } + fprintf(out, ") "); + fprint_type(out, &types[0]); + } break; } } diff --git a/test.toc b/test.toc index e8ae1b1..a7abd42 100644 --- a/test.toc +++ b/test.toc @@ -1,11 +1,3 @@ -asfdhjfdsaf @= fn() { -}; - -main @= fn() { - foo @= fn(x: int, y: float, z: double) i8 { - }; - bar @= fn() { - - }; - x : int = 12 + --3 + 3; +main @ fn (int) fn(fn() fn()) = fn() { + printf("Hello, World!\n"); }; \ No newline at end of file -- cgit v1.2.3