X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.issues.common%2Fsrc%2Forg%2Fsimantics%2Fissues%2Fcommon%2FAllActiveIssues.java;h=006e779d47cb105311e11bf66906ca2c1c4de85a;hp=72728018561bcb598967ca78fe8b4abebda74c5d;hb=1ae2c52a087a20a7fc9c0288b7e2398b4429e20e;hpb=158d6269660a3b415504f1da5a0b8341e761a5be diff --git a/bundles/org.simantics.issues.common/src/org/simantics/issues/common/AllActiveIssues.java b/bundles/org.simantics.issues.common/src/org/simantics/issues/common/AllActiveIssues.java index 727280185..006e779d4 100644 --- a/bundles/org.simantics.issues.common/src/org/simantics/issues/common/AllActiveIssues.java +++ b/bundles/org.simantics.issues.common/src/org/simantics/issues/common/AllActiveIssues.java @@ -1,5 +1,5 @@ /******************************************************************************* - * Copyright (c) 2007, 2010 Association for Decentralized Information Management + * Copyright (c) 2007, 2019 Association for Decentralized Information Management * in Industry THTH ry. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 @@ -8,11 +8,11 @@ * * Contributors: * VTT Technical Research Centre of Finland - initial API and implementation + * Semantum Oy - Reorganization *******************************************************************************/ package org.simantics.issues.common; -import gnu.trove.set.hash.THashSet; - +import java.util.List; import java.util.Set; import org.simantics.db.ReadGraph; @@ -20,12 +20,13 @@ import org.simantics.db.Resource; import org.simantics.db.common.request.ObjectsWithType; import org.simantics.db.common.request.ResourceRead; import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.adapter.Instances; -import org.simantics.issues.ontology.IssueResource; -import org.simantics.layer0.Layer0; import org.simantics.operation.Layer0X; +import org.simantics.scl.db.SCLFunctions; +import org.simantics.scl.runtime.tuple.Tuple0; import org.simantics.simulation.ontology.SimulationResource; +import gnu.trove.set.hash.THashSet; + /** * @author Antti Villberg */ @@ -37,20 +38,23 @@ public class AllActiveIssues extends ResourceRead> { @Override public Set perform(ReadGraph graph) throws DatabaseException { - Layer0 L0 = Layer0.getInstance(graph); + Layer0X L0X = Layer0X.getInstance(graph); - IssueResource ISSUE = IssueResource.getInstance(graph); SimulationResource SIMU = SimulationResource.getInstance(graph); - Set result = new THashSet(); - Instances indexedIssues = graph.getPossibleAdapter(ISSUE.Issue, Instances.class); + Set result = new THashSet<>(); + for (Resource model : graph.syncRequest(new ObjectsWithType(resource, L0X.Activates, SIMU.Model))) { - for (Resource issue : graph.syncRequest(new ObjectsWithType(model, L0.ConsistsOf, ISSUE.Issue))) { - result.add(issue); - } - if (indexedIssues != null) - result.addAll(indexedIssues.find(graph, model)); + result.addAll(graph.syncRequest(new AllModelIssues(model, false))); } + + List libraries = SCLFunctions.evaluateDB("Simantics/SharedOntologies", "getSharedOntologies", Tuple0.INSTANCE); + + for (Resource library : libraries) { + result.addAll(graph.syncRequest(new AllModelIssues(library, false))); + } + return result; + } }