Closer to old state
This commit is contained in:
53
ccodegen.cpp
53
ccodegen.cpp
@@ -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:{
|
||||
|
||||
Reference in New Issue
Block a user