]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.layer0.utils/src/org/simantics/layer0/utils/predicates/Disjunction.java
Fixed all line endings of the repository
[simantics/platform.git] / bundles / org.simantics.layer0.utils / src / org / simantics / layer0 / utils / predicates / Disjunction.java
index 5edb02a338c012d46aa3571169b7021acd5e66e4..26cf54697b5bda4d5abbb1a6f95cc91bbd2a8b5e 100644 (file)
-/*******************************************************************************\r
- * Copyright (c) 2007, 2010 Association for Decentralized Information Management\r
- * in Industry THTH ry.\r
- * All rights reserved. This program and the accompanying materials\r
- * are made available under the terms of the Eclipse Public License v1.0\r
- * which accompanies this distribution, and is available at\r
- * http://www.eclipse.org/legal/epl-v10.html\r
- *\r
- * Contributors:\r
- *     VTT Technical Research Centre of Finland - initial API and implementation\r
- *******************************************************************************/\r
-package org.simantics.layer0.utils.predicates;\r
-\r
-import java.util.Arrays;\r
-import java.util.Collection;\r
-import java.util.Collections;\r
-import java.util.HashSet;\r
-import java.util.Iterator;\r
-import java.util.Set;\r
-\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.ReadGraph;\r
-import org.simantics.db.WriteGraph;\r
-import org.simantics.db.exception.DatabaseException;\r
-\r
-public class Disjunction extends UnaryPredicate {\r
-\r
-       Collection<IUnaryPredicate> predicates;\r
-\r
-       public Disjunction(Collection<IUnaryPredicate> predicates) {\r
-               this.predicates = predicates;\r
-       }\r
-       \r
-       public Disjunction(IUnaryPredicate ... predicates) {\r
-           this(Arrays.asList(predicates));\r
-       }\r
-\r
-       @Override\r
-       public Collection<Resource> getResources(ReadGraph g) throws DatabaseException {\r
-               Iterator<IUnaryPredicate> it = predicates.iterator();\r
-               \r
-               while(it.hasNext()) {\r
-                       Collection<Resource> result = it.next().getResources(g);\r
-                       if(!result.isEmpty()) {\r
-                               while(it.hasNext()) {\r
-                                       Collection<Resource> temp = it.next().getResources(g);\r
-                                       if(!temp.isEmpty()) {\r
-                                               Set<Resource> merged = new HashSet<Resource>(result.size() + temp.size());\r
-                                               merged.addAll(result);\r
-                                               merged.addAll(temp);\r
-                                               while(it.hasNext())\r
-                                                       merged.addAll(it.next().getResources(g));\r
-                                               return merged;\r
-                                       }\r
-                               }\r
-                               return result;\r
-                       }\r
-               }\r
-               return Collections.emptyList();\r
-       }\r
-    \r
-       @Override\r
-       public boolean has(ReadGraph g, Resource resource) throws DatabaseException {\r
-               for(IUnaryPredicate pred : predicates)\r
-                       if(pred.has(g, resource))\r
-                               return true;\r
-               return false;\r
-       }\r
-\r
-       @Override\r
-       public boolean supportsUnboundedQuery() {               \r
-               for(IUnaryPredicate pred : predicates)\r
-                       if(!pred.supportsUnboundedQuery())\r
-                               return false;\r
-               return true;\r
-       }\r
-\r
-       @Override\r
-       public void add(WriteGraph g, Resource r) {\r
-               throw new UnsupportedOperationException();\r
-       }\r
-\r
-       @Override\r
-       public void remove(WriteGraph g, Resource r) {\r
-               throw new UnsupportedOperationException();\r
-       }\r
-\r
-       @Override\r
-       public boolean supportsAddition() {\r
-               return false;\r
-       }\r
-\r
-       @Override\r
-       public boolean supportsRemoval() {              \r
-               return false;\r
-       }\r
-\r
-       @Override\r
-       public int hashCode() {\r
-               final int prime = 31;\r
-               int result = 1;\r
-               result = prime * result\r
-                               + ((predicates == null) ? 0 : predicates.hashCode());\r
-               return result;\r
-       }\r
-\r
-       @Override\r
-       public boolean equals(Object obj) {\r
-               if (this == obj)\r
-                       return true;\r
-               if (obj == null)\r
-                       return false;\r
-               if (getClass() != obj.getClass())\r
-                       return false;\r
-               Disjunction other = (Disjunction) obj;\r
-               if (predicates == null) {\r
-                       if (other.predicates != null)\r
-                               return false;\r
-               } else if (!predicates.equals(other.predicates))\r
-                       return false;\r
-               return true;\r
-       }       \r
-       \r
-}\r
+/*******************************************************************************
+ * 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<IUnaryPredicate> predicates;
+
+       public Disjunction(Collection<IUnaryPredicate> predicates) {
+               this.predicates = predicates;
+       }
+       
+       public Disjunction(IUnaryPredicate ... predicates) {
+           this(Arrays.asList(predicates));
+       }
+
+       @Override
+       public Collection<Resource> getResources(ReadGraph g) throws DatabaseException {
+               Iterator<IUnaryPredicate> it = predicates.iterator();
+               
+               while(it.hasNext()) {
+                       Collection<Resource> result = it.next().getResources(g);
+                       if(!result.isEmpty()) {
+                               while(it.hasNext()) {
+                                       Collection<Resource> temp = it.next().getResources(g);
+                                       if(!temp.isEmpty()) {
+                                               Set<Resource> merged = new HashSet<Resource>(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;
+       }       
+       
+}