diff options
Diffstat (limited to 'cdo/bundles/org.eclipse.papyrus.infra.gmfdiag.css.cdo/src/org/eclipse/papyrus/infra/gmfdiag/css/cdo/CSSPropertiesSetStyleImpl.java')
-rw-r--r-- | cdo/bundles/org.eclipse.papyrus.infra.gmfdiag.css.cdo/src/org/eclipse/papyrus/infra/gmfdiag/css/cdo/CSSPropertiesSetStyleImpl.java | 110 |
1 files changed, 110 insertions, 0 deletions
diff --git a/cdo/bundles/org.eclipse.papyrus.infra.gmfdiag.css.cdo/src/org/eclipse/papyrus/infra/gmfdiag/css/cdo/CSSPropertiesSetStyleImpl.java b/cdo/bundles/org.eclipse.papyrus.infra.gmfdiag.css.cdo/src/org/eclipse/papyrus/infra/gmfdiag/css/cdo/CSSPropertiesSetStyleImpl.java new file mode 100644 index 00000000..98a679ea --- /dev/null +++ b/cdo/bundles/org.eclipse.papyrus.infra.gmfdiag.css.cdo/src/org/eclipse/papyrus/infra/gmfdiag/css/cdo/CSSPropertiesSetStyleImpl.java @@ -0,0 +1,110 @@ +/***************************************************************************** + * Copyright (c) 2012 CEA LIST. + * + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License 2.0 + * which accompanies this distribution, and is available at + * https://www.eclipse.org/legal/epl-2.0/ + * + * SPDX-License-Identifier: EPL-2.0 + * + * Contributors: + * Camille Letavernier (CEA LIST) camille.letavernier@cea.fr - Initial API and implementation + *****************************************************************************/ +package org.eclipse.papyrus.infra.gmfdiag.css.cdo; + +import org.eclipse.emf.ecore.EObject; +import org.eclipse.emf.ecore.EStructuralFeature; +import org.eclipse.gmf.runtime.notation.NotationPackage; +import org.eclipse.gmf.runtime.notation.View; +import org.eclipse.emf.cdo.gmf.notation.impl.PropertiesSetStyleImpl; +import org.eclipse.papyrus.infra.gmfdiag.css.engine.ExtendedCSSEngine; +import org.eclipse.papyrus.infra.gmfdiag.css.notation.CSSDiagram; +import org.eclipse.papyrus.infra.gmfdiag.css.notation.ForceValueHelper; +import org.eclipse.papyrus.infra.gmfdiag.css.style.CSSPropertiesSetStyle; +import org.eclipse.papyrus.infra.gmfdiag.css.style.impl.CSSPropertiesSetStyleDelegate; + +public class CSSPropertiesSetStyleImpl extends PropertiesSetStyleImpl implements CSSPropertiesSetStyle { + + protected ExtendedCSSEngine engine; + + private CSSPropertiesSetStyle propertiesSetStyle; + + protected CSSPropertiesSetStyle getPropertiesSetStyle() { + if (propertiesSetStyle == null) { + propertiesSetStyle = new CSSPropertiesSetStyleDelegate(this, getEngine()); + } + return propertiesSetStyle; + } + + protected ExtendedCSSEngine getEngine() { + if (engine == null) { + engine = ((CSSDiagram) findView().getDiagram()).getEngine(); + } + return engine; + } + + protected View findView() { + EObject parent = eContainer(); + while (!(parent instanceof View) && parent != null) { + parent = parent.eContainer(); + } + + if (parent != null) { + return (View) parent; + } + + return null; + } + + + // //////////////////////////////////////// + // Forwards accesses to CSS properties // + // //////////////////////////////////////// + + + @Override + public java.lang.String getCSSName() { + java.lang.String value = super.getName(); + + if (ForceValueHelper.isSet(findView(), this, NotationPackage.eINSTANCE.getNamedStyle_Name(), value)) { + return value; + } else { + return getPropertiesSetStyle().getCSSName(); + } + } + + + @Override + public java.lang.String getName() { + return getCSSName(); + } + + + + // ////////////////////////////////////////////// + // Implements a setter for each CSS property // + // ////////////////////////////////////////////// + + @Override + public void setName(java.lang.String value) { + super.setName(value); + + EStructuralFeature feature = NotationPackage.eINSTANCE.getNamedStyle_Name(); + ForceValueHelper.setValue(findView(), feature, value); + } + + // //////////////////////////////// + // Implements the unset method // + // //////////////////////////////// + + @Override + public void eUnset(int featureId) { + super.eUnset(featureId); + + EStructuralFeature feature = eClass().getEStructuralFeature(featureId); + ForceValueHelper.unsetValue(findView(), feature); + } + + +} |