--- /dev/null
+package org.simantics.db.indexing;\r
+\r
+import java.util.Collections;\r
+import java.util.List;\r
+\r
+import org.simantics.db.ReadGraph;\r
+import org.simantics.db.Resource;\r
+import org.simantics.db.common.primitiverequest.Adapter;\r
+import org.simantics.db.common.procedure.adapter.TransientCacheListener;\r
+import org.simantics.db.common.request.BinaryRead;\r
+import org.simantics.db.exception.DatabaseException;\r
+import org.simantics.operation.Layer0X;\r
+import org.simantics.scl.runtime.function.Function;\r
+\r
+/**\r
+ * A (cacheable) query to optimize single index queries for immutable\r
+ * indexes such as ontologies.\r
+ */\r
+class QueryIndexResources extends BinaryRead<Resource, String, List<Resource>> {\r
+\r
+ public QueryIndexResources(Resource index, String filter) {\r
+ super(index, filter);\r
+ }\r
+\r
+ @Override\r
+ public List<Resource> perform(ReadGraph graph) throws DatabaseException {\r
+\r
+ Layer0X L0X = Layer0X.getInstance(graph);\r
+\r
+ @SuppressWarnings({ "unchecked", "rawtypes" })\r
+ Function dependencies = graph.syncRequest(new Adapter(L0X.DependencyResources, Function.class), TransientCacheListener.<Function>instance());\r
+\r
+ @SuppressWarnings("unchecked")\r
+ List<Resource> results = (List<Resource>)dependencies.apply(graph, parameter, parameter2);\r
+ if (results == null || results.isEmpty())\r
+ return Collections.emptyList();\r
+\r
+ return results;\r
+\r
+ }\r
+\r
+}
\ No newline at end of file