summaryrefslogtreecommitdiff
path: root/base/src/main/java/bjc/utils/patterns/MutablePatternMatcher.java
diff options
context:
space:
mode:
authorBenjamin J. Culkin <bjculkin@mix.wvu.edu>2020-12-14 19:29:37 -0400
committerBenjamin J. Culkin <bjculkin@mix.wvu.edu>2020-12-14 19:29:37 -0400
commit9351ea3e97bbe2d348aa17067ccc6267dc7c080f (patch)
treedd2269c26161c735d94d8dc83d56e6076c2a155d /base/src/main/java/bjc/utils/patterns/MutablePatternMatcher.java
parent8933de7f646f0565edf700aa2f2fcab06d639855 (diff)
parent6dcadc360dafdd12142d53327f44579379a4c9dd (diff)
Merge branch 'master' of https://github.com/bculkin2442/bjc-utils2
Diffstat (limited to 'base/src/main/java/bjc/utils/patterns/MutablePatternMatcher.java')
-rw-r--r--base/src/main/java/bjc/utils/patterns/MutablePatternMatcher.java15
1 files changed, 8 insertions, 7 deletions
diff --git a/base/src/main/java/bjc/utils/patterns/MutablePatternMatcher.java b/base/src/main/java/bjc/utils/patterns/MutablePatternMatcher.java
index 7900262..28e9cd7 100644
--- a/base/src/main/java/bjc/utils/patterns/MutablePatternMatcher.java
+++ b/base/src/main/java/bjc/utils/patterns/MutablePatternMatcher.java
@@ -13,9 +13,10 @@ import bjc.data.*;
* @author Ben Culkin
*
* @param <ReturnType> The type returned by the pattern matcher.
+ * @param <InputType> The type of the input to match against.
*/
public class MutablePatternMatcher<ReturnType, InputType>
- implements IPatternMatcher<ReturnType, InputType>{
+ implements PatternMatcher<ReturnType, InputType> {
private final List<ComplexPattern<ReturnType, Object, InputType>> patterns;
/**
@@ -45,15 +46,15 @@ public class MutablePatternMatcher<ReturnType, InputType>
@Override
public ReturnType matchFor(InputType input) throws NonExhaustiveMatch {
Iterator<ComplexPattern<ReturnType, Object, InputType>> iterator;
- for (iterator = new NonCMEIterator<>(patterns);
- iterator.hasNext();) {
+ iterator = new NonCMEIterator<>(patterns);
+ while(iterator.hasNext()) {
ComplexPattern<ReturnType, Object, InputType> pattern = iterator.next();
- IPair<Boolean, Object> matches = pattern.matches(input);
+ Pair<Boolean, Object> matches = pattern.matches(input);
- if (matches.getLeft()) {
- pattern.apply(input, matches.getRight());
- }
+ matches.doWith((bool, obj) -> {
+ if (bool) pattern.apply(input, obj);
+ });
}
throw new NonExhaustiveMatch("Non-exhaustive match against " + input);