diff --git a/src/de/dhbwstuttgart/bytecode/BytecodeGenMethod.java b/src/de/dhbwstuttgart/bytecode/BytecodeGenMethod.java index 3da49bca..5422fed2 100644 --- a/src/de/dhbwstuttgart/bytecode/BytecodeGenMethod.java +++ b/src/de/dhbwstuttgart/bytecode/BytecodeGenMethod.java @@ -110,7 +110,7 @@ public class BytecodeGenMethod implements StatementVisitor { } public BytecodeGenMethod(LambdaExpression lambdaExpression, ResultSet resultSet, MethodVisitor mv, - int indexOfFirstParamLam, boolean isInterface, HashMap classFiles, String path, int lamCounter) { + int indexOfFirstParamLam, boolean isInterface, HashMap classFiles, String path, int lamCounter, SourceFile sf) { this.resultSet = resultSet; this.mv = mv; @@ -118,6 +118,7 @@ public class BytecodeGenMethod implements StatementVisitor { this.classFiles = classFiles; this.path = path; this.lamCounter = lamCounter; + this.sf = sf; Iterator itr = lambdaExpression.params.iterator(); int i = indexOfFirstParamLam; while (itr.hasNext()) { @@ -378,6 +379,12 @@ public class BytecodeGenMethod implements StatementVisitor { case BIGGEREQUAL: mv.visitJumpInsn(Opcodes.IF_ICMPLT, branchLabel); break; + case EQUAL: + mv.visitJumpInsn(Opcodes.IF_ICMPNE, branchLabel); + break; + case NOTEQUAL: + mv.visitJumpInsn(Opcodes.IFEQ, branchLabel); + break; default: break; } @@ -403,6 +410,12 @@ public class BytecodeGenMethod implements StatementVisitor { case BIGGEREQUAL: mv.visitJumpInsn(Opcodes.IFLT, branchLabel); break; + case EQUAL: + mv.visitJumpInsn(Opcodes.IFNE, branchLabel); + break; + case NOTEQUAL: + mv.visitJumpInsn(Opcodes.IFEQ, branchLabel); + break; default: break; } @@ -567,7 +580,7 @@ public class BytecodeGenMethod implements StatementVisitor { methodName, arg3.toString(), null, null); new BytecodeGenMethod(lambdaExpression, this.resultSet, mvLambdaBody, indexOfFirstParamLam, isInterface, - classFiles,this.path, lamCounter); + classFiles,this.path, lamCounter, sf); mvLambdaBody.visitMaxs(0, 0); mvLambdaBody.visitEnd(); @@ -850,11 +863,13 @@ public class BytecodeGenMethod implements StatementVisitor { // methCallType = "L"+methCallType+";"; // } for(java.lang.reflect.Method m : methods) { - if(name.equals(m.getName()) && i == m.getParameterCount() && methCallType.equals(m.getReturnType().getName().replace(".", "/"))) { + if(name.equals(m.getName()) && i == m.getParameterCount() && + (methCallType.equals(m.getReturnType().getName().replace(".", "/")) || + m.getReturnType().getName().replace(".", "/").equals(Type.getInternalName(Object.class)))) { boolean typesEqual = true; Class[] pTypes = m.getParameterTypes(); for(int j = 0; j { - if(x<0) { - return 0; - }else if (x < 1) { - return x; - } - else { - return x * (fact.apply(x-1)); - } - }; + if (x == 1) { + return 1; + } + else { + return x * (fact.apply(x-1)); + } + }; } // m (x) {