package org.simantics.scl.compiler.elaboration.expressions;
+import org.simantics.scl.compiler.compilation.CompilationContext;
import org.simantics.scl.compiler.elaboration.contexts.ReplaceContext;
import org.simantics.scl.compiler.elaboration.contexts.SimplificationContext;
import org.simantics.scl.compiler.elaboration.contexts.TranslationContext;
import org.simantics.scl.compiler.elaboration.contexts.TypingContext;
-import org.simantics.scl.compiler.environment.Environment;
import org.simantics.scl.compiler.errors.Locations;
import org.simantics.scl.compiler.internal.codegen.references.IVal;
import org.simantics.scl.compiler.internal.codegen.writer.CodeWriter;
}
@Override
- public IVal toVal(Environment env, CodeWriter w) {
- IVal conditionVal = condition.toVal(env, w);
+ public IVal toVal(CompilationContext context, CodeWriter w) {
+ IVal conditionVal = condition.toVal(context, w);
CodeWriter joinPoint = w.createBlock(getType());
CodeWriter thenBlock = w.createBlock();
if(else_ != null) {
CodeWriter elseBlock = w.createBlock();
w.if_(conditionVal, thenBlock.getContinuation(), elseBlock.getContinuation());
- IVal elseVal = else_.toVal(env, elseBlock);
+ IVal elseVal = else_.toVal(context, elseBlock);
elseBlock.jump(joinPoint.getContinuation(), elseVal);
}
else {
w.if_(conditionVal, thenBlock.getContinuation(), joinPoint.getContinuation());
}
- IVal thenVal = then_.toVal(env, thenBlock);
+ IVal thenVal = then_.toVal(context, thenBlock);
thenBlock.jump(joinPoint.getContinuation(), thenVal);
w.continueAs(joinPoint);