fixing missing features in the cranelift backend

Signed-off-by: Jakub Doka <jakub.doka2@gmail.com>
This commit is contained in:
Jakub Doka 2024-12-30 14:46:59 +01:00
parent 58479deca1
commit 95e1e8bcab
No known key found for this signature in database
GPG key ID: C6E9A89936B8C143
2 changed files with 35 additions and 0 deletions

View file

@ -334,6 +334,8 @@ impl FuncBuilder<'_, '_> {
self.bl.ins().stack_store(v, slot, offset); self.bl.ins().stack_store(v, slot, offset);
offset += align as i32; offset += align as i32;
} }
self.values[arg as usize] =
Some(Ok(self.bl.ins().stack_addr(cir::types::I64, slot, 0)))
} else { } else {
let loc = arg_vals.take(..abi_meta.arg_count).unwrap(); let loc = arg_vals.take(..abi_meta.arg_count).unwrap();
debug_assert_eq!(loc.len(), 1); debug_assert_eq!(loc.len(), 1);
@ -516,6 +518,8 @@ impl FuncBuilder<'_, '_> {
Err(self.block_of(block)) Err(self.block_of(block))
} }
Kind::Call { func, unreachable, args } => { Kind::Call { func, unreachable, args } => {
assert_ne!(func, hbty::Func::ECA, "@eca is not supported");
if unreachable { if unreachable {
todo!() todo!()
} else { } else {

31
smh.hb Normal file
View file

@ -0,0 +1,31 @@
ResultInner := fn($T: type, $E: type): type return union {ok: T, err: E}
Result := fn($T: type, $E: type): type return struct {
inner: ResultInner(T, E),
is_ok: bool,
$ok := fn(k: T): Self return .(.{ok: k}, true)
$err := fn(k: E): Self return .(.{err: k}, false)
$unwrap := fn(self: Self): T return self.expect("Panic: Unwrap on Error Variant.\0".ptr)
$unwrap_unchecked := fn(self: Self): T return self.inner.ok
unwrap_or := fn(self: Self, v: T): T if self.is_ok return self.inner.ok else return v
unwrap_or_else := fn(self: Self, $F: type): T if self.is_ok return self.inner.ok else return F(self.inner.err)
expect := fn(self: Self, msg: ^u8): T if self.is_ok return self.inner.ok else {
@eca(0, msg)
die
}
}
SomeError := enum {
SkillIssue,
}
div := fn(a: uint, b: uint): Result(uint, SomeError) {
if b != 0 return Result(uint, SomeError).ok(a / b)
return Result(uint, SomeError).err(.SkillIssue)
}
main := fn(): uint {
a := div(100, 0)
return a.expect("goof\0".ptr)
}