Closer to old state

This commit is contained in:
Krzosa Karol
2022-06-10 14:08:27 +02:00
parent d5d9911f3e
commit 89b3e00ae4
8 changed files with 219 additions and 422 deletions

View File

@@ -164,15 +164,15 @@ gen_expr(Ast_Expr *ast){
BREAK();
}
// CASE(CAST, Cast){
// gen("(");
// gen("(");
// gen_simple_decl(resolved_type_get(node->typespec), {});
// gen(")");
// gen_expr(node->expr);
// gen(")");
// BREAK();
// }
CASE(CAST, Cast){
gen("(");
gen("(");
gen_simple_decl(node->after_type, {});
gen(")");
gen_expr(node->expr);
gen(")");
BREAK();
}
CASE(VAR, Decl){
gen_ast(node);
@@ -180,8 +180,13 @@ gen_expr(Ast_Expr *ast){
}
CASE(CALL, Call){
unused(node);
gen_expr(node->name);
gen("(");
For(node->exprs){
gen_expr(it->item);
if(!node->exprs.is_last(&it)) gen(", ");
}
gen(")");
BREAK();
}
@@ -215,11 +220,7 @@ enum {
function void
gen_var(Intern_String name, Ast_Resolved_Type *type, Ast_Expr *expr, B32 emit_value){
if(is_array(type)){
gen("Slice %s", name.str);
} else{
gen_simple_decl(type, name);
}
gen_simple_decl(type, name);
if(emit_value == DONT_EMIT_VALUE){
return;
@@ -228,11 +229,6 @@ gen_var(Intern_String name, Ast_Resolved_Type *type, Ast_Expr *expr, B32 emit_va
if(expr){
gen(" = ");
gen_expr(expr);
} else if(is_array(type)){
gen(" = (Slice){%d, (", type->arr.size);
gen_simple_decl(type, {});
gen("){}");
gen("}");
} else { // Default zero
if(is_numeric(type)){
gen(" = 0");
@@ -337,6 +333,21 @@ gen_ast(Ast *ast){
BREAK();
}
CASE(STRUCT, Decl){
gen("typedef struct %s{", node->name.str);
global_indent++;
is_inside_struct++;
For(node->scope->decls){
genln("");
gen_ast(it);
}
is_inside_struct--;
global_indent--;
genln("}%s;", node->name.str);
BREAK();
}
CASE(CONST, Decl){
switch(node->type->kind){
CASE_FLOAT:{