diff options
author | Leo Tenenbaum <pommicket@gmail.com> | 2019-12-03 22:29:25 -0500 |
---|---|---|
committer | Leo Tenenbaum <pommicket@gmail.com> | 2019-12-03 22:29:25 -0500 |
commit | 6b82029a3d8ac93b831dc8e8c9a8959acdf71f21 (patch) | |
tree | 8782ab2593459de0a707d4d58ce427c986be63f5 | |
parent | 876c1cdd06b52b0895c048c3d6e5648df1e516c1 (diff) |
fixed problem with checking for non-constant type declarations
-rw-r--r-- | test.toc | 61 | ||||
-rw-r--r-- | types.c | 67 |
2 files changed, 71 insertions, 57 deletions
@@ -1,34 +1,39 @@ -puti @= fn(x: int) { - #C("printf(\"%ld\\n\", (long)x); -"); -}; -putf @= fn(x: float) { - #C("printf(\"%f\\n\", (double)x); -"); -}; +// puti @= fn(x: int) { +// #C("printf(\"%ld\\n\", (long)x); +// "); +// }; +// putf @= fn(x: float) { +// #C("printf(\"%f\\n\", (double)x); +// "); +// }; -Arr @= fn (t @ Type) Type { - struct { - data : []t; - len, cap : u64; - } -}; +// Arr @= fn (t @ Type) Type { +// struct { +// data : []t; +// len, cap : u64; +// } +// }; // todo: test that t @ type doesn't cause problems -arr_add @= fn(t @ Type, a : &Arr(t), x : t) { - if a.len >= a.cap { - a.cap = a.cap * 2 + 2; - new_data := new(t, a.cap); - each i := 0..a.len { - new_data[i] = a.data[i]; - } - a.data = new_data; - } - a.data[a.len] = x; - a.len += 1; -}; +// arr_add @= fn(t @ Type, a : &Arr(t), x : t) { +// if a.len >= a.cap { +// a.cap = a.cap * 2 + 2; +// new_data := new(t, a.cap); +// each i := 0..a.len { +// new_data[i] = a.data[i]; +// } +// a.data = new_data; +// } +// a.data[a.len] = x; +// a.len += 1; +// }; + +t @= fn(t : Type) Type { t }; -// main @= fn() { +// f @= fn(x : &t(float)){}; + +main @= fn() { + x : &t(float); // arr : Arr(int); // // arr_add(int, &arr, 5); // // arr_add(int, &arr, 10); @@ -36,7 +41,7 @@ arr_add @= fn(t @ Type, a : &Arr(t), x : t) { // // each i := 0..arr.len - 1 { // // puti(arr.data[i]); // // } -// }; +}; // t @= fn(x @ Type) Type { struct { t: x; } }; // // pass the wrong thing to t, and the error is in the wrong place @@ -212,14 +212,20 @@ static bool type_of_fn(Typer *tr, FnExpr *f, Location where, Type *t, U16 flags) entered_fn = true; arr_foreach(f->params, Declaration, decl) { - if (!types_decl(tr, decl)) return false; + if (!types_decl(tr, decl)) { + success = false; + goto ret; + } if (decl->type.kind == TYPE_TUPLE) { err_print(decl->where, "Functions can't have tuple parameters."); - return false; + success = false; + goto ret; } - if (!type_resolve(tr, &decl->type, where)) - return false; + if (!type_resolve(tr, &decl->type, where)) { + success = false; + goto ret; + } U32 is_at_all_const = decl->flags & (DECL_IS_CONST | DECL_SEMI_CONST); if (is_at_all_const) { if (!t->fn.constness) { @@ -276,8 +282,10 @@ static bool type_of_fn(Typer *tr, FnExpr *f, Location where, Type *t, U16 flags) if (f->ret_decls && f->ret_type.kind == TYPE_VOID /* haven't found return type yet */) { /* find return type */ arr_foreach(f->ret_decls, Declaration, d) { - if (!types_decl(tr, d)) - return false; + if (!types_decl(tr, d)) { + success = false; + goto ret; + } } if (arr_len(f->ret_decls) == 1 && arr_len(f->ret_decls[0].idents) == 1) { f->ret_type = f->ret_decls[0].type; @@ -1743,36 +1751,37 @@ static bool types_decl(Typer *tr, Declaration *d) { d->flags |= DECL_FOUND_VAL; } } - for (size_t i = 0; i < arr_len(d->idents); i++) { - Type *t = d->type.kind == TYPE_TUPLE ? &d->type.tuple[i] : &d->type; + + } + + for (size_t i = 0; i < arr_len(d->idents); i++) { + Type *t = d->type.kind == TYPE_TUPLE ? &d->type.tuple[i] : &d->type; + if (t->kind == TYPE_TYPE) { + if (!(d->flags & DECL_IS_CONST)) { + err_print(d->where, "Cannot declare non-constant type."); + success = false; + goto ret; + } Value *val = d->type.kind == TYPE_TUPLE ? &d->val.tuple[i] : &d->val; - if (t->kind == TYPE_TYPE) { - if (!(d->flags & DECL_IS_CONST)) { - err_print(d->where, "Cannot declare non-constant type."); - success = false; - goto ret; - } - if (!type_resolve(tr, val->type, d->where)) return false; - if (val->type->kind == TYPE_TUPLE) { - err_print(d->where, "You can't declare a new type to be a tuple."); + if (!type_resolve(tr, val->type, d->where)) return false; + if (val->type->kind == TYPE_TUPLE) { + err_print(d->where, "You can't declare a new type to be a tuple."); + success = false; + goto ret; + } + } else if (!(d->flags & DECL_IS_CONST) && t->kind == TYPE_FN && t->fn.constness) { + for (size_t p = 0; p < arr_len(t->fn.types)-1; p++) { + if (t->fn.constness[p] == CONSTNESS_YES) { + err_print(d->where, "You can't have a pointer to a function with constant parameters."); success = false; goto ret; } - } else if (!(d->flags & DECL_IS_CONST) && t->kind == TYPE_FN && t->fn.constness) { - for (size_t p = 0; p < arr_len(t->fn.types)-1; p++) { - if (t->fn.constness[p] == CONSTNESS_YES) { - err_print(d->where, "You can't have a pointer to a function with constant parameters."); - success = false; - goto ret; - } - } - /* make constness NULL, so that semi-constant parameters turn into non-constant arguments */ - t->fn.constness = NULL; } + /* make constness NULL, so that semi-constant parameters turn into non-constant arguments */ + t->fn.constness = NULL; } - - } + size_t n_idents = arr_len(d->idents); if (d->type.kind == TYPE_TUPLE) { if (n_idents != arr_len(d->type.tuple)) { |