X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.project%2Fsrc%2Forg%2Fsimantics%2Fproject%2Ffeatures%2FDependencyValidationFeature.java;fp=bundles%2Forg.simantics.project%2Fsrc%2Forg%2Fsimantics%2Fproject%2Ffeatures%2FDependencyValidationFeature.java;h=ddaa2c88b905168fde21731757f3273053a9fe47;hp=45ca05be7e359c7d8dd856b37e233874a62b3a18;hb=0ae2b770234dfc3cbb18bd38f324125cf0faca07;hpb=24e2b34260f219f0d1644ca7a138894980e25b14 diff --git a/bundles/org.simantics.project/src/org/simantics/project/features/DependencyValidationFeature.java b/bundles/org.simantics.project/src/org/simantics/project/features/DependencyValidationFeature.java index 45ca05be7..ddaa2c88b 100644 --- a/bundles/org.simantics.project/src/org/simantics/project/features/DependencyValidationFeature.java +++ b/bundles/org.simantics.project/src/org/simantics/project/features/DependencyValidationFeature.java @@ -1,172 +1,172 @@ -/******************************************************************************* - * 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.project.features; - -import java.net.URI; -import java.net.URISyntaxException; -import java.util.ArrayList; -import java.util.Collection; - -import org.eclipse.core.runtime.CoreException; -import org.eclipse.core.runtime.IConfigurationElement; -import org.eclipse.core.runtime.IExecutableExtension; -import org.eclipse.core.runtime.IStatus; -import org.eclipse.core.runtime.Status; -import org.simantics.db.Resource; -import org.simantics.db.Session; -import org.simantics.db.VirtualGraph; -import org.simantics.db.WriteGraph; -import org.simantics.db.common.CommentMetadata; -import org.simantics.db.common.request.WriteRequest; -import org.simantics.db.common.utils.NameUtils; -import org.simantics.db.exception.AssumptionException; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.exception.ResourceNotFoundException; -import org.simantics.db.service.VirtualGraphSupport; -import org.simantics.layer0.Layer0; -import org.simantics.project.exception.ProjectException; -import org.simantics.project.ontology.ProjectResource; -import org.simantics.scl.reflection.OntologyVersions; - -/** - * A project feature for validating that a set of namespaces (URIs) are - * reachable in the database for which this feature is configured. - * - * The URIs are described as class arguments in the extension class spec (after - * ':' character). - * - * @author Tuukka Lehtonen - */ -public class DependencyValidationFeature extends AbstractProjectFeature implements IExecutableExtension { - - private String virtualGraphId; - private String[] uris = {}; - - public DependencyValidationFeature() { - } - - public DependencyValidationFeature(String virtualGraphId, String[] uris) { - this.virtualGraphId = virtualGraphId; - this.uris = uris; - } - - @Override - public void setInitializationData(IConfigurationElement config, String propertyName, Object data) - throws CoreException { - if (data instanceof String) { - // Expecting comma-separated list of URIs in the argument. - String[] uris = ((String) data).split(","); - if (uris.length > 0) { - for(int i=0;i nss = new ArrayList(); - Collection notFound = new ArrayList(); - - Resource project = getProject().get(); - String projectName = NameUtils.getSafeName(graph, project); - - ProjectResource PROJ = ProjectResource.getInstance(graph); - - ArrayList resourcesToLinkToProject = new ArrayList(); - - for (String uri : uris) { - // This will fail if the extension-specified URI does not exist - Resource namespaceRequirement = null; - try { - namespaceRequirement = graph.getResource(uri); - resourcesToLinkToProject.add(namespaceRequirement); - } catch (ResourceNotFoundException e) { - notFound.add(uri); - continue; - } - - for (Resource nsp : graph.getObjects(namespaceRequirement, PROJ.RequiresNamespace)) { - String ns = graph.getValue(nsp); - nss.add(ns); - } - - for (String ns : nss) { - try { - // This will fail if the namespace is not found. - graph.getResource(ns); - } catch (ResourceNotFoundException e) { - notFound.add(ns); - } - } - } - - if (!notFound.isEmpty()) { - StringBuilder sb = new StringBuilder(); - sb.append("Failed to locate the following namespaces required by project '"); - sb.append(projectName); - sb.append("':\n"); - for (String nf : notFound) { - sb.append("\t"); - sb.append(nf); - sb.append("\n"); - } - throw new AssumptionException(sb.toString()); - } - - // Ensure that the namespace requirements are linked to the project to - // make them discoverable by database queries. - linkTo(graph, project, resourcesToLinkToProject); - } - - protected void linkTo(WriteGraph graph, Resource target, ArrayList resourcesToLink) throws DatabaseException { - Layer0 L0 = Layer0.getInstance(graph); - for (Resource resource : resourcesToLink) { - if (!graph.hasStatement(target, L0.IsLinkedTo, resource)) - graph.claim(target, L0.IsLinkedTo, resource); - } - } - - @Override - public void deconfigure() throws ProjectException { - } - -} +/******************************************************************************* + * 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.project.features; + +import java.net.URI; +import java.net.URISyntaxException; +import java.util.ArrayList; +import java.util.Collection; + +import org.eclipse.core.runtime.CoreException; +import org.eclipse.core.runtime.IConfigurationElement; +import org.eclipse.core.runtime.IExecutableExtension; +import org.eclipse.core.runtime.IStatus; +import org.eclipse.core.runtime.Status; +import org.simantics.db.Resource; +import org.simantics.db.Session; +import org.simantics.db.VirtualGraph; +import org.simantics.db.WriteGraph; +import org.simantics.db.common.CommentMetadata; +import org.simantics.db.common.request.WriteRequest; +import org.simantics.db.common.utils.NameUtils; +import org.simantics.db.exception.AssumptionException; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.exception.ResourceNotFoundException; +import org.simantics.db.service.VirtualGraphSupport; +import org.simantics.layer0.Layer0; +import org.simantics.project.exception.ProjectException; +import org.simantics.project.ontology.ProjectResource; +import org.simantics.scl.reflection.OntologyVersions; + +/** + * A project feature for validating that a set of namespaces (URIs) are + * reachable in the database for which this feature is configured. + * + * The URIs are described as class arguments in the extension class spec (after + * ':' character). + * + * @author Tuukka Lehtonen + */ +public class DependencyValidationFeature extends AbstractProjectFeature implements IExecutableExtension { + + private String virtualGraphId; + private String[] uris = {}; + + public DependencyValidationFeature() { + } + + public DependencyValidationFeature(String virtualGraphId, String[] uris) { + this.virtualGraphId = virtualGraphId; + this.uris = uris; + } + + @Override + public void setInitializationData(IConfigurationElement config, String propertyName, Object data) + throws CoreException { + if (data instanceof String) { + // Expecting comma-separated list of URIs in the argument. + String[] uris = ((String) data).split(","); + if (uris.length > 0) { + for(int i=0;i nss = new ArrayList(); + Collection notFound = new ArrayList(); + + Resource project = getProject().get(); + String projectName = NameUtils.getSafeName(graph, project); + + ProjectResource PROJ = ProjectResource.getInstance(graph); + + ArrayList resourcesToLinkToProject = new ArrayList(); + + for (String uri : uris) { + // This will fail if the extension-specified URI does not exist + Resource namespaceRequirement = null; + try { + namespaceRequirement = graph.getResource(uri); + resourcesToLinkToProject.add(namespaceRequirement); + } catch (ResourceNotFoundException e) { + notFound.add(uri); + continue; + } + + for (Resource nsp : graph.getObjects(namespaceRequirement, PROJ.RequiresNamespace)) { + String ns = graph.getValue(nsp); + nss.add(ns); + } + + for (String ns : nss) { + try { + // This will fail if the namespace is not found. + graph.getResource(ns); + } catch (ResourceNotFoundException e) { + notFound.add(ns); + } + } + } + + if (!notFound.isEmpty()) { + StringBuilder sb = new StringBuilder(); + sb.append("Failed to locate the following namespaces required by project '"); + sb.append(projectName); + sb.append("':\n"); + for (String nf : notFound) { + sb.append("\t"); + sb.append(nf); + sb.append("\n"); + } + throw new AssumptionException(sb.toString()); + } + + // Ensure that the namespace requirements are linked to the project to + // make them discoverable by database queries. + linkTo(graph, project, resourcesToLinkToProject); + } + + protected void linkTo(WriteGraph graph, Resource target, ArrayList resourcesToLink) throws DatabaseException { + Layer0 L0 = Layer0.getInstance(graph); + for (Resource resource : resourcesToLink) { + if (!graph.hasStatement(target, L0.IsLinkedTo, resource)) + graph.claim(target, L0.IsLinkedTo, resource); + } + } + + @Override + public void deconfigure() throws ProjectException { + } + +}