net.sf.ehcache.search.expression.And Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ehcache-core Show documentation
Show all versions of ehcache-core Show documentation
Internal ehcache-core module. This artifact is not meant to be used directly for jdk 1.5
The newest version!
/**
* Copyright Terracotta, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.sf.ehcache.search.expression;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import net.sf.ehcache.Element;
import net.sf.ehcache.search.Attribute;
import net.sf.ehcache.search.attribute.AttributeExtractor;
/**
* A search criteria composed of the logical "and" of two or more other criteria
*
* @author teck
*/
public class And extends BaseCriteria {
private final Criteria[] criterion;
/**
* Simple constructor for two criteria
*
* @param lhs the left hand side of the "and" expression
* @param rhs the right hand side of the "and" expression
*/
public And(Criteria lhs, Criteria rhs) {
this.criterion = new Criteria[]{lhs, rhs};
}
private And(And original, Criteria additional) {
Criteria[] originalCriteria = original.getCriterion();
this.criterion = new Criteria[originalCriteria.length + 1];
System.arraycopy(originalCriteria, 0, criterion, 0, originalCriteria.length);
this.criterion[originalCriteria.length] = additional;
}
@Override
public Criteria and(Criteria other) {
return new And(this, other);
}
/**
* Return criterion
*
* @return criterion
*/
public Criteria[] getCriterion() {
return this.criterion;
}
/**
* {@inheritDoc}
*/
public boolean execute(Element e, Map attributeExtractors) {
for (Criteria c : criterion) {
if (!c.execute(e, attributeExtractors)) {
return false;
}
}
return true;
}
/**
* {@inheritDoc}
*/
public Set> getAttributes() {
Set> attrs = new HashSet>();
for (Criteria c: criterion) {
attrs.addAll(((BaseCriteria)c).getAttributes());
}
return attrs;
}
}