diff --git a/src/de/dhbwstuttgart/bytecode/BytecodeGenMethod.java b/src/de/dhbwstuttgart/bytecode/BytecodeGenMethod.java index 7cfd8e7d..ce5d3def 100644 --- a/src/de/dhbwstuttgart/bytecode/BytecodeGenMethod.java +++ b/src/de/dhbwstuttgart/bytecode/BytecodeGenMethod.java @@ -772,7 +772,19 @@ public class BytecodeGenMethod implements StatementVisitor { @Override public void visit(Return aReturn) { + if(aReturn.retexpr instanceof BinaryExpr) + isBinaryExp = true; + aReturn.retexpr.accept(this); + + if (isBinaryExp) { + BinaryExpr binary = (BinaryExpr) aReturn.retexpr; + String lexpType = getResolvedType(binary.lexpr.getType()); + String rexpType = getResolvedType(binary.rexpr.getType()); + getValueOfIns(getLargerType(lexpType, rexpType)); + isBinaryExp = false; + } + mv.visitInsn(Opcodes.ARETURN); } diff --git a/test/bytecode/OpTest.java b/test/bytecode/OpTest.java index 39bde2b3..1d213a78 100644 --- a/test/bytecode/OpTest.java +++ b/test/bytecode/OpTest.java @@ -29,7 +29,7 @@ public class OpTest { fileToTest = new File(path); compiler = new JavaTXCompiler(fileToTest); compiler.generateBytecode(); - pathToClassFile = System.getProperty("user.dir")+"/testBytecode/generatedBC/examples/"; + pathToClassFile = System.getProperty("user.dir")+"/testBytecode/generatedBC/"; loader = new URLClassLoader(new URL[] {new URL("file://"+pathToClassFile)}); classToTest = loader.loadClass("Op"); instanceOfClass = classToTest.getDeclaredConstructor().newInstance(); diff --git a/test/bytecode/javFiles/Op.jav b/test/bytecode/javFiles/Op.jav index 8092d18f..c01e7e6e 100644 --- a/test/bytecode/javFiles/Op.jav +++ b/test/bytecode/javFiles/Op.jav @@ -9,8 +9,8 @@ import java.lang.Byte; public class Op { - m(a,b) { - var c = a+b; - return c; + Integer m(Integer a, Integer b) { + //var c = a+b; + return a+b; } } \ No newline at end of file