X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;ds=sidebyside;f=bundles%2Forg.simantics.scenegraph.profile%2Fsrc%2Forg%2Fsimantics%2Fscenegraph%2Fprofile%2Frequest%2FRuntimeProfileActiveEntryResources.java;h=f59c1d71a0978addc151df7c0705e23543ffbeb2;hb=refs%2Fchanges%2F28%2F1728%2F2;hp=291c11326add548309ee6510566adfec82399e8e;hpb=969bd23cab98a79ca9101af33334000879fb60c5;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.scenegraph.profile/src/org/simantics/scenegraph/profile/request/RuntimeProfileActiveEntryResources.java b/bundles/org.simantics.scenegraph.profile/src/org/simantics/scenegraph/profile/request/RuntimeProfileActiveEntryResources.java index 291c11326..f59c1d71a 100644 --- a/bundles/org.simantics.scenegraph.profile/src/org/simantics/scenegraph/profile/request/RuntimeProfileActiveEntryResources.java +++ b/bundles/org.simantics.scenegraph.profile/src/org/simantics/scenegraph/profile/request/RuntimeProfileActiveEntryResources.java @@ -1,49 +1,70 @@ -/******************************************************************************* - * Copyright (c) 2007, 2010 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 - * which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v10.html - * - * Contributors: - * VTT Technical Research Centre of Finland - initial API and implementation - *******************************************************************************/ -package org.simantics.scenegraph.profile.request; - -import java.util.ArrayList; -import java.util.Collection; - -import org.simantics.db.ReadGraph; -import org.simantics.db.Resource; -import org.simantics.db.common.request.ResourceRead; -import org.simantics.db.exception.DatabaseException; -import org.simantics.diagram.stubs.DiagramResource; - -/** - * @author Antti Villberg - */ -public class RuntimeProfileActiveEntryResources extends ResourceRead> { - - public RuntimeProfileActiveEntryResources(Resource resource) { - super(resource); - } - - @Override - public Collection perform(ReadGraph graph) throws DatabaseException { - DiagramResource DIA = DiagramResource.getInstance(graph); - - ArrayList result = new ArrayList(); - Resource activeProfile = graph.getPossibleObject(resource, DIA.RuntimeDiagram_HasRuntimeProfile); - if (activeProfile == null) - return result; - - Resource rootEntries = graph.getPossibleObject(activeProfile, DIA.HasEntries); - if (rootEntries == null) - return result; - - return graph.syncRequest(new ProfileActiveEntryResources(activeProfile, rootEntries)); - - } - -} +/******************************************************************************* + * Copyright (c) 2007, 2010 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 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * VTT Technical Research Centre of Finland - initial API and implementation + *******************************************************************************/ +package org.simantics.scenegraph.profile.request; + +import java.util.ArrayList; +import java.util.Collection; +import java.util.List; + +import org.simantics.db.ReadGraph; +import org.simantics.db.Resource; +import org.simantics.db.common.NamedResource; +import org.simantics.db.common.request.ResourceRead; +import org.simantics.db.exception.DatabaseException; +import org.simantics.diagram.stubs.DiagramResource; +import org.simantics.scenegraph.profile.ProfileUtils; + +/** + * @author Antti Villberg + */ +public class RuntimeProfileActiveEntryResources extends ResourceRead> { + + public RuntimeProfileActiveEntryResources(Resource resource) { + super(resource); + } + + @Override + public Collection perform(ReadGraph graph) throws DatabaseException { + DiagramResource DIA = DiagramResource.getInstance(graph); + + ArrayList result = new ArrayList(); + + result.addAll(graph.syncRequest(new ProfileEntryContributions(resource))); + + Resource activeProfile = graph.getPossibleObject(resource, DIA.RuntimeDiagram_HasRuntimeProfile); + if (activeProfile == null) { + + List available = graph.syncRequest(new AvailableProfiles(resource)); + if(available.size() != 1) return result; + + activeProfile = available.iterator().next().getResource(); + + } + + Resource rootEntries = graph.getPossibleObject(activeProfile, DIA.HasEntries); + if (rootEntries == null) + return result; + + if(graph.isImmutable(activeProfile)) { + Resource activationState = ProfileUtils.getPossibleProfileActivationState(graph, resource, activeProfile); + if(activationState != null) { + result.addAll(graph.syncRequest(new ProfileActiveEntryResources(activationState, rootEntries))); + } + } else { + result.addAll(graph.syncRequest(new ProfileActiveEntryResources(activeProfile, rootEntries))); + } + + return result; + + } + +}