diff options
Diffstat (limited to 'extraplugins/deprecated-plugins/uml.deprecated/org.eclipse.papyrus.tabbedproperties.uml/generated/org/eclipse/papyrus/tabbedproperties/uml/components/ClearVariableActionBasePropertiesEditionComponent.java')
1 files changed, 917 insertions, 0 deletions
diff --git a/extraplugins/deprecated-plugins/uml.deprecated/org.eclipse.papyrus.tabbedproperties.uml/generated/org/eclipse/papyrus/tabbedproperties/uml/components/ClearVariableActionBasePropertiesEditionComponent.java b/extraplugins/deprecated-plugins/uml.deprecated/org.eclipse.papyrus.tabbedproperties.uml/generated/org/eclipse/papyrus/tabbedproperties/uml/components/ClearVariableActionBasePropertiesEditionComponent.java new file mode 100644 index 00000000000..eac90c17e21 --- /dev/null +++ b/extraplugins/deprecated-plugins/uml.deprecated/org.eclipse.papyrus.tabbedproperties.uml/generated/org/eclipse/papyrus/tabbedproperties/uml/components/ClearVariableActionBasePropertiesEditionComponent.java @@ -0,0 +1,917 @@ +/******************************************************************************* + * Copyright (c) 2009 Obeo. + * 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: + * Obeo - initial API and implementation + *******************************************************************************/ +package org.eclipse.papyrus.tabbedproperties.uml.components; + +// Start of user code for imports + +import java.util.Iterator; +import java.util.List; +import java.util.Map; + +import org.eclipse.emf.common.command.CompoundCommand; +import org.eclipse.emf.common.command.IdentityCommand; +import org.eclipse.emf.common.notify.Notification; +import org.eclipse.emf.common.notify.impl.AdapterImpl; +import org.eclipse.emf.common.util.BasicDiagnostic; +import org.eclipse.emf.common.util.Diagnostic; +import org.eclipse.emf.common.util.Enumerator; +import org.eclipse.emf.ecore.EEnum; +import org.eclipse.emf.ecore.EObject; +import org.eclipse.emf.ecore.EReference; +import org.eclipse.emf.ecore.EStructuralFeature; +import org.eclipse.emf.ecore.resource.Resource; +import org.eclipse.emf.ecore.resource.ResourceSet; +import org.eclipse.emf.ecore.util.Diagnostician; +import org.eclipse.emf.ecore.util.EContentAdapter; +import org.eclipse.emf.ecore.util.EcoreUtil; +import org.eclipse.emf.edit.command.AddCommand; +import org.eclipse.emf.edit.command.DeleteCommand; +import org.eclipse.emf.edit.command.MoveCommand; +import org.eclipse.emf.edit.command.RemoveCommand; +import org.eclipse.emf.edit.command.SetCommand; +import org.eclipse.emf.edit.domain.EditingDomain; +import org.eclipse.emf.eef.runtime.EMFPropertiesRuntime; +import org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent; +import org.eclipse.emf.eef.runtime.api.notify.IPropertiesEditionListener; +import org.eclipse.emf.eef.runtime.api.parts.IPropertiesEditionPart; +import org.eclipse.emf.eef.runtime.api.providers.IPropertiesEditionPartProvider; +import org.eclipse.emf.eef.runtime.impl.components.StandardPropertiesEditionComponent; +import org.eclipse.emf.eef.runtime.impl.filters.EObjectFilter; +import org.eclipse.emf.eef.runtime.impl.notify.PropertiesEditionEvent; +import org.eclipse.emf.eef.runtime.impl.services.PropertiesContextService; +import org.eclipse.emf.eef.runtime.impl.services.PropertiesEditionPartProviderService; +import org.eclipse.jface.dialogs.IMessageProvider; +import org.eclipse.jface.viewers.Viewer; +import org.eclipse.jface.viewers.ViewerFilter; +import org.eclipse.papyrus.tabbedproperties.uml.parts.ClearVariableActionPropertiesEditionPart; +import org.eclipse.papyrus.tabbedproperties.uml.parts.UMLViewsRepository; +import org.eclipse.uml2.uml.ClearVariableAction; +import org.eclipse.uml2.uml.Comment; +import org.eclipse.uml2.uml.Constraint; +import org.eclipse.uml2.uml.ExceptionHandler; +import org.eclipse.uml2.uml.UMLPackage; +import org.eclipse.uml2.uml.VisibilityKind; + +// End of user code + +/** + * @author <a href="mailto:jerome.benois@obeo.fr">Jerome Benois</a> + */ +public class ClearVariableActionBasePropertiesEditionComponent extends StandardPropertiesEditionComponent { + + public static String BASE_PART = "Base"; //$NON-NLS-1$ + + private String[] parts = { BASE_PART }; + + /** + * The EObject to edit + */ + private ClearVariableAction clearVariableAction; + + /** + * The Base part + */ + private ClearVariableActionPropertiesEditionPart basePart; + + /** + * Default constructor + */ + public ClearVariableActionBasePropertiesEditionComponent(EObject clearVariableAction, String editing_mode) { + if(clearVariableAction instanceof ClearVariableAction) { + this.clearVariableAction = (ClearVariableAction)clearVariableAction; + if(IPropertiesEditionComponent.LIVE_MODE.equals(editing_mode)) { + semanticAdapter = initializeSemanticAdapter(); + this.clearVariableAction.eAdapters().add(semanticAdapter); + } + } + this.editing_mode = editing_mode; + } + + /** + * Initialize the semantic model listener for live editing mode + * + * @return the semantic model listener + */ + private AdapterImpl initializeSemanticAdapter() { + return new EContentAdapter() { + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.common.notify.impl.AdapterImpl#notifyChanged(org.eclipse.emf.common.notify.Notification) + */ + public void notifyChanged(Notification msg) { + if(basePart == null) + ClearVariableActionBasePropertiesEditionComponent.this.dispose(); + else { + if(msg.getFeature() != null && + (((EStructuralFeature)msg.getFeature()) == UMLPackage.eINSTANCE.getElement_OwnedComment() + || ((EStructuralFeature)msg.getFeature()).getEContainingClass() == UMLPackage.eINSTANCE.getElement_OwnedComment())) { + basePart.updateOwnedComment(clearVariableAction); + } + if(UMLPackage.eINSTANCE.getNamedElement_Name().equals(msg.getFeature()) && basePart != null) { + if(msg.getNewValue() != null) { + basePart.setName((String)msg.getNewValue()); + } else { + basePart.setName(""); + } + } + if(UMLPackage.eINSTANCE.getNamedElement_Visibility().equals(msg.getFeature()) && basePart != null) + basePart.setVisibility((Enumerator)msg.getNewValue()); + + if(UMLPackage.eINSTANCE.getNamedElement_ClientDependency().equals(msg.getFeature())) + basePart.updateClientDependency(clearVariableAction); + if(UMLPackage.eINSTANCE.getRedefinableElement_IsLeaf().equals(msg.getFeature()) && basePart != null) + basePart.setIsLeaf((Boolean)msg.getNewValue()); + + if(UMLPackage.eINSTANCE.getActivityNode_Outgoing().equals(msg.getFeature())) + basePart.updateOutgoing(clearVariableAction); + if(UMLPackage.eINSTANCE.getActivityNode_Incoming().equals(msg.getFeature())) + basePart.updateIncoming(clearVariableAction); + if(UMLPackage.eINSTANCE.getActivityNode_InPartition().equals(msg.getFeature())) + basePart.updateInPartition(clearVariableAction); + if(UMLPackage.eINSTANCE.getActivityNode_InInterruptibleRegion().equals(msg.getFeature())) + basePart.updateInInterruptibleRegion(clearVariableAction); + if(UMLPackage.eINSTANCE.getActivityNode_RedefinedNode().equals(msg.getFeature())) + basePart.updateRedefinedNode(clearVariableAction); + if(msg.getFeature() != null && + (((EStructuralFeature)msg.getFeature()) == UMLPackage.eINSTANCE.getExecutableNode_Handler() + || ((EStructuralFeature)msg.getFeature()).getEContainingClass() == UMLPackage.eINSTANCE.getExecutableNode_Handler())) { + basePart.updateHandler(clearVariableAction); + } + if(msg.getFeature() != null && + (((EStructuralFeature)msg.getFeature()) == UMLPackage.eINSTANCE.getAction_LocalPrecondition() + || ((EStructuralFeature)msg.getFeature()).getEContainingClass() == UMLPackage.eINSTANCE.getAction_LocalPrecondition())) { + basePart.updateLocalPrecondition(clearVariableAction); + } + if(msg.getFeature() != null && + (((EStructuralFeature)msg.getFeature()) == UMLPackage.eINSTANCE.getAction_LocalPostcondition() + || ((EStructuralFeature)msg.getFeature()).getEContainingClass() == UMLPackage.eINSTANCE.getAction_LocalPostcondition())) { + basePart.updateLocalPostcondition(clearVariableAction); + } + + + } + } + + }; + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.impl.components.StandardPropertiesEditionComponent#translatePart(java.lang.String) + */ + public java.lang.Class translatePart(String key) { + if(BASE_PART.equals(key)) + return UMLViewsRepository.ClearVariableAction.class; + return super.translatePart(key); + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent#partsList() + */ + public String[] partsList() { + return parts; + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent#getPropertiesEditionPart (java.lang.String, java.lang.String) + */ + public IPropertiesEditionPart getPropertiesEditionPart(int kind, String key) { + if(clearVariableAction != null && BASE_PART.equals(key)) { + if(basePart == null) { + IPropertiesEditionPartProvider provider = PropertiesEditionPartProviderService.getInstance().getProvider(UMLViewsRepository.class); + if(provider != null) { + basePart = (ClearVariableActionPropertiesEditionPart)provider.getPropertiesEditionPart(UMLViewsRepository.ClearVariableAction.class, kind, this); + addListener((IPropertiesEditionListener)basePart); + } + } + return (IPropertiesEditionPart)basePart; + } + return null; + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.impl.components.StandardPropertiesEditionComponent# setPropertiesEditionPart(java.lang.Class, int, + * org.eclipse.emf.eef.runtime.api.parts.IPropertiesEditionPart) + */ + public void setPropertiesEditionPart(java.lang.Class key, int kind, IPropertiesEditionPart propertiesEditionPart) { + if(key == UMLViewsRepository.ClearVariableAction.class) + this.basePart = (ClearVariableActionPropertiesEditionPart)propertiesEditionPart; + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent#initPart(java.lang.Class, int, org.eclipse.emf.ecore.EObject, + * org.eclipse.emf.ecore.resource.ResourceSet) + */ + public void initPart(java.lang.Class key, int kind, EObject elt, ResourceSet allResource) { + if(basePart != null && key == UMLViewsRepository.ClearVariableAction.class) { + ((IPropertiesEditionPart)basePart).setContext(elt, allResource); + final ClearVariableAction clearVariableAction = (ClearVariableAction)elt; + // init values + basePart.initOwnedComment(clearVariableAction, null, UMLPackage.eINSTANCE.getElement_OwnedComment()); + if(clearVariableAction.getName() != null) + basePart.setName(clearVariableAction.getName()); + + basePart.initVisibility((EEnum)UMLPackage.eINSTANCE.getNamedElement_Visibility().getEType(), clearVariableAction.getVisibility()); + basePart.initClientDependency(clearVariableAction, null, UMLPackage.eINSTANCE.getNamedElement_ClientDependency()); + basePart.setIsLeaf(clearVariableAction.isLeaf()); + + basePart.initOutgoing(clearVariableAction, null, UMLPackage.eINSTANCE.getActivityNode_Outgoing()); + basePart.initIncoming(clearVariableAction, null, UMLPackage.eINSTANCE.getActivityNode_Incoming()); + basePart.initInPartition(clearVariableAction, null, UMLPackage.eINSTANCE.getActivityNode_InPartition()); + basePart.initInInterruptibleRegion(clearVariableAction, null, UMLPackage.eINSTANCE.getActivityNode_InInterruptibleRegion()); + basePart.initRedefinedNode(clearVariableAction, null, UMLPackage.eINSTANCE.getActivityNode_RedefinedNode()); + basePart.initHandler(clearVariableAction, null, UMLPackage.eINSTANCE.getExecutableNode_Handler()); + basePart.initLocalPrecondition(clearVariableAction, null, UMLPackage.eINSTANCE.getAction_LocalPrecondition()); + basePart.initLocalPostcondition(clearVariableAction, null, UMLPackage.eINSTANCE.getAction_LocalPostcondition()); + + // init filters + basePart.addFilterToOwnedComment(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + return (element instanceof String && element.equals("")) || (element instanceof Comment); //$NON-NLS-1$ + + } + + }); + // Start of user code for additional businessfilters for ownedComment + + // End of user code + + + basePart.addFilterToClientDependency(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + if(element instanceof EObject) + return (!basePart.isContainedInClientDependencyTable((EObject)element)); + return element instanceof Resource; + } + + }); + basePart.addFilterToClientDependency(new EObjectFilter(UMLPackage.eINSTANCE.getDependency())); + // Start of user code for additional businessfilters for clientDependency + + // End of user code + + basePart.addFilterToOutgoing(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + if(element instanceof EObject) + return (!basePart.isContainedInOutgoingTable((EObject)element)); + return element instanceof Resource; + } + + }); + basePart.addFilterToOutgoing(new EObjectFilter(UMLPackage.eINSTANCE.getActivityEdge())); + // Start of user code for additional businessfilters for outgoing + + // End of user code + basePart.addFilterToIncoming(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + if(element instanceof EObject) + return (!basePart.isContainedInIncomingTable((EObject)element)); + return element instanceof Resource; + } + + }); + basePart.addFilterToIncoming(new EObjectFilter(UMLPackage.eINSTANCE.getActivityEdge())); + // Start of user code for additional businessfilters for incoming + + // End of user code + basePart.addFilterToInPartition(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + if(element instanceof EObject) + return (!basePart.isContainedInInPartitionTable((EObject)element)); + return element instanceof Resource; + } + + }); + basePart.addFilterToInPartition(new EObjectFilter(UMLPackage.eINSTANCE.getActivityPartition())); + // Start of user code for additional businessfilters for inPartition + + // End of user code + basePart.addFilterToInInterruptibleRegion(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + if(element instanceof EObject) + return (!basePart.isContainedInInInterruptibleRegionTable((EObject)element)); + return element instanceof Resource; + } + + }); + basePart.addFilterToInInterruptibleRegion(new EObjectFilter(UMLPackage.eINSTANCE.getInterruptibleActivityRegion())); + // Start of user code for additional businessfilters for inInterruptibleRegion + + // End of user code + basePart.addFilterToRedefinedNode(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + if(element instanceof EObject) + return (!basePart.isContainedInRedefinedNodeTable((EObject)element)); + return element instanceof Resource; + } + + }); + basePart.addFilterToRedefinedNode(new EObjectFilter(UMLPackage.eINSTANCE.getActivityNode())); + // Start of user code for additional businessfilters for redefinedNode + + // End of user code + basePart.addFilterToHandler(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + return (element instanceof String && element.equals("")) || (element instanceof ExceptionHandler); //$NON-NLS-1$ + + } + + }); + // Start of user code for additional businessfilters for handler + + // End of user code + basePart.addFilterToLocalPrecondition(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + return (element instanceof String && element.equals("")) || (element instanceof Constraint); //$NON-NLS-1$ + + } + + }); + // Start of user code for additional businessfilters for localPrecondition + + // End of user code + basePart.addFilterToLocalPostcondition(new ViewerFilter() { + + /* + * (non-Javadoc) + * + * @see org.eclipse.jface.viewers.ViewerFilter#select(org.eclipse.jface.viewers.Viewer, java.lang.Object, java.lang.Object) + */ + public boolean select(Viewer viewer, Object parentElement, Object element) { + return (element instanceof String && element.equals("")) || (element instanceof Constraint); //$NON-NLS-1$ + + } + + }); + // Start of user code for additional businessfilters for localPostcondition + + // End of user code + } + // init values for referenced views + + // init filters for referenced views + + } + + + + + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent#getPropertiesEditionCommand + * (org.eclipse.emf.edit.domain.EditingDomain) + */ + public CompoundCommand getPropertiesEditionCommand(EditingDomain editingDomain) { + CompoundCommand cc = new CompoundCommand(); + if(clearVariableAction != null) { + List ownedCommentToAddFromOwnedComment = basePart.getOwnedCommentToAdd(); + for(Iterator iter = ownedCommentToAddFromOwnedComment.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getElement_OwnedComment(), iter.next())); + Map ownedCommentToRefreshFromOwnedComment = basePart.getOwnedCommentToEdit(); + for(Iterator iter = ownedCommentToRefreshFromOwnedComment.keySet().iterator(); iter.hasNext();) { + + + + Comment nextElement = (Comment)iter.next(); + Comment ownedComment = (Comment)ownedCommentToRefreshFromOwnedComment.get(nextElement); + + for(EStructuralFeature feature : nextElement.eClass().getEAllStructuralFeatures()) { + if(feature.isChangeable() && !(feature instanceof EReference && ((EReference)feature).isContainer())) { + cc.append(SetCommand.create(editingDomain, nextElement, feature, ownedComment.eGet(feature))); + } + } + + + + } + List ownedCommentToRemoveFromOwnedComment = basePart.getOwnedCommentToRemove(); + for(Iterator iter = ownedCommentToRemoveFromOwnedComment.iterator(); iter.hasNext();) + cc.append(DeleteCommand.create(editingDomain, iter.next())); + List ownedCommentToMoveFromOwnedComment = basePart.getOwnedCommentToMove(); + for(Iterator iter = ownedCommentToMoveFromOwnedComment.iterator(); iter.hasNext();) { + org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getComment(), moveElement.getElement(), moveElement.getIndex())); + } + cc.append(SetCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_Name(), basePart.getName())); + + cc.append(SetCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_Visibility(), basePart.getVisibility())); + + List clientDependencyToAddFromClientDependency = basePart.getClientDependencyToAdd(); + for(Iterator iter = clientDependencyToAddFromClientDependency.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_ClientDependency(), iter.next())); + List clientDependencyToRemoveFromClientDependency = basePart.getClientDependencyToRemove(); + for(Iterator iter = clientDependencyToRemoveFromClientDependency.iterator(); iter.hasNext();) + cc.append(RemoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_ClientDependency(), iter.next())); + //List clientDependencyToMoveFromClientDependency = basePart.getClientDependencyToMove(); + //for (Iterator iter = clientDependencyToMoveFromClientDependency.iterator(); iter.hasNext();){ + // org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + // cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getDependency(), moveElement.getElement(), moveElement.getIndex())); + //} + cc.append(SetCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getRedefinableElement_IsLeaf(), basePart.getIsLeaf())); + + List outgoingToAddFromOutgoing = basePart.getOutgoingToAdd(); + for(Iterator iter = outgoingToAddFromOutgoing.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Outgoing(), iter.next())); + List outgoingToRemoveFromOutgoing = basePart.getOutgoingToRemove(); + for(Iterator iter = outgoingToRemoveFromOutgoing.iterator(); iter.hasNext();) + cc.append(RemoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Outgoing(), iter.next())); + //List outgoingToMoveFromOutgoing = basePart.getOutgoingToMove(); + //for (Iterator iter = outgoingToMoveFromOutgoing.iterator(); iter.hasNext();){ + // org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + // cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityEdge(), moveElement.getElement(), moveElement.getIndex())); + //} + List incomingToAddFromIncoming = basePart.getIncomingToAdd(); + for(Iterator iter = incomingToAddFromIncoming.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Incoming(), iter.next())); + List incomingToRemoveFromIncoming = basePart.getIncomingToRemove(); + for(Iterator iter = incomingToRemoveFromIncoming.iterator(); iter.hasNext();) + cc.append(RemoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Incoming(), iter.next())); + //List incomingToMoveFromIncoming = basePart.getIncomingToMove(); + //for (Iterator iter = incomingToMoveFromIncoming.iterator(); iter.hasNext();){ + // org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + // cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityEdge(), moveElement.getElement(), moveElement.getIndex())); + //} + List inPartitionToAddFromInPartition = basePart.getInPartitionToAdd(); + for(Iterator iter = inPartitionToAddFromInPartition.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InPartition(), iter.next())); + List inPartitionToRemoveFromInPartition = basePart.getInPartitionToRemove(); + for(Iterator iter = inPartitionToRemoveFromInPartition.iterator(); iter.hasNext();) + cc.append(RemoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InPartition(), iter.next())); + //List inPartitionToMoveFromInPartition = basePart.getInPartitionToMove(); + //for (Iterator iter = inPartitionToMoveFromInPartition.iterator(); iter.hasNext();){ + // org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + // cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityPartition(), moveElement.getElement(), moveElement.getIndex())); + //} + List inInterruptibleRegionToAddFromInInterruptibleRegion = basePart.getInInterruptibleRegionToAdd(); + for(Iterator iter = inInterruptibleRegionToAddFromInInterruptibleRegion.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InInterruptibleRegion(), iter.next())); + List inInterruptibleRegionToRemoveFromInInterruptibleRegion = basePart.getInInterruptibleRegionToRemove(); + for(Iterator iter = inInterruptibleRegionToRemoveFromInInterruptibleRegion.iterator(); iter.hasNext();) + cc.append(RemoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InInterruptibleRegion(), iter.next())); + //List inInterruptibleRegionToMoveFromInInterruptibleRegion = basePart.getInInterruptibleRegionToMove(); + //for (Iterator iter = inInterruptibleRegionToMoveFromInInterruptibleRegion.iterator(); iter.hasNext();){ + // org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + // cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getInterruptibleActivityRegion(), moveElement.getElement(), moveElement.getIndex())); + //} + List redefinedNodeToAddFromRedefinedNode = basePart.getRedefinedNodeToAdd(); + for(Iterator iter = redefinedNodeToAddFromRedefinedNode.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_RedefinedNode(), iter.next())); + List redefinedNodeToRemoveFromRedefinedNode = basePart.getRedefinedNodeToRemove(); + for(Iterator iter = redefinedNodeToRemoveFromRedefinedNode.iterator(); iter.hasNext();) + cc.append(RemoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_RedefinedNode(), iter.next())); + //List redefinedNodeToMoveFromRedefinedNode = basePart.getRedefinedNodeToMove(); + //for (Iterator iter = redefinedNodeToMoveFromRedefinedNode.iterator(); iter.hasNext();){ + // org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + // cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode(), moveElement.getElement(), moveElement.getIndex())); + //} + List handlerToAddFromHandler = basePart.getHandlerToAdd(); + for(Iterator iter = handlerToAddFromHandler.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getExecutableNode_Handler(), iter.next())); + Map handlerToRefreshFromHandler = basePart.getHandlerToEdit(); + for(Iterator iter = handlerToRefreshFromHandler.keySet().iterator(); iter.hasNext();) { + + + + ExceptionHandler nextElement = (ExceptionHandler)iter.next(); + ExceptionHandler handler = (ExceptionHandler)handlerToRefreshFromHandler.get(nextElement); + + for(EStructuralFeature feature : nextElement.eClass().getEAllStructuralFeatures()) { + if(feature.isChangeable() && !(feature instanceof EReference && ((EReference)feature).isContainer())) { + cc.append(SetCommand.create(editingDomain, nextElement, feature, handler.eGet(feature))); + } + } + + + + } + List handlerToRemoveFromHandler = basePart.getHandlerToRemove(); + for(Iterator iter = handlerToRemoveFromHandler.iterator(); iter.hasNext();) + cc.append(DeleteCommand.create(editingDomain, iter.next())); + List handlerToMoveFromHandler = basePart.getHandlerToMove(); + for(Iterator iter = handlerToMoveFromHandler.iterator(); iter.hasNext();) { + org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getExceptionHandler(), moveElement.getElement(), moveElement.getIndex())); + } + List localPreconditionToAddFromLocalPrecondition = basePart.getLocalPreconditionToAdd(); + for(Iterator iter = localPreconditionToAddFromLocalPrecondition.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getAction_LocalPrecondition(), iter.next())); + Map localPreconditionToRefreshFromLocalPrecondition = basePart.getLocalPreconditionToEdit(); + for(Iterator iter = localPreconditionToRefreshFromLocalPrecondition.keySet().iterator(); iter.hasNext();) { + + + + Constraint nextElement = (Constraint)iter.next(); + Constraint localPrecondition = (Constraint)localPreconditionToRefreshFromLocalPrecondition.get(nextElement); + + for(EStructuralFeature feature : nextElement.eClass().getEAllStructuralFeatures()) { + if(feature.isChangeable() && !(feature instanceof EReference && ((EReference)feature).isContainer())) { + cc.append(SetCommand.create(editingDomain, nextElement, feature, localPrecondition.eGet(feature))); + } + } + + + + } + List localPreconditionToRemoveFromLocalPrecondition = basePart.getLocalPreconditionToRemove(); + for(Iterator iter = localPreconditionToRemoveFromLocalPrecondition.iterator(); iter.hasNext();) + cc.append(DeleteCommand.create(editingDomain, iter.next())); + List localPreconditionToMoveFromLocalPrecondition = basePart.getLocalPreconditionToMove(); + for(Iterator iter = localPreconditionToMoveFromLocalPrecondition.iterator(); iter.hasNext();) { + org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getConstraint(), moveElement.getElement(), moveElement.getIndex())); + } + List localPostconditionToAddFromLocalPostcondition = basePart.getLocalPostconditionToAdd(); + for(Iterator iter = localPostconditionToAddFromLocalPostcondition.iterator(); iter.hasNext();) + cc.append(AddCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getAction_LocalPostcondition(), iter.next())); + Map localPostconditionToRefreshFromLocalPostcondition = basePart.getLocalPostconditionToEdit(); + for(Iterator iter = localPostconditionToRefreshFromLocalPostcondition.keySet().iterator(); iter.hasNext();) { + + + + Constraint nextElement = (Constraint)iter.next(); + Constraint localPostcondition = (Constraint)localPostconditionToRefreshFromLocalPostcondition.get(nextElement); + + for(EStructuralFeature feature : nextElement.eClass().getEAllStructuralFeatures()) { + if(feature.isChangeable() && !(feature instanceof EReference && ((EReference)feature).isContainer())) { + cc.append(SetCommand.create(editingDomain, nextElement, feature, localPostcondition.eGet(feature))); + } + } + + + + } + List localPostconditionToRemoveFromLocalPostcondition = basePart.getLocalPostconditionToRemove(); + for(Iterator iter = localPostconditionToRemoveFromLocalPostcondition.iterator(); iter.hasNext();) + cc.append(DeleteCommand.create(editingDomain, iter.next())); + List localPostconditionToMoveFromLocalPostcondition = basePart.getLocalPostconditionToMove(); + for(Iterator iter = localPostconditionToMoveFromLocalPostcondition.iterator(); iter.hasNext();) { + org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement moveElement = (org.eclipse.emf.eef.runtime.impl.utils.EMFListEditUtil.MoveElement)iter.next(); + cc.append(MoveCommand.create(editingDomain, clearVariableAction, UMLPackage.eINSTANCE.getConstraint(), moveElement.getElement(), moveElement.getIndex())); + } + + + } + if(!cc.isEmpty()) + return cc; + cc.append(IdentityCommand.INSTANCE); + return cc; + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent#getPropertiesEditionObject() + */ + public EObject getPropertiesEditionObject(EObject source) { + if(source instanceof ClearVariableAction) { + ClearVariableAction clearVariableActionToUpdate = (ClearVariableAction)source; + clearVariableActionToUpdate.getOwnedComments().addAll(basePart.getOwnedCommentToAdd()); + clearVariableActionToUpdate.setName(basePart.getName()); + + clearVariableActionToUpdate.setVisibility((VisibilityKind)basePart.getVisibility()); + + clearVariableActionToUpdate.getClientDependencies().addAll(basePart.getClientDependencyToAdd()); + clearVariableActionToUpdate.setIsLeaf(new Boolean(basePart.getIsLeaf()).booleanValue()); + + clearVariableActionToUpdate.getOutgoings().addAll(basePart.getOutgoingToAdd()); + clearVariableActionToUpdate.getIncomings().addAll(basePart.getIncomingToAdd()); + clearVariableActionToUpdate.getInPartitions().addAll(basePart.getInPartitionToAdd()); + clearVariableActionToUpdate.getInInterruptibleRegions().addAll(basePart.getInInterruptibleRegionToAdd()); + clearVariableActionToUpdate.getRedefinedNodes().addAll(basePart.getRedefinedNodeToAdd()); + clearVariableActionToUpdate.getHandlers().addAll(basePart.getHandlerToAdd()); + clearVariableActionToUpdate.getLocalPreconditions().addAll(basePart.getLocalPreconditionToAdd()); + clearVariableActionToUpdate.getLocalPostconditions().addAll(basePart.getLocalPostconditionToAdd()); + + + return clearVariableActionToUpdate; + } else + return null; + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.notify.IPropertiesEditionListener#firePropertiesChanged(org.eclipse.emf.common.notify.Notification) + */ + public void firePropertiesChanged(PropertiesEditionEvent event) { + super.firePropertiesChanged(event); + if(PropertiesEditionEvent.COMMIT == event.getState() && IPropertiesEditionComponent.LIVE_MODE.equals(editing_mode)) { + CompoundCommand command = new CompoundCommand(); + if(UMLViewsRepository.ClearVariableAction.ownedComment == event.getAffectedEditor()) { + if(PropertiesEditionEvent.SET == event.getKind()) { + Comment oldValue = (Comment)event.getOldValue(); + Comment newValue = (Comment)event.getNewValue(); + + + // TODO: Complete the clearVariableAction update command + for(EStructuralFeature feature : newValue.eClass().getEAllStructuralFeatures()) { + if(feature.isChangeable() && !(feature instanceof EReference && ((EReference)feature).isContainer())) { + command.append(SetCommand.create(liveEditingDomain, oldValue, feature, newValue.eGet(feature))); + } + } + + + } else if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getElement_OwnedComment(), event.getNewValue())); + else if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(DeleteCommand.create(liveEditingDomain, event.getNewValue())); + else if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getComment(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.name == event.getAffectedEditor()) + command.append(SetCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_Name(), event.getNewValue())); + + if(UMLViewsRepository.ClearVariableAction.visibility == event.getAffectedEditor()) + command.append(SetCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_Visibility(), event.getNewValue())); + + if(UMLViewsRepository.ClearVariableAction.clientDependency == event.getAffectedEditor()) { + if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_ClientDependency(), event.getNewValue())); + if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(RemoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_ClientDependency(), event.getNewValue())); + if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getNamedElement_ClientDependency(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.isLeaf == event.getAffectedEditor()) + command.append(SetCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getRedefinableElement_IsLeaf(), event.getNewValue())); + + if(UMLViewsRepository.ClearVariableAction.outgoing == event.getAffectedEditor()) { + if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Outgoing(), event.getNewValue())); + if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(RemoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Outgoing(), event.getNewValue())); + if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Outgoing(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.incoming == event.getAffectedEditor()) { + if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Incoming(), event.getNewValue())); + if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(RemoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Incoming(), event.getNewValue())); + if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_Incoming(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.inPartition == event.getAffectedEditor()) { + if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InPartition(), event.getNewValue())); + if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(RemoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InPartition(), event.getNewValue())); + if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InPartition(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.inInterruptibleRegion == event.getAffectedEditor()) { + if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InInterruptibleRegion(), event.getNewValue())); + if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(RemoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InInterruptibleRegion(), event.getNewValue())); + if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_InInterruptibleRegion(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.redefinedNode == event.getAffectedEditor()) { + if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_RedefinedNode(), event.getNewValue())); + if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(RemoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_RedefinedNode(), event.getNewValue())); + if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getActivityNode_RedefinedNode(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.handler == event.getAffectedEditor()) { + if(PropertiesEditionEvent.SET == event.getKind()) { + ExceptionHandler oldValue = (ExceptionHandler)event.getOldValue(); + ExceptionHandler newValue = (ExceptionHandler)event.getNewValue(); + + + // TODO: Complete the clearVariableAction update command + for(EStructuralFeature feature : newValue.eClass().getEAllStructuralFeatures()) { + if(feature.isChangeable() && !(feature instanceof EReference && ((EReference)feature).isContainer())) { + command.append(SetCommand.create(liveEditingDomain, oldValue, feature, newValue.eGet(feature))); + } + } + + + } else if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getExecutableNode_Handler(), event.getNewValue())); + else if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(DeleteCommand.create(liveEditingDomain, event.getNewValue())); + else if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getExceptionHandler(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.localPrecondition == event.getAffectedEditor()) { + if(PropertiesEditionEvent.SET == event.getKind()) { + Constraint oldValue = (Constraint)event.getOldValue(); + Constraint newValue = (Constraint)event.getNewValue(); + + + // TODO: Complete the clearVariableAction update command + for(EStructuralFeature feature : newValue.eClass().getEAllStructuralFeatures()) { + if(feature.isChangeable() && !(feature instanceof EReference && ((EReference)feature).isContainer())) { + command.append(SetCommand.create(liveEditingDomain, oldValue, feature, newValue.eGet(feature))); + } + } + + + } else if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getAction_LocalPrecondition(), event.getNewValue())); + else if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(DeleteCommand.create(liveEditingDomain, event.getNewValue())); + else if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getConstraint(), event.getNewValue(), event.getNewIndex())); + } + if(UMLViewsRepository.ClearVariableAction.localPostcondition == event.getAffectedEditor()) { + if(PropertiesEditionEvent.SET == event.getKind()) { + Constraint oldValue = (Constraint)event.getOldValue(); + Constraint newValue = (Constraint)event.getNewValue(); + + + // TODO: Complete the clearVariableAction update command + for(EStructuralFeature feature : newValue.eClass().getEAllStructuralFeatures()) { + if(feature.isChangeable() && !(feature instanceof EReference && ((EReference)feature).isContainer())) { + command.append(SetCommand.create(liveEditingDomain, oldValue, feature, newValue.eGet(feature))); + } + } + + + } else if(PropertiesEditionEvent.ADD == event.getKind()) + command.append(AddCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getAction_LocalPostcondition(), event.getNewValue())); + else if(PropertiesEditionEvent.REMOVE == event.getKind()) + command.append(DeleteCommand.create(liveEditingDomain, event.getNewValue())); + else if(PropertiesEditionEvent.MOVE == event.getKind()) + command.append(MoveCommand.create(liveEditingDomain, clearVariableAction, UMLPackage.eINSTANCE.getConstraint(), event.getNewValue(), event.getNewIndex())); + } + + + if(!command.isEmpty() && !command.canExecute()) { + EMFPropertiesRuntime.getDefault().logError("Cannot perform model change command.", null); + } else { + liveEditingDomain.getCommandStack().execute(command); + } + } else if(PropertiesEditionEvent.CHANGE == event.getState()) { + Diagnostic diag = this.validateValue(event); + if(diag != null && diag.getSeverity() != Diagnostic.OK) { + + if(UMLViewsRepository.ClearVariableAction.name == event.getAffectedEditor()) + basePart.setMessageForName(diag.getMessage(), IMessageProvider.ERROR); + + + + + + } else { + + if(UMLViewsRepository.ClearVariableAction.name == event.getAffectedEditor()) + basePart.unsetMessageForName(); + + + + + + } + } + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.impl.components.StandardPropertiesEditionComponent#isRequired(java.lang.String, int) + */ + public boolean isRequired(String key, int kind) { + return key == UMLViewsRepository.ClearVariableAction.isLeaf; + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent#validateValue(org.eclipse.emf.common.notify.Notification) + */ + public Diagnostic validateValue(PropertiesEditionEvent event) { + Diagnostic ret = null; + if(event.getNewValue() != null) { + String newStringValue = event.getNewValue().toString(); + try { + if(UMLViewsRepository.ClearVariableAction.name == event.getAffectedEditor()) { + Object newValue = EcoreUtil.createFromString(UMLPackage.eINSTANCE.getNamedElement_Name().getEAttributeType(), newStringValue); + ret = Diagnostician.INSTANCE.validate(UMLPackage.eINSTANCE.getNamedElement_Name().getEAttributeType(), newValue); + } + if(UMLViewsRepository.ClearVariableAction.visibility == event.getAffectedEditor()) { + Object newValue = EcoreUtil.createFromString(UMLPackage.eINSTANCE.getNamedElement_Visibility().getEAttributeType(), newStringValue); + ret = Diagnostician.INSTANCE.validate(UMLPackage.eINSTANCE.getNamedElement_Visibility().getEAttributeType(), newValue); + } + if(UMLViewsRepository.ClearVariableAction.isLeaf == event.getAffectedEditor()) { + Object newValue = EcoreUtil.createFromString(UMLPackage.eINSTANCE.getRedefinableElement_IsLeaf().getEAttributeType(), newStringValue); + ret = Diagnostician.INSTANCE.validate(UMLPackage.eINSTANCE.getRedefinableElement_IsLeaf().getEAttributeType(), newValue); + } + + } catch (IllegalArgumentException iae) { + ret = BasicDiagnostic.toDiagnostic(iae); + } + } + return ret; + } + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent#validate() + */ + public Diagnostic validate() { + Diagnostic validate = null; + if(IPropertiesEditionComponent.BATCH_MODE.equals(editing_mode)) { + EObject copy = EcoreUtil.copy(PropertiesContextService.getInstance().entryPointElement()); + copy = PropertiesContextService.getInstance().entryPointComponent().getPropertiesEditionObject(copy); + validate = Diagnostician.INSTANCE.validate(copy); + } else if(IPropertiesEditionComponent.LIVE_MODE.equals(editing_mode)) + validate = Diagnostician.INSTANCE.validate(clearVariableAction); + // Start of user code for custom validation check + + // End of user code + + return validate; + } + + + /** + * {@inheritDoc} + * + * @see org.eclipse.emf.eef.runtime.api.component.IPropertiesEditionComponent#dispose() + */ + public void dispose() { + if(semanticAdapter != null) + clearVariableAction.eAdapters().remove(semanticAdapter); + } + +} |