For from pointer to reference
This commit is contained in:
40
ccodegen.cpp
40
ccodegen.cpp
@@ -59,8 +59,8 @@ gen_simple_decl(Ast_Resolved_Type *ast, Intern_String name){
|
||||
gen_simple_decl_prefix(ast->func.ret);
|
||||
gen("(*%s)(", name.str);
|
||||
For(ast->func.args){
|
||||
gen_simple_decl_prefix(it[0]);
|
||||
if(it != ast->func.args.end() - 1) gen(", ");
|
||||
gen_simple_decl_prefix(it);
|
||||
if(&it != ast->func.args.end() - 1) gen(", ");
|
||||
}
|
||||
gen(")");
|
||||
}
|
||||
@@ -143,7 +143,7 @@ gen_expr(Ast_Expr *ast){
|
||||
|
||||
gen("{");
|
||||
For(node->exprs){
|
||||
auto comp = it[0];
|
||||
auto comp = it;
|
||||
if(comp->name){
|
||||
gen("[");
|
||||
gen_expr(comp->name);
|
||||
@@ -157,7 +157,7 @@ gen_expr(Ast_Expr *ast){
|
||||
assert(comp->item);
|
||||
gen_expr(comp->item);
|
||||
|
||||
if(!node->exprs.is_last(it)) gen(", ");
|
||||
if(!node->exprs.is_last(&it)) gen(", ");
|
||||
}
|
||||
gen("}");
|
||||
}
|
||||
@@ -165,8 +165,8 @@ gen_expr(Ast_Expr *ast){
|
||||
gen_expr(node->name);
|
||||
gen("(");
|
||||
For(node->exprs){
|
||||
gen_expr(it[0]->item);
|
||||
if(!node->exprs.is_last(it)) gen(", ");
|
||||
gen_expr(it->item);
|
||||
if(!node->exprs.is_last(&it)) gen(", ");
|
||||
}
|
||||
gen(")");
|
||||
}
|
||||
@@ -186,7 +186,7 @@ gen_block(Ast_Block *block){
|
||||
global_indent++;
|
||||
For(block->stmts) {
|
||||
genln("");
|
||||
gen_ast(it[0]);
|
||||
gen_ast(it);
|
||||
}
|
||||
global_indent--;
|
||||
genln("}");
|
||||
@@ -199,7 +199,7 @@ gen_ast(Ast *ast){
|
||||
CASE(PACKAGE, Package){
|
||||
For(node->ordered) {
|
||||
genln("");
|
||||
gen_ast(*it);
|
||||
gen_ast(it);
|
||||
}
|
||||
BREAK();
|
||||
}
|
||||
@@ -238,21 +238,21 @@ gen_ast(Ast *ast){
|
||||
|
||||
CASE(IF, If){
|
||||
For(node->ifs){
|
||||
if(it[0]->init) gen_ast(it[0]->init);
|
||||
if(node->ifs.is_first(it)){
|
||||
if(it->init) gen_ast(it->init);
|
||||
if(node->ifs.is_first(&it)){
|
||||
genln("if(");
|
||||
gen_expr(it[0]->expr);
|
||||
gen_expr(it->expr);
|
||||
gen(")");
|
||||
gen_block(it[0]->block);
|
||||
gen_block(it->block);
|
||||
}
|
||||
else{
|
||||
genln("else");
|
||||
if(it[0]->expr){
|
||||
if(it->expr){
|
||||
gen(" if(");
|
||||
gen_expr(it[0]->expr);
|
||||
gen_expr(it->expr);
|
||||
gen(")");
|
||||
}
|
||||
gen_block(it[0]->block);
|
||||
gen_block(it->block);
|
||||
}
|
||||
}
|
||||
BREAK();
|
||||
@@ -269,10 +269,10 @@ gen_ast(Ast *ast){
|
||||
gen_simple_decl(ret, node->name);
|
||||
gen("(");
|
||||
For(lambda->args){
|
||||
assert(it[0]->kind == AST_LAMBDA_ARG);
|
||||
Ast_Resolved_Type *type = resolved_type_get(it[0]->typespec);
|
||||
gen_simple_decl(type, it[0]->name);
|
||||
if(it != (lambda->args.end() - 1)) gen(", ");
|
||||
assert(it->kind == AST_LAMBDA_ARG);
|
||||
Ast_Resolved_Type *type = resolved_type_get(it->typespec);
|
||||
gen_simple_decl(type, it->name);
|
||||
if(&it != (lambda->args.end() - 1)) gen(", ");
|
||||
}
|
||||
gen(")");
|
||||
|
||||
@@ -302,7 +302,7 @@ gen_ast(Ast *ast){
|
||||
global_indent++;
|
||||
For(agg->members){
|
||||
genln("");
|
||||
gen_ast(it[0]);
|
||||
gen_ast(it);
|
||||
}
|
||||
global_indent--;
|
||||
genln("};");
|
||||
|
||||
Reference in New Issue
Block a user