Skip to content

Commit

Permalink
handle unit return
Browse files Browse the repository at this point in the history
  • Loading branch information
edg-l committed Feb 4, 2024
1 parent 4970727 commit db6b6e9
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 9 deletions.
19 changes: 13 additions & 6 deletions lib/edlang_codegen_mlir/src/codegen.rs
Original file line number Diff line number Diff line change
Expand Up @@ -136,19 +136,26 @@ fn compile_module(ctx: &ModuleCompileCtx, module: &ir::ModuleBody) {
}

fn compile_fn_signature(ctx: &ModuleCompileCtx, body: &ir::Body) {
let (args, ret_type) = { (body.get_args(), body.ret_type.clone().unwrap()) };
let name = ctx.ctx.symbols.get(&body.def_id).unwrap();
info!("compiling fn sig: {}", name);

let (args, ret_type) = { (body.get_args(), body.ret_type.clone()) };

let args: Vec<BasicMetadataTypeEnum> = args
.iter()
.map(|x| compile_basic_type(ctx, &x.ty).into())
.collect();
let ret_type = compile_basic_type(ctx, &ret_type);
let name = ctx.ctx.symbols.get(&body.def_id).unwrap();
info!("compiling fn sig: {}", name);
// let ret_type = compile_basic_type(ctx, &ret_type);

let fn_type = if let ir::TypeKind::Unit = ret_type.kind {
ctx.ctx.context.void_type().fn_type(&args, false)
} else {
compile_basic_type(ctx, &ret_type).fn_type(&args, false)
};

ctx.module.add_function(
name,
ret_type.fn_type(&args, false),
fn_type,
Some(if body.is_extern {
inkwell::module::Linkage::AvailableExternally
} else if body.is_pub {
Expand Down Expand Up @@ -381,7 +388,7 @@ fn compile_type<'a>(
.functions
.get(def_id)
.unwrap();
(fn_body.get_args(), fn_body.ret_type.clone().unwrap())
(fn_body.get_args(), fn_body.ret_type.clone())
};

let args: Vec<BasicMetadataTypeEnum> = args
Expand Down
2 changes: 1 addition & 1 deletion lib/edlang_ir/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ pub struct Body {
pub def_id: DefId,
pub is_pub: bool,
pub is_extern: bool,
pub ret_type: Option<TypeInfo>,
pub ret_type: TypeInfo,
pub locals: SmallVec<[Local; 4]>,
pub blocks: SmallVec<[BasicBlock; 8]>,
pub fn_span: Span,
Expand Down
11 changes: 9 additions & 2 deletions lib/edlang_lowering/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,14 @@ fn lower_function(

let body = ir::Body {
def_id,
ret_type: func.return_type.as_ref().map(|x| lower_type(&mut ctx, x)),
ret_type: func
.return_type
.as_ref()
.map(|x| lower_type(&mut ctx, x))
.unwrap_or_else(|| TypeInfo {
span: None,
kind: ir::TypeKind::Unit,
}),
locals: Default::default(),
blocks: Default::default(),
fn_span: func.span,
Expand Down Expand Up @@ -543,7 +550,7 @@ fn lower_value(
fn lower_return(builder: &mut BodyBuilder, info: &ast::ReturnStmt) {
let ret_type = builder.body.ret_type.clone();
if let Some(value) = &info.value {
let rvalue = lower_expr(builder, value, ret_type.as_ref());
let rvalue = lower_expr(builder, value, Some(&ret_type));
let ret_local = builder.ret_local.unwrap();

builder.statements.push(Statement {
Expand Down
6 changes: 6 additions & 0 deletions programs/simple.ed
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,10 @@ mod Main {
x = 4;
return x;
}

pub fn a() {
let mut x: i32 = 2;
x = 4;
return;
}
}

0 comments on commit db6b6e9

Please sign in to comment.