diff options
author | Leo Tenenbaum <pommicket@gmail.com> | 2020-05-13 11:23:07 -0400 |
---|---|---|
committer | Leo Tenenbaum <pommicket@gmail.com> | 2020-05-13 11:23:07 -0400 |
commit | c466d81a2423d7122d7a0cbdc8059e69e88899f2 (patch) | |
tree | 3f729ca9dcfc48c2ce5852f6688a2ff43f7c4800 | |
parent | 2f9e7e8a3a8239bc4b4f880cc5e91c23cdd154dc (diff) |
fixed segfault following #include error
-rw-r--r-- | main.c | 2 | ||||
-rw-r--r-- | test.toc | 51 | ||||
-rw-r--r-- | types.c | 8 |
3 files changed, 15 insertions, 46 deletions
@@ -13,7 +13,7 @@ cgen_recurse_subtypes should go inside struct params. maybe it could also go int get rid of UNARY_LEN? detect circular declarations (A ::= B; B ::= A) either detect circular #includes or set a #include depth limit (maybe sometimes you want finite circular includes with #if) -initialization functions (maybe #init(-50), where -50 is the priority and <0 is reserved for standard library) +initialization statements (maybe #init(-50), where -50 is the priority and <0 is reserved for standard library) if we do #include "foo.toc", bar; and foo.toc fails, bar should be declared as TYPE_UNKNOWN (right now it's undeclared) improve type_to_str: Foo ::= struct(t::Type) {} @@ -1,47 +1,14 @@ -#include "tests/std/io.toc", io; -#include "std/mem.toc"; - -main ::= fn() { - nums := news(int, 10); - for x, i := &nums { - *x = i*i; - } - l := slice_to_ll(nums); - p := &l; - while p { - io.puti(p.head); - p = p.tail; - } - f: Foo; - f.k = -173; - f.b = new(Bar); - f.b.f.b = new(Bar); - f.b.f.b.f.k = 9; - io.puti(f.k); - io.puti(f.b.f.k); - io.puti(f.b.f.b.f.k); -} - -slice_to_ll ::= fn(t::=, slice: []t) use ll: LinkedList(t) { - head = slice[0]; - if slice.len == 1 { - tail = null; +Point ::= struct { + #if 1 { + #include "point.toc"; } else { - tail = new(LinkedList(t)); - *tail = slice_to_ll(slice[1:]); + z: int; } } -LinkedList ::= struct (of :: Type) { - head: of; - tail: &LinkedList(of); -} - -Foo ::= struct { - k: int; - b: &Bar; -} - -Bar ::= struct { - f: Foo; +main ::= fn() { + p : Point; + p.x; + p.y; + p.z; } @@ -3881,7 +3881,7 @@ static Status types_stmt(Typer *tr, Statement *s) { err_print(s->where, "Redeclaration of identifier %s.", istr); info_print(ident_decl_location(i), "Previous declaration was here."); free(istr); - goto inc_fail; + return false; /* NOT goto inc_fail; */ } } i->decl = d; @@ -3895,8 +3895,10 @@ static Status types_stmt(Typer *tr, Statement *s) { } break; inc_fail: - tr->nms = prev_nms; - typer_block_exit(tr); + if (inc_nms) { + tr->nms = prev_nms; + typer_block_exit(tr); + } return false; } case STMT_MESSAGE: { |