From a984cedd59c5dc290b896e4b8743f771df31e1bd Mon Sep 17 00:00:00 2001 From: lemon Date: Mon, 29 Aug 2022 08:17:03 +0200 Subject: add type, multiline strings --- src/cffc.hff | 1 + src/llvm.cff | 17 +++++++++++++++-- src/parse.cff | 16 ++++++++++++++-- 3 files changed, 30 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/cffc.hff b/src/cffc.hff index 7dc9cfa..e329965 100644 --- a/src/cffc.hff +++ b/src/cffc.hff @@ -498,6 +498,7 @@ extern fn ir_free(*IRCtx) void; extern static g_asmbackend Backend; // llvm.cff +extern fn llvm_addtype(*const Type) void; extern fn llvm_addglobl(*Decl, staticp bool) void; extern fn llvm_genfn(externp bool, name *const u8, f *Fn) void; extern fn llvm_genstatic(externp bool, name *const u8, var *Var) void; diff --git a/src/llvm.cff b/src/llvm.cff index 0031777..eb13919 100644 --- a/src/llvm.cff +++ b/src/llvm.cff @@ -72,6 +72,15 @@ extern fn genagg(ty *const Type) void { } } +extern fn llvm_addtype(ty *const Type) void { + if ty.u.#tag == :Agg and !ty.u.Agg.fwd { + gen("%%type.%s.%d = type ", ty.u.Agg.name ?? as(*u8)".", ty.u.Agg.id); + genagg(ty); + gen("\n"); + } +} + + fn gendata(ty *const Type, ex *Expr) void; fn gen(fmt *const u8, ...) void { let ap va_list #?; @@ -93,8 +102,12 @@ fn gen(fmt *const u8, ...) void { case Arr arr; assert(arr.length >= 0, "arr length"); gen("[%z x %t]", arr.length, arr.child); - case Agg; - genagg(ty); + case Agg agg; + if agg.fwd { + genagg(ty); + } else { + gen("%%type.%s.%d", ty.u.Agg.name ?? as(*u8)".", ty.u.Agg.id); + } case Enum enu; pritype(enu.intty); case BitF bitf; pritype(bitf.intty); case Fn f; diff --git a/src/parse.cff b/src/parse.cff index 5c3ac63..2e6cec9 100644 --- a/src/parse.cff +++ b/src/parse.cff @@ -804,6 +804,7 @@ fn parseagg(P *Parser, loc Loc, kind AggKind, name *const u8, retdecl **Decl) *c fld.off += off; } } + llvm_addtype(ty); if havedecls { agg.decls = mkenv(P.curenv, P.alloc); constty.u.Agg.decls = agg.decls; @@ -1461,8 +1462,19 @@ fn pexprimary(P *Parser) Expr { ex = { tok.loc, ty_voidptr, .u: :NullLit }; case :str; - let ty = mkarrtype(tok.u.str.#len + 1, #t, ty_u8); - ex = { tok.loc, ty, .u: :StrLit(tok.u.str) }; + let str = tok.u.str; + let s Vec = {}; + if lexpeek(P).t == :str { + foreach (c, _, tok.u.str) { s->push(c); } + while lexmatch(P, &tok, :str) { + foreach (c, _, tok.u.str) { s->push(c); } + } + s->push('\0'); + --s.len; + str = s->move(P.tlalloc); + } + let ty = mkarrtype(str.#len + 1, #t, ty_u8); + ex = { tok.loc, ty, .u: :StrLit(str) }; case :ident; let ident = tok.u.ident; -- cgit v1.2.3