From e9dd7187f2e08301b3d1c05d95a5501cedc97fe4 Mon Sep 17 00:00:00 2001 From: Marc Miltenberger Date: Fri, 13 Dec 2024 22:27:18 +0100 Subject: [PATCH] .NET: Fix a problem for empty catch handlers --- .../soot/dotnet/instructions/CatchFilterHandlerBody.java | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/main/java/soot/dotnet/instructions/CatchFilterHandlerBody.java b/src/main/java/soot/dotnet/instructions/CatchFilterHandlerBody.java index 62ce2d585ba..e22024751e4 100644 --- a/src/main/java/soot/dotnet/instructions/CatchFilterHandlerBody.java +++ b/src/main/java/soot/dotnet/instructions/CatchFilterHandlerBody.java @@ -94,16 +94,19 @@ public Body getFilterHandlerBody(Value generalExceptionVariable) { ConditionExpr cond = Jimple.v().newEqExpr(returnValue, IntConstant.v(0)); IfStmt ifRetCondStmt = Jimple.v().newIfStmt(cond, filterCondFalseNop); // if ret==0 ignore handler // jump to end of filter instructions - cond true - GotoStmt gotoHandlerBodyCondTrueStmt = Jimple.v().newGotoStmt(handlerBody.getUnits().getFirst()); + if (!handlerBody.getUnits().isEmpty()) { + //this may happen when there is an empty handler + GotoStmt gotoHandlerBodyCondTrueStmt = Jimple.v().newGotoStmt(handlerBody.getUnits().getFirst()); - handlerFilterContainerBlockBody.getUnits().insertAfter(gotoHandlerBodyCondTrueStmt, returnStmt); + handlerFilterContainerBlockBody.getUnits().insertAfter(gotoHandlerBodyCondTrueStmt, returnStmt); + } handlerFilterContainerBlockBody.getUnits().swapWith(returnStmt, ifRetCondStmt); dotnetBody.blockEntryPointsManager.swapGotoEntryUnit(ifRetCondStmt, returnStmt); } jb.getUnits().addAll(handlerFilterContainerBlockBody.getUnits()); // handler body - if (lastStmtIsNotReturn(handlerBody)) { + if (handlerBody.getUnits().isEmpty() || lastStmtIsNotReturn(handlerBody)) { // if last stmt is not return, insert goto stmt, to go to end whole block handlerBody.getUnits().add(Jimple.v().newGotoStmt(nopStmtEnd)); }