X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.modeling%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2Ftypicals%2Frules%2FProfileMonitorRule.java;fp=bundles%2Forg.simantics.modeling%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2Ftypicals%2Frules%2FProfileMonitorRule.java;h=31ab720ef51d1f2f17f35d51045edb9309facde9;hb=0ae2b770234dfc3cbb18bd38f324125cf0faca07;hp=b6c6276f7ef027a5d7c67f4b3fffea84889bba1e;hpb=24e2b34260f219f0d1644ca7a138894980e25b14;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.modeling/src/org/simantics/modeling/typicals/rules/ProfileMonitorRule.java b/bundles/org.simantics.modeling/src/org/simantics/modeling/typicals/rules/ProfileMonitorRule.java index b6c6276f7..31ab720ef 100644 --- a/bundles/org.simantics.modeling/src/org/simantics/modeling/typicals/rules/ProfileMonitorRule.java +++ b/bundles/org.simantics.modeling/src/org/simantics/modeling/typicals/rules/ProfileMonitorRule.java @@ -1,65 +1,65 @@ -/******************************************************************************* - * 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.typicals.rules; - -import org.simantics.db.Resource; -import org.simantics.db.WriteGraph; -import org.simantics.db.exception.DatabaseException; -import org.simantics.diagram.stubs.DiagramResource; -import org.simantics.modeling.typicals.ITypicalSynchronizationRule; -import org.simantics.modeling.typicals.TypicalInfo; - -/** - * Synchronizes: - * * Grow Profile Monitors Upward? - * * Hide Profile Monitors? - * * Profile Monitor Offset? - * * Profile Monitor Spacing? - * - * @author Antti Villberg - */ -public enum ProfileMonitorRule implements ITypicalSynchronizationRule { - - INSTANCE; - - public static ProfileMonitorRule getInstance() { - return INSTANCE; - } - - @Override - public boolean synchronize(WriteGraph graph, Resource template, Resource instance, TypicalInfo info) throws DatabaseException { - - DiagramResource DIA = DiagramResource.getInstance(graph); - - // TODO consider making sure HasMonitorComponent is up-to-date also even though users should not be able to modify it - - boolean changed = false; - boolean result = changed |= Properties.synchronizePrimitivePropertyValue(graph, template, instance, DIA.Element_upProfileMonitors); - if(result) info.messageLog.add("\t\t\tgrow profile monitors upward => " + graph.getPossibleRelatedValue(instance, DIA.Element_upProfileMonitors)); - changed |= result; - result = Properties.synchronizePrimitivePropertyValue(graph, template, instance, DIA.Element_hideProfileMonitors); - if(result) info.messageLog.add("\t\t\thide profile monitors => " + graph.getPossibleRelatedValue(instance, DIA.Element_hideProfileMonitors)); - changed |= result; - result = Properties.synchronizePrimitivePropertyValue(graph, template, instance, DIA.Element_profileMonitorOffset); - if(result) info.messageLog.add("\t\t\tprofile monitor offset => " + graph.getPossibleRelatedValue(instance, DIA.Element_profileMonitorOffset)); - changed |= result; - result = Properties.synchronizeEnumerationPropertyValue(graph, template, instance, DIA.Element_profileMonitorSpacing); - if(result) info.messageLog.add("\t\t\tprofile monitor spacing => " + graph.getPossibleRelatedValue(instance, DIA.Element_profileMonitorSpacing)); - changed |= result; - - // TODO: sync font - //changed |= Properties.synchronizeStructuredPropertyValue(graph, template, instance, G2D.HasFont); - - return changed; - } - -} +/******************************************************************************* + * 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.typicals.rules; + +import org.simantics.db.Resource; +import org.simantics.db.WriteGraph; +import org.simantics.db.exception.DatabaseException; +import org.simantics.diagram.stubs.DiagramResource; +import org.simantics.modeling.typicals.ITypicalSynchronizationRule; +import org.simantics.modeling.typicals.TypicalInfo; + +/** + * Synchronizes: + * * Grow Profile Monitors Upward? + * * Hide Profile Monitors? + * * Profile Monitor Offset? + * * Profile Monitor Spacing? + * + * @author Antti Villberg + */ +public enum ProfileMonitorRule implements ITypicalSynchronizationRule { + + INSTANCE; + + public static ProfileMonitorRule getInstance() { + return INSTANCE; + } + + @Override + public boolean synchronize(WriteGraph graph, Resource template, Resource instance, TypicalInfo info) throws DatabaseException { + + DiagramResource DIA = DiagramResource.getInstance(graph); + + // TODO consider making sure HasMonitorComponent is up-to-date also even though users should not be able to modify it + + boolean changed = false; + boolean result = changed |= Properties.synchronizePrimitivePropertyValue(graph, template, instance, DIA.Element_upProfileMonitors); + if(result) info.messageLog.add("\t\t\tgrow profile monitors upward => " + graph.getPossibleRelatedValue(instance, DIA.Element_upProfileMonitors)); + changed |= result; + result = Properties.synchronizePrimitivePropertyValue(graph, template, instance, DIA.Element_hideProfileMonitors); + if(result) info.messageLog.add("\t\t\thide profile monitors => " + graph.getPossibleRelatedValue(instance, DIA.Element_hideProfileMonitors)); + changed |= result; + result = Properties.synchronizePrimitivePropertyValue(graph, template, instance, DIA.Element_profileMonitorOffset); + if(result) info.messageLog.add("\t\t\tprofile monitor offset => " + graph.getPossibleRelatedValue(instance, DIA.Element_profileMonitorOffset)); + changed |= result; + result = Properties.synchronizeEnumerationPropertyValue(graph, template, instance, DIA.Element_profileMonitorSpacing); + if(result) info.messageLog.add("\t\t\tprofile monitor spacing => " + graph.getPossibleRelatedValue(instance, DIA.Element_profileMonitorSpacing)); + changed |= result; + + // TODO: sync font + //changed |= Properties.synchronizeStructuredPropertyValue(graph, template, instance, G2D.HasFont); + + return changed; + } + +}