summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLeo Tenenbaum <pommicket@gmail.com>2019-08-25 13:03:00 -0400
committerLeo Tenenbaum <pommicket@gmail.com>2019-08-25 13:03:00 -0400
commite6c4c5038902b98c6969d3b5a3c28ee149917bb8 (patch)
treef9e6599b54e163ad40511e232b9a1a87bcaf7e2f
parent22fe17e12d0a0891bc6452e0a55dc474ae74c4e8 (diff)
parsing function types
-rw-r--r--out.c9
-rw-r--r--out.h2
-rw-r--r--parse.c57
-rw-r--r--test.toc12
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 <stdint.h>
-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