1 /*******************************************************************************
\r
2 * Copyright (c) 2007, 2010 Association for Decentralized Information Management
\r
3 * in Industry THTH ry.
\r
4 * All rights reserved. This program and the accompanying materials
\r
5 * are made available under the terms of the Eclipse Public License v1.0
\r
6 * which accompanies this distribution, and is available at
\r
7 * http://www.eclipse.org/legal/epl-v10.html
\r
10 * VTT Technical Research Centre of Finland - initial API and implementation
\r
11 *******************************************************************************/
\r
12 package org.simantics.db.impl.query;
\r
14 import java.util.concurrent.Semaphore;
\r
16 import org.simantics.db.common.exception.DebugException;
\r
17 import org.simantics.db.impl.graph.ReadGraphImpl;
\r
18 import org.simantics.db.impl.procedure.IntProcedureAdapter;
\r
19 import org.simantics.db.procedure.ListenerBase;
\r
21 final public class DirectPredicates extends CollectionUnaryQuery<IntProcedure> {
\r
23 private DirectPredicates(final int resource) {
\r
27 final static DirectPredicates entry(final QueryProcessor provider, final int r) {
\r
29 return (DirectPredicates)provider.directPredicatesMap.get(r);
\r
33 final static void runner(ReadGraphImpl graph, final int r, final QueryProcessor provider, final CacheEntry parent, final ListenerBase listener, final IntProcedure procedure) {
\r
35 DirectPredicates entry = (DirectPredicates)provider.directPredicatesMap.get(r);
\r
38 entry = new DirectPredicates(r);
\r
40 entry.clearResult(provider.querySupport);
\r
41 entry.putEntry(provider);
\r
43 provider.performForEach(graph, entry, parent, listener, procedure);
\r
47 if(!entry.isReady()) {
\r
48 synchronized(entry) {
\r
49 if(!entry.isReady()) {
\r
50 provider.registerDependencies(graph, entry, parent, listener, procedure, false);
\r
51 entry.computeForEach(graph, provider, procedure, true);
\r
57 provider.performForEach(graph, entry, parent, listener, procedure);
\r
63 final public static void queryEach(ReadGraphImpl graph, final int r, final QueryProcessor provider, final CacheEntry parent, final ListenerBase listener, final IntProcedure procedure) {
\r
65 if(parent == null && listener == null) {
\r
66 DirectPredicates entry = (DirectPredicates)provider.directPredicatesMap.get(r);
\r
67 if(entry != null && entry.isReady()) {
\r
68 entry.performFromCache(graph, provider, procedure);
\r
71 computeForEach(graph, r, null, procedure, false);
\r
76 runner(graph, r, provider, parent, listener, procedure);
\r
82 public void clearResult(QuerySupport support) {
\r
83 // The cached result is never used
\r
84 setResult(INVALID_RESULT);
\r
88 public UnaryQuery<IntProcedure> getEntry(QueryProcessor provider) {
\r
89 return provider.directPredicatesMap.get(id);
\r
93 public void putEntry(QueryProcessor provider) {
\r
94 provider.directPredicatesMap.put(id, this);
\r
98 final public void removeEntry(QueryProcessor provider) {
\r
99 provider.directPredicatesMap.remove(id);
\r
103 public Object computeForEach(ReadGraphImpl graph, QueryProcessor provider, IntProcedure procedure, boolean store) {
\r
104 return computeForEach(graph, id, this, procedure, store);
\r
107 public static Object computeForEach(ReadGraphImpl graph, int id, final DirectPredicates entry, final IntProcedure procedure, final boolean store) {
\r
109 graph.processor.querySupport.ensureLoaded(graph, id);
\r
111 final IntArray list = new IntArray();
\r
113 graph.processor.querySupport.getPredicates(graph, id, new IntProcedure() {
\r
116 public void execute(ReadGraphImpl graph, int i) {
\r
121 public void finished(ReadGraphImpl graph) {
\r
125 public void exception(ReadGraphImpl graph, Throwable t) {
\r
126 if(DebugException.DEBUG) new DebugException(t).printStackTrace();
\r
132 entry.finish(graph, graph.processor);
\r
134 if(list.data == null) {
\r
135 if(list.sizeOrData != IntArray.NO_DATA) procedure.execute(graph, list.sizeOrData);
\r
137 for(int i = 0;i < list.sizeOrData ; i++) procedure.execute(graph, list.data[i]);
\r
140 procedure.finished(graph);
\r
147 public String toString() {
\r
148 return "DirectPredicates[" + id + "]";
\r
152 public void setReady() {
\r
153 statusOrException = READY;
\r
156 final private void finish(ReadGraphImpl graph, QueryProcessor provider) {
\r
163 public Object performFromCache(ReadGraphImpl graph, QueryProcessor provider, IntProcedure procedure) {
\r
167 return computeForEach(graph, provider, procedure, false);
\r
172 public void recompute(ReadGraphImpl graph, QueryProcessor provider) {
\r
174 final Semaphore s = new Semaphore(0);
\r
176 computeForEach(graph, provider, new IntProcedureAdapter() {
\r
179 public void finished(ReadGraphImpl graph) {
\r
184 public void exception(ReadGraphImpl graph, Throwable t) {
\r
186 new Error("Error in recompute.", t).printStackTrace();
\r
191 while(!s.tryAcquire()) {
\r
192 provider.resume(graph);
\r
199 boolean isImmutable(ReadGraphImpl graph) {
\r
200 return graph.processor.isImmutable(id);
\r