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=8013c1a47d2c0684e0a5a2cf1a3084ab079fcde6;hpb=1cb58fb59cd64891c682a7e7b04e00af9e3be575;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 8013c1a47..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); @@ -82,7 +90,7 @@ final public class AssertedPredicates extends CollectionUnaryQuery } - @Override + //@Override public Object compute(ReadGraphImpl graph, final IntProcedure proc) throws DatabaseException { QueryProcessor processor = graph.processor; @@ -160,40 +168,16 @@ final public class AssertedPredicates extends CollectionUnaryQuery } - final static InternalProcedure ip = new InternalProcedure() { - - @Override - public void execute(ReadGraphImpl graph, RelationInfo result) { - } - - @Override - public void exception(ReadGraphImpl graph, Throwable throwable) { - } - - }; - - final static InternalProcedure ip2 = new InternalProcedure() { - - @Override - public void execute(ReadGraphImpl graph, IntSet result) { - } - - @Override - public void exception(ReadGraphImpl graph, Throwable throwable) { - } - - }; - synchronized private void addOrSetHiding(ReadGraphImpl graph, int add, CacheEntry parent) throws DatabaseException { assert(isPending()); IntArray value = (IntArray)getResult(); - RelationInfo ri = QueryCacheBase.resultRelationInfoQuery(graph, add, parent, null, ip); + RelationInfo ri = QueryCacheBase.resultRelationInfoQuery(graph, add, parent, null); if(ri.isFunctional) { // Replace existing functional predicate if found try { - IntSet supers = QueryCache.resultSuperRelations(graph, add, parent, null, ip2); + IntSet supers = QueryCache.resultSuperRelations(graph, add, parent, null); if(value.data == null) { if(value.sizeOrData != IntArray.NO_DATA) { if(supers.contains(value.sizeOrData)) {