From 9ec77a95e02ad18811ea8ac246f7b4887275e8fd Mon Sep 17 00:00:00 2001 From: zaaarf Date: Fri, 3 Mar 2023 17:17:27 +0100 Subject: fix: fixed breaking bug in find method --- src/main/java/ftbsc/lll/tools/PatternMatcher.java | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) (limited to 'src/main/java/ftbsc/lll/tools/PatternMatcher.java') diff --git a/src/main/java/ftbsc/lll/tools/PatternMatcher.java b/src/main/java/ftbsc/lll/tools/PatternMatcher.java index 1b7d567..79539df 100644 --- a/src/main/java/ftbsc/lll/tools/PatternMatcher.java +++ b/src/main/java/ftbsc/lll/tools/PatternMatcher.java @@ -86,17 +86,16 @@ public class PatternMatcher { if(ignoreFrames && cur.getType() == AbstractInsnNode.FRAME) continue; if(ignoreLineNumbers && cur.getType() == AbstractInsnNode.LINE) continue; if(match == predicates.size()) { - last = cur.getPrevious(); //it was actually the preiovus run in this case - break; + last = cur.getPrevious(); //it was actually the previous run in this case + if(first != null && last != null) { + if(reverse) return new InsnSequence(last, first); + else return new InsnSequence(first, last); + } } else if (predicates.get(match).test(cur)) { match++; if(first == null) first = cur; - } else break; - } - if(first != null && last != null) { - if(reverse) return new InsnSequence(last, first); - else return new InsnSequence(first, last); + } else match = 0; } } throw new PatternNotFoundException("Failed to find pattern!"); -- cgit v1.2.3-56-ga3b1