import org.simantics.db.impl.graph.ReadGraphImpl;
import org.simantics.db.impl.procedure.InternalProcedure;
-public class URIToResource extends StringQuery<InternalProcedure<Integer>> {
+public class URIToResource extends StringQuery<InternalProcedure<Integer>> implements InternalProcedure<Integer> {
URIToResource(final String id) {
super(id);
provider.cache.remove(this);
}
- @Override
+ //@Override
public Object compute(ReadGraphImpl graph, final InternalProcedure<Integer> procedure) throws DatabaseException {
computeForEach(graph, id, this, procedure);
return getResult();
}
- static void computeForEach(ReadGraphImpl graph, String id, final URIToResource entry, final InternalProcedure<Integer> procedure) throws DatabaseException {
+ static void computeForEach(ReadGraphImpl graph, String id, final URIToResource entry, final InternalProcedure<Integer> procedure_) throws DatabaseException {
+
+ InternalProcedure<Integer> procedure = entry != null ? entry : procedure_;
if("http://".equals(id) || "http:/".equals(id)) {
QueryProcessor processor = graph.processor;
- if(entry != null) entry.addOrSet(graph, processor, processor.getRootLibrary());
procedure.execute(graph, processor.getRootLibrary());
} else {
final String[] parts = URIStringUtils.splitURI(id);
if (parts != null) {
- Integer parentId = QueryCache.resultURIToResource(graph, parts[0], entry, null);
- ObjectResourceIdMap<String> map = QueryCache.resultChildMap(graph, parentId, entry, null);
- if(map == null) {
- procedure.execute(graph, 0);
- if(entry != null) entry.addOrSet(graph, graph.processor, 0);
- } else {
- int result = map.getId(URIStringUtils.unescape(parts[1]));
- if(entry != null) entry.addOrSet(graph, graph.processor, result);
- procedure.execute(graph, result);
- }
+ QueryCache.runnerURIToResource(graph, parts[0], entry, null, new InternalProcedure<Integer>() {
+
+ @Override
+ public void execute(ReadGraphImpl graph, Integer parentId) throws DatabaseException {
+
+ ObjectResourceIdMap<String> map = QueryCache.resultChildMap(graph, parentId, entry, null);
+ assert(map != null);
+ int result = map.getId(URIStringUtils.unescape(parts[1]));
+ if (result == 0) {
+ ResourceNotFoundException e = new ResourceNotFoundException("No resource for URI: " + id);
+ procedure.exception(graph, e);
+ } else {
+ procedure.execute(graph, result);
+ }
+ }
+
+ @Override
+ public void exception(ReadGraphImpl graph, Throwable throwable) throws DatabaseException {
+ procedure.exception(graph, throwable);
+ }
+
+ });
+
} else {
-
ResourceNotFoundException e = new ResourceNotFoundException("No resource for URI: " + id);
- if(entry != null) entry.except(e);
- procedure.exception(graph, e);
-
+ procedure.exception(graph, e);
}
}
+ if(entry != null) entry.performFromCache(graph, procedure_);
+
}
- public void addOrSet(ReadGraphImpl graph, QueryProcessor provider, Integer result) {
+ public void addOrSet(Integer result) {
assert(isPending());
assert(isReady());
- if(handleException(graph, procedure)) return (Throwable)statusOrException;
+ if(handleException(graph, procedure)) return (Throwable)getResult();
Integer result = (Integer)getResult();
procedure.execute(graph, result);
});
}
+
+ @Override
+ public void execute(ReadGraphImpl graph, Integer result) throws DatabaseException {
+ synchronized(this) {
+ setResult(result);
+ setReady();
+ }
+ }
+
+ @Override
+ public void exception(ReadGraphImpl graph, Throwable throwable) throws DatabaseException {
+ except(throwable);
+ }
}