X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.modeling%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2Fadapters%2FMappingSubgraphAdvisor.java;fp=bundles%2Forg.simantics.modeling%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2Fadapters%2FMappingSubgraphAdvisor.java;h=1e95b95bf4e665fa1333fdd5d70c0793243de56a;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.modeling/src/org/simantics/modeling/adapters/MappingSubgraphAdvisor.java b/bundles/org.simantics.modeling/src/org/simantics/modeling/adapters/MappingSubgraphAdvisor.java new file mode 100644 index 000000000..1e95b95bf --- /dev/null +++ b/bundles/org.simantics.modeling/src/org/simantics/modeling/adapters/MappingSubgraphAdvisor.java @@ -0,0 +1,34 @@ +/******************************************************************************* + * Copyright (c) 2012 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.modeling.adapters; + +import org.simantics.db.AsyncReadGraph; +import org.simantics.db.Statement; +import org.simantics.db.layer0.adapter.SubgraphAdvisor; +import org.simantics.db.procedure.AsyncProcedure; +import org.simantics.modeling.ModelingResources; + +public class MappingSubgraphAdvisor implements SubgraphAdvisor { + + @Override + public void advise(AsyncReadGraph graph, Statement statement, AsyncProcedure procedure) { + ModelingResources mr = graph.getService(ModelingResources.class); + if(mr.CompositeToDiagram.equals(statement.getPredicate())) procedure.execute(graph, true); + else procedure.execute(graph, false); + } + + @Override + public double priority() { + return 0; + } + +}