X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.db.impl%2Fsrc%2Forg%2Fsimantics%2Fdb%2Fimpl%2Fquery%2FAssertedPredicates.java;h=b4104e965fbc0b56be90fc40a8f0cd07eef5ab3a;hb=de8b6e194da6d56c410101d9c72763078b0e8717;hp=184276412f7a3251690dd62b72be51c67eeceb1f;hpb=880a8a4927805afbbf47005a807cef3f39406866;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.db.impl/src/org/simantics/db/impl/query/AssertedPredicates.java b/bundles/org.simantics.db.impl/src/org/simantics/db/impl/query/AssertedPredicates.java index 184276412..b4104e965 100644 --- a/bundles/org.simantics.db.impl/src/org/simantics/db/impl/query/AssertedPredicates.java +++ b/bundles/org.simantics.db.impl/src/org/simantics/db/impl/query/AssertedPredicates.java @@ -15,11 +15,9 @@ import org.simantics.db.RelationInfo; import org.simantics.db.exception.DatabaseException; import org.simantics.db.impl.graph.ReadGraphImpl; import org.simantics.db.impl.procedure.IntProcedureAdapter; -import org.simantics.db.impl.procedure.InternalProcedure; -import org.simantics.db.procedure.ListenerBase; -final public class AssertedPredicates extends CollectionUnaryQuery { +final public class AssertedPredicates extends UnaryQuery { AssertedPredicates(final int r) { super(r); @@ -28,11 +26,21 @@ final public class AssertedPredicates extends CollectionUnaryQuery public static AssertedPredicates newInstance(final int r) { return new AssertedPredicates(r); } - -// final public static void queryEach(ReadGraphImpl graph, final int r, final QueryProcessor provider, final CacheEntry parent, final ListenerBase listener, final IntProcedure procedure) throws DatabaseException { -// QueryCache.runnerAssertedPredicates(graph, r, parent, listener, procedure); -// } + @Override + final public void clearResult(QuerySupport support) { + setResult(new IntArray()); + } + + @Override + final public void setReady() { + super.setReady(); + IntArray v = (IntArray)getResult(); + int size = v.size(); + if(size == 0) setResult(IntArray.EMPTY); + else v.trim(); + } + @Override final public void removeEntry(QueryProcessor provider) { provider.cache.remove(this);