From c2fd879a93f69c1c176c5dd10facbd430f6b146c Mon Sep 17 00:00:00 2001 From: kindlich Date: Sat, 14 Sep 2024 23:41:51 +0200 Subject: [PATCH] Cleanup: Apply some things seen during the code-review --- .../javabytecode/compiler/JavaFieldBytecodeCompiler.java | 5 ++--- .../compiler/JavaNonPushingExpressionVisitor.java | 7 +++---- ...edExpressionVisitorToAccessCapturesInsideTheLambda.java | 5 +++-- 3 files changed, 8 insertions(+), 9 deletions(-) diff --git a/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/JavaFieldBytecodeCompiler.java b/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/JavaFieldBytecodeCompiler.java index 40d553a13..68309f822 100644 --- a/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/JavaFieldBytecodeCompiler.java +++ b/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/JavaFieldBytecodeCompiler.java @@ -1,16 +1,15 @@ package org.openzen.zenscript.javabytecode.compiler; import org.openzen.zenscript.codemodel.expression.Expression; -import org.openzen.zenscript.codemodel.expression.ExpressionVisitor; import org.openzen.zenscript.codemodel.type.builtin.BuiltinFieldSymbol; import org.openzen.zenscript.javashared.*; public class JavaFieldBytecodeCompiler implements JavaFieldCompiler { private final JavaWriter javaWriter; - private final ExpressionVisitor expressionVisitor; + private final JavaExpressionVisitor expressionVisitor; private final boolean pushing; - public JavaFieldBytecodeCompiler(JavaWriter javaWriter, ExpressionVisitor expressionVisitor, boolean pushing) { + public JavaFieldBytecodeCompiler(JavaWriter javaWriter, JavaExpressionVisitor expressionVisitor, boolean pushing) { this.javaWriter = javaWriter; this.expressionVisitor = expressionVisitor; this.pushing = pushing; diff --git a/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/JavaNonPushingExpressionVisitor.java b/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/JavaNonPushingExpressionVisitor.java index e071c1bb0..f40b25b49 100644 --- a/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/JavaNonPushingExpressionVisitor.java +++ b/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/JavaNonPushingExpressionVisitor.java @@ -24,11 +24,11 @@ public class JavaNonPushingExpressionVisitor implements ExpressionVisitor private final JavaBytecodeContext context; private final JavaCompiledModule module; private final JavaWriter javaWriter; - private final ExpressionVisitor original; + private final JavaExpressionVisitor original; private final JavaFieldBytecodeCompiler fieldCompiler; private final JavaMangler mangler; - public JavaNonPushingExpressionVisitor(JavaBytecodeContext context, JavaCompiledModule module, JavaWriter javaWriter, JavaMangler mangler, ExpressionVisitor original) { + public JavaNonPushingExpressionVisitor(JavaBytecodeContext context, JavaCompiledModule module, JavaWriter javaWriter, JavaMangler mangler, JavaExpressionVisitor original) { this.context = context; this.module = module; this.javaWriter = javaWriter; @@ -335,8 +335,7 @@ public Void visitPlatformSpecific(Expression expression) { @Override public Void visitModification(ModificationExpression expression) { - // Todo: fix cast - ((JavaExpressionVisitor)original).modify(expression, PushOption.NONE); + original.modify(expression, PushOption.NONE); return null; } diff --git a/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/capturing/JavaCapturedExpressionVisitorToAccessCapturesInsideTheLambda.java b/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/capturing/JavaCapturedExpressionVisitorToAccessCapturesInsideTheLambda.java index 4d8acfc19..fd034bdab 100644 --- a/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/capturing/JavaCapturedExpressionVisitorToAccessCapturesInsideTheLambda.java +++ b/JavaBytecodeCompiler/src/main/java/org/openzen/zenscript/javabytecode/compiler/capturing/JavaCapturedExpressionVisitorToAccessCapturesInsideTheLambda.java @@ -8,7 +8,7 @@ import org.openzen.zenscript.javabytecode.compiler.JavaWriter; /** - * {@link CapturedExpressionVisitor} used to inside a lambda expression. + * {@link CapturedExpressionVisitor} used to access captured values inside a lambda expression. */ public class JavaCapturedExpressionVisitorToAccessCapturesInsideTheLambda implements CapturedExpressionVisitor { @@ -41,6 +41,7 @@ public Void visitCapturedThis(CapturedThisExpression expression) { @Override public Void visitCapturedParameter(CapturedParameterExpression expression) { final int position = calculateMemberPosition(expression, this.functionExpression); + javaWriter.loadObject(0); javaWriter.getField(lambdaClassName, this.javaMangler.mangleCapturedParameter(position, false), context.getDescriptor(expression.parameter.type)); return null; @@ -57,7 +58,7 @@ public Void visitCapturedLocal(CapturedLocalVariableExpression expression) { @Override public Void visitRecaptured(CapturedClosureExpression expression) { - int position = findIndex(expression); + final int position = findIndex(expression); javaWriter.loadObject(0); javaWriter.getField(lambdaClassName, this.javaMangler.mangleCapturedParameter(position, false), context.getDescriptor(expression.type));