From 06e8851f8e14a4ccde610749d5223b77f0011e9a Mon Sep 17 00:00:00 2001 From: mertcandav Date: Mon, 20 May 2024 12:25:16 +0300 Subject: [PATCH] compiler: fix and improve code generation for iterations --- src/julec/obj/cxx/scope.jule | 78 ++++++++++++++++++------------------ 1 file changed, 40 insertions(+), 38 deletions(-) diff --git a/src/julec/obj/cxx/scope.jule b/src/julec/obj/cxx/scope.jule index 574f48074..16416202a 100644 --- a/src/julec/obj/cxx/scope.jule +++ b/src/julec/obj/cxx/scope.jule @@ -73,24 +73,23 @@ impl scopeCoder { self.oc.indent() self.oc.write("auto expr = ") let mut ref = false - match type it.Expr.Model { - | &Var: - let v = (&Var)(it.Expr.Model) - if v.Reference { - ref = true - self.oc.ec.model(it.Expr.Model) - break - } - fall - |: - if opt::Copy && isCopyOptimizable(it.Expr) { - ref = true + if opt::Copy && isCopyOptimizable(it.Expr) { + ref = true + match type it.Expr.Model { + | &Var: + let v = (&Var)(it.Expr.Model) + if v.Reference { + self.oc.ec.model(it.Expr.Model) + break + } + fall + |: self.oc.write("&(") self.oc.ec.model(it.Expr.Model) self.oc.write(")") - } else { - self.oc.ec.model(it.Expr.Model) } + } else { + self.oc.ec.possibleRefExpr(it.Expr.Model) } self.oc.write(";\n") self.oc.indent() @@ -102,16 +101,18 @@ impl scopeCoder { } self.oc.write("begin();\n") self.oc.indent() - self.oc.write(begin) - self.oc.write(":;\n") - self.oc.indent() - self.oc.write("if (it != expr") + self.oc.write("auto expr_end = expr") if ref { self.oc.write("->") } else { self.oc.write(".") } - self.oc.write("end()) {\n") + self.oc.write("end();\n") + self.oc.indent() + self.oc.write(begin) + self.oc.write(":;\n") + self.oc.indent() + self.oc.write("if (it != expr_end) {\n") self.oc.addIndent() self.oc.indent() if it.KeyA != nil { @@ -180,24 +181,23 @@ impl scopeCoder { self.oc.indent() self.oc.write("auto expr = ") let mut ref = false - match type it.Expr.Model { - | &Var: - let v = (&Var)(it.Expr.Model) - if v.Reference { - ref = true - self.oc.ec.model(it.Expr.Model) - break - } - fall - |: - if opt::Copy && isCopyOptimizable(it.Expr) { - ref = true + if opt::Copy && isCopyOptimizable(it.Expr) { + ref = true + match type it.Expr.Model { + | &Var: + let v = (&Var)(it.Expr.Model) + if v.Reference { + self.oc.ec.model(it.Expr.Model) + break + } + fall + |: self.oc.write("&(") self.oc.ec.model(it.Expr.Model) self.oc.write(")") - } else { - self.oc.ec.model(it.Expr.Model) } + } else { + self.oc.ec.possibleRefExpr(it.Expr.Model) } self.oc.write(";\n") self.oc.indent() @@ -209,16 +209,18 @@ impl scopeCoder { } self.oc.write("begin();\n") self.oc.indent() - self.oc.write(begin) - self.oc.write(":;\n") - self.oc.indent() - self.oc.write("if (it != expr") + self.oc.write("auto expr_end = expr") if ref { self.oc.write("->") } else { self.oc.write(".") } - self.oc.write("end()) {\n") + self.oc.write("end();\n") + self.oc.indent() + self.oc.write(begin) + self.oc.write(":;\n") + self.oc.indent() + self.oc.write("if (it != expr_end) {\n") self.oc.addIndent() self.oc.indent() if it.KeyA != nil {