/**
* Disjunction
* Copyright 2014 by Michael Peter Christen
* First released 03.08.2014 at http://yacy.net
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program in the file lgpl21.txt
* If not, see <http://www.gnu.org/licenses/>.
*/
package net.yacy.cora.federate.solr.logic;
import org.apache.solr.common.SolrDocument;
/**
* A Disjunction is a desjunction of terms to Solr. The purpose of this class is,
* to provide a mechanism to reduce the calls to Solr when calling Solr several times with sets of
* terms which are all disjunctive.
*/
public class Disjunction extends AbstractOperations implements Operations {
public Disjunction() {
super("OR");
}
public Disjunction(final Term t1, final Term t2) {
super("OR");
this.addOperand(t1);
this.addOperand(t2);
}
@Override
public Object clone() {
Disjunction c = new Disjunction();
for (Term t: this.terms) c.addOperand(t);
return c;
}
@Override
public boolean equals(Object otherTerm) {
if (!(otherTerm instanceof Disjunction)) return false;
Disjunction o = (Disjunction) otherTerm;
for (Term t: this.terms) {
if (!TermTools.isIn(t, o.getOperands())) return false;
}
return true;
}
/**
* check if this disjunction matches with a given SolrDocument
* @param doc the SolrDocument to match to
* @return true, if all literals of this disjunction match with the terms of the document
*/
@Override
public boolean matches(SolrDocument doc) {
for (Term term: this.terms) {
if (term.matches(doc)) return true;
}
return false;
}
}