X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.db.layer0%2Fsrc%2Forg%2Fsimantics%2Fdb%2Flayer0%2FQueryIndexUtils.java;fp=bundles%2Forg.simantics.db.layer0%2Fsrc%2Forg%2Fsimantics%2Fdb%2Flayer0%2FQueryIndexUtils.java;h=4a066a30c06b817cf186e93eeb2701567d8d6fc7;hp=0000000000000000000000000000000000000000;hb=a57dcc8e1a200d33fec06da5edffb064f286a82f;hpb=d299155927a09469473e029cb9bdc22f11a9a827 diff --git a/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/QueryIndexUtils.java b/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/QueryIndexUtils.java new file mode 100644 index 000000000..4a066a30c --- /dev/null +++ b/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/QueryIndexUtils.java @@ -0,0 +1,95 @@ +package org.simantics.db.layer0; + +import java.util.ArrayList; +import java.util.Collection; +import java.util.List; + +import org.simantics.datatypes.literal.GUID; +import org.simantics.db.ReadGraph; +import org.simantics.db.Resource; +import org.simantics.db.common.procedure.adapter.TransientCacheListener; +import org.simantics.db.common.utils.NameUtils; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.layer0.adapter.Instances; +import org.simantics.db.layer0.adapter.impl.EntityInstances.QueryIndex; +import org.simantics.db.layer0.util.Layer0Utils; +import org.simantics.layer0.Layer0; +import org.simantics.scl.runtime.function.Function1; +import org.simantics.utils.datastructures.Triple; + +public final class QueryIndexUtils { + + public static List searchByTypeShallow(ReadGraph graph, Resource model, Resource type) throws DatabaseException { + return graph.syncRequest(new QueryIndex(model, type, ""), TransientCacheListener.>instance()); + } + + public static List searchByType(ReadGraph graph, Resource model, Resource type) throws DatabaseException { + Instances query = graph.adapt(type, Instances.class); + return Layer0Utils.sortByCluster(graph, query.find(graph, model)); + } + + public static List searchByGUID(ReadGraph graph, Resource indexRoot, GUID guid) throws DatabaseException { + return searchByGUID(graph, indexRoot, guid.indexString()); + } + + public static List searchByGUID(ReadGraph graph, Resource indexRoot, String indexString) throws DatabaseException { + return searchByQueryShallow(graph, indexRoot, "GUID:" + indexString); + } + + public static List searchByQueryShallow(ReadGraph graph, Resource model, String query) throws DatabaseException { + return graph.syncRequest(new QueryIndex(model, Layer0.getInstance(graph).Entity, query), TransientCacheListener.>instance()); + } + + public static List searchByQuery(ReadGraph graph, Resource model, String query) throws DatabaseException { + Instances instances = graph.adapt(Layer0.getInstance(graph).Entity, Instances.class); + Collection queryResult = instances.find(graph, model, query); + return Layer0Utils.sortByCluster(graph, queryResult); + } + + public static List searchByTypeAndFilter(ReadGraph graph, Resource model, Resource type, Function1 filter) throws DatabaseException { + Instances query = graph.adapt(type, Instances.class); + ArrayList result = new ArrayList(); + for(Resource r : query.find(graph, model)) { + if(filter.apply(r)) + result.add(r); + } + return result; + } + + public static List> getIndexEntries(ReadGraph graph, Resource model, String filter) throws DatabaseException { + Layer0 L0 = Layer0.getInstance(graph); + List entries = searchByQuery(graph, model, filter); + List> listOfTriples = new ArrayList>(); + for (Resource entry : entries) { + Resource type = graph.getPossibleObject(entry, L0.InstanceOf); + String name = NameUtils.getSafeName(graph, entry); + listOfTriples.add(new Triple(entry, type, name)); + } + return listOfTriples; + } + + public static String listIndexEntries(ReadGraph graph, Resource model, String filter) throws DatabaseException { + List> listOfTriples = getIndexEntries(graph, model, filter); + StringBuilder sb = new StringBuilder(); + sb.append("== LISTING INDEX ENTRIES OF INDEX: " + NameUtils.getSafeName(graph, model) + ". AMOUNT OF ENTRIES: " + listOfTriples.size() + " ==\n"); + for (Triple entry : listOfTriples) { + String instanceOf = NameUtils.getSafeName(graph, entry.second); + sb.append("Name: " + entry.third + " instanceOf: " + instanceOf + " Resource: " + entry.first.toString() + "\n"); + } + return sb.toString(); + } + + public static List searchByTypeAndName(ReadGraph graph, Resource model, Resource type, String name) throws DatabaseException { + Instances query = graph.adapt(type, Instances.class); + ArrayList result = new ArrayList(); + for(Resource r : query.findByName(graph, model, name)) { + if(graph.isInstanceOf(r, type)) + result.add(r); + } + return result; + } + + public static List searchByTypeAndNameShallow(ReadGraph graph, Resource model, Resource type, String name) throws DatabaseException { + return graph.syncRequest(new QueryIndex(model, type, name), TransientCacheListener.>instance()); + } +}