
com.bpodgursky.jbool_expressions.rules.SimplifyAnd Maven / Gradle / Ivy
package com.bpodgursky.jbool_expressions.rules;
import com.google.common.collect.Lists;
import com.google.common.collect.Sets;
import com.bpodgursky.jbool_expressions.*;
import java.util.*;
public class SimplifyAnd extends Rule, K> {
@Override
public Expression applyInternal(And input) {
for (Expression expr : input.expressions) {
if (expr instanceof Literal) {
Literal l = (Literal) expr;
if (l.getValue()) {
return copyWithoutTrue(input);
} else {
return Literal.getFalse();
}
}
// succeed immediately if require something or its opposite
if( expr instanceof Not){
Expression notChild = ((Not)expr).getE();
for(Expression child: input.expressions){
if(child.equals(notChild)){
return Literal.getFalse();
}
}
}
}
return input;
}
private Expression copyWithoutTrue(And input){
List> copy = Lists.newArrayList();
for (Expression expr : input.expressions) {
if (expr instanceof Literal) {
Literal l = (Literal) expr;
if (l.getValue()) {
continue;
}
}
copy.add(expr);
}
if (copy.isEmpty()) {
return Literal.getTrue();
}
return And.of(copy);
}
@Override
protected boolean isApply(Expression input) {
return input instanceof And;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy