diff options
author | Leo Tenenbaum <pommicket@gmail.com> | 2019-08-25 13:03:00 -0400 |
---|---|---|
committer | Leo Tenenbaum <pommicket@gmail.com> | 2019-08-25 13:03:00 -0400 |
commit | e6c4c5038902b98c6969d3b5a3c28ee149917bb8 (patch) | |
tree | f9e6599b54e163ad40511e232b9a1a87bcaf7e2f | |
parent | 22fe17e12d0a0891bc6452e0a55dc474ae74c4e8 (diff) |
parsing function types
-rw-r--r-- | out.c | 9 | ||||
-rw-r--r-- | out.h | 2 | ||||
-rw-r--r-- | parse.c | 57 | ||||
-rw-r--r-- | test.toc | 12 |
4 files changed, 57 insertions, 23 deletions
@@ -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) { @@ -1,4 +1,2 @@ #include <stdint.h> -void asfdhjfdsaf(); void main__(void); -static int8_t foo(int64_t x, float y, double z); @@ -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; } } @@ -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 |