X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.db.layer0%2Fsrc%2Forg%2Fsimantics%2Fdb%2Flayer0%2Fvalidation%2FValidationUtils.java;fp=bundles%2Forg.simantics.db.layer0%2Fsrc%2Forg%2Fsimantics%2Fdb%2Flayer0%2Fvalidation%2FValidationUtils.java;h=b5ea24686b4daeb7f2c7111bc14b748d348dfee9;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/validation/ValidationUtils.java b/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/validation/ValidationUtils.java new file mode 100644 index 000000000..b5ea24686 --- /dev/null +++ b/bundles/org.simantics.db.layer0/src/org/simantics/db/layer0/validation/ValidationUtils.java @@ -0,0 +1,81 @@ +package org.simantics.db.layer0.validation; + +import gnu.trove.set.hash.THashSet; + +import java.util.Collections; +import java.util.List; +import java.util.Map; +import java.util.Set; + +import org.simantics.db.Issue; +import org.simantics.db.ReadGraph; +import org.simantics.db.Resource; +import org.simantics.db.common.utils.Functions; +import org.simantics.db.common.utils.Logger; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.layer0.adapter.SubgraphExtent.ExtentStatus; +import org.simantics.db.layer0.util.DomainProcessor3; +import org.simantics.db.layer0.util.ModelTransferableGraphSourceRequest; +import org.simantics.layer0.Layer0; + +public class ValidationUtils { + + /** + * Performs L0.Constraint validations for the specified resource and puts + * the resulting issues in the specified {@link Issue} set. If the specified + * issue set is null, a new set will be created and returned. + * Otherwise the method function will return the same set as its return + * value. + * + * @param graph + * database read access handle + * @param r + * resource to validate against ontology-defined constraints + * @param result + * a set for the resulting issues or null to + * allocate a new set if necessary + * @return the discovered set of issues in r + * @throws DatabaseException + */ + public static Set validateConstraints(ReadGraph graph, Resource r, Set result) throws DatabaseException { + Layer0 L0 = Layer0.getInstance(graph); + + for (Resource constraint : graph.syncRequest(new GetConstraints(r))) { + try { + Resource function = graph.getSingleObject(constraint, L0.Constraint_Validator); + @SuppressWarnings("unchecked") + List issues = (List)Functions.exec(graph, function, graph, r); + if (issues != null && !issues.isEmpty()) { + if (result == null) + result = new THashSet(); + result.addAll(issues); + } + } catch (Throwable t) { + Logger.defaultLogError(t); + } + } + + return result != null ? result : Collections.emptySet(); + } + + public static Set validateConstraints(ReadGraph graph, Resource r) throws DatabaseException { + return validateConstraints(graph, r, null); + } + + public static Set validateConstraintsForDomain(ReadGraph graph, Resource r) throws DatabaseException { + Set result = null; + + DomainProcessor3 dp = ModelTransferableGraphSourceRequest.getDomainOnly(graph, null, r); + for(Map.Entry status : dp.getStatus().entrySet()) { + if(ExtentStatus.INTERNAL.equals(status.getValue())) { + Resource rr = status.getKey(); + Set issues = validateConstraints(graph, rr, result); + if (!issues.isEmpty()) + result = issues; + } + } + + return result != null ? result : Collections.emptySet(); + } + +}