X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.layer0.utils%2Fsrc%2Forg%2Fsimantics%2Flayer0%2Futils%2Fpredicates%2FDisjunction.java;h=26cf54697b5bda4d5abbb1a6f95cc91bbd2a8b5e;hb=refs%2Fchanges%2F69%2F1969%2F7;hp=5edb02a338c012d46aa3571169b7021acd5e66e4;hpb=969bd23cab98a79ca9101af33334000879fb60c5;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.layer0.utils/src/org/simantics/layer0/utils/predicates/Disjunction.java b/bundles/org.simantics.layer0.utils/src/org/simantics/layer0/utils/predicates/Disjunction.java index 5edb02a33..26cf54697 100644 --- a/bundles/org.simantics.layer0.utils/src/org/simantics/layer0/utils/predicates/Disjunction.java +++ b/bundles/org.simantics.layer0.utils/src/org/simantics/layer0/utils/predicates/Disjunction.java @@ -1,124 +1,124 @@ -/******************************************************************************* - * Copyright (c) 2007, 2010 Association for Decentralized Information Management - * in Industry THTH ry. - * All rights reserved. This program and the accompanying materials - * are made available under the terms of the Eclipse Public License v1.0 - * which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v10.html - * - * Contributors: - * VTT Technical Research Centre of Finland - initial API and implementation - *******************************************************************************/ -package org.simantics.layer0.utils.predicates; - -import java.util.Arrays; -import java.util.Collection; -import java.util.Collections; -import java.util.HashSet; -import java.util.Iterator; -import java.util.Set; - -import org.simantics.db.Resource; -import org.simantics.db.ReadGraph; -import org.simantics.db.WriteGraph; -import org.simantics.db.exception.DatabaseException; - -public class Disjunction extends UnaryPredicate { - - Collection predicates; - - public Disjunction(Collection predicates) { - this.predicates = predicates; - } - - public Disjunction(IUnaryPredicate ... predicates) { - this(Arrays.asList(predicates)); - } - - @Override - public Collection getResources(ReadGraph g) throws DatabaseException { - Iterator it = predicates.iterator(); - - while(it.hasNext()) { - Collection result = it.next().getResources(g); - if(!result.isEmpty()) { - while(it.hasNext()) { - Collection temp = it.next().getResources(g); - if(!temp.isEmpty()) { - Set merged = new HashSet(result.size() + temp.size()); - merged.addAll(result); - merged.addAll(temp); - while(it.hasNext()) - merged.addAll(it.next().getResources(g)); - return merged; - } - } - return result; - } - } - return Collections.emptyList(); - } - - @Override - public boolean has(ReadGraph g, Resource resource) throws DatabaseException { - for(IUnaryPredicate pred : predicates) - if(pred.has(g, resource)) - return true; - return false; - } - - @Override - public boolean supportsUnboundedQuery() { - for(IUnaryPredicate pred : predicates) - if(!pred.supportsUnboundedQuery()) - return false; - return true; - } - - @Override - public void add(WriteGraph g, Resource r) { - throw new UnsupportedOperationException(); - } - - @Override - public void remove(WriteGraph g, Resource r) { - throw new UnsupportedOperationException(); - } - - @Override - public boolean supportsAddition() { - return false; - } - - @Override - public boolean supportsRemoval() { - return false; - } - - @Override - public int hashCode() { - final int prime = 31; - int result = 1; - result = prime * result - + ((predicates == null) ? 0 : predicates.hashCode()); - return result; - } - - @Override - public boolean equals(Object obj) { - if (this == obj) - return true; - if (obj == null) - return false; - if (getClass() != obj.getClass()) - return false; - Disjunction other = (Disjunction) obj; - if (predicates == null) { - if (other.predicates != null) - return false; - } else if (!predicates.equals(other.predicates)) - return false; - return true; - } - -} +/******************************************************************************* + * Copyright (c) 2007, 2010 Association for Decentralized Information Management + * in Industry THTH ry. + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v1.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * VTT Technical Research Centre of Finland - initial API and implementation + *******************************************************************************/ +package org.simantics.layer0.utils.predicates; + +import java.util.Arrays; +import java.util.Collection; +import java.util.Collections; +import java.util.HashSet; +import java.util.Iterator; +import java.util.Set; + +import org.simantics.db.Resource; +import org.simantics.db.ReadGraph; +import org.simantics.db.WriteGraph; +import org.simantics.db.exception.DatabaseException; + +public class Disjunction extends UnaryPredicate { + + Collection predicates; + + public Disjunction(Collection predicates) { + this.predicates = predicates; + } + + public Disjunction(IUnaryPredicate ... predicates) { + this(Arrays.asList(predicates)); + } + + @Override + public Collection getResources(ReadGraph g) throws DatabaseException { + Iterator it = predicates.iterator(); + + while(it.hasNext()) { + Collection result = it.next().getResources(g); + if(!result.isEmpty()) { + while(it.hasNext()) { + Collection temp = it.next().getResources(g); + if(!temp.isEmpty()) { + Set merged = new HashSet(result.size() + temp.size()); + merged.addAll(result); + merged.addAll(temp); + while(it.hasNext()) + merged.addAll(it.next().getResources(g)); + return merged; + } + } + return result; + } + } + return Collections.emptyList(); + } + + @Override + public boolean has(ReadGraph g, Resource resource) throws DatabaseException { + for(IUnaryPredicate pred : predicates) + if(pred.has(g, resource)) + return true; + return false; + } + + @Override + public boolean supportsUnboundedQuery() { + for(IUnaryPredicate pred : predicates) + if(!pred.supportsUnboundedQuery()) + return false; + return true; + } + + @Override + public void add(WriteGraph g, Resource r) { + throw new UnsupportedOperationException(); + } + + @Override + public void remove(WriteGraph g, Resource r) { + throw new UnsupportedOperationException(); + } + + @Override + public boolean supportsAddition() { + return false; + } + + @Override + public boolean supportsRemoval() { + return false; + } + + @Override + public int hashCode() { + final int prime = 31; + int result = 1; + result = prime * result + + ((predicates == null) ? 0 : predicates.hashCode()); + return result; + } + + @Override + public boolean equals(Object obj) { + if (this == obj) + return true; + if (obj == null) + return false; + if (getClass() != obj.getClass()) + return false; + Disjunction other = (Disjunction) obj; + if (predicates == null) { + if (other.predicates != null) + return false; + } else if (!predicates.equals(other.predicates)) + return false; + return true; + } + +}