X-Git-Url: https://gerrit.simantics.org/r/gitweb?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=45ca05be7e359c7d8dd856b37e233874a62b3a18;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git 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 new file mode 100644 index 000000000..45ca05be7 --- /dev/null +++ b/bundles/org.simantics.project/src/org/simantics/project/features/DependencyValidationFeature.java @@ -0,0 +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 { + } + +}