blob: a4ca69b0798eb91d727480b8479f7f34622022c5 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2013 CEA LIST.
* 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:
* Cedric Dumoulin - cedric.dumoulin@lifl.fr
******************************************************************************/
package org.eclipse.papyrus.internal.infra.gmfdiag.layers.model.notifier;
import java.util.ArrayList;
import java.util.List;
import org.eclipse.emf.common.notify.Adapter;
import org.eclipse.emf.common.notify.Notification;
import org.eclipse.emf.ecore.util.EContentAdapter;
import org.eclipse.papyrus.internal.infra.gmfdiag.layers.model.layers.LayersStack;
import org.eclipse.papyrus.internal.infra.gmfdiag.layers.model.layers.LayersStackApplication;
import org.eclipse.uml2.uml.NamedElement;
/**
* An EMF {@link Adapter} listening on uml::NamedElement properties changes.
*
* This class listen to a {@link NamedElement} and send following events to listeners:
* <ul>
* <li>valueChanged</li>
* </ul>
*
* @author cedric dumoulin
*
*/
public class UmlNamedElementChangedEventNotifier extends EContentAdapter {
boolean isDisposed = false;
/**
* List of listener to notify.
*/
protected List<IUmlNamedElementChangedEventListener> listeners = new ArrayList<IUmlNamedElementChangedEventListener>();
/**
* Something happen on the tree of object
*
* @see org.eclipse.emf.ecore.util.EContentAdapter#notifyChanged(org.eclipse.emf.common.notify.Notification)
*
* @param msg
*/
@Override
public void notifyChanged(Notification notification) {
// Self atttach
super.notifyChanged(notification);
// Retain only NamedElement
if (!(notification.getNotifier() instanceof NamedElement)) {
return;
}
// No more filter: all events are forwarded
fireValueChangedEvent(notification);
// // We are only interested in NamedElement (from newValue if set, or oldValue if removed)
// Object newValue = notification.getNewValue();
// if( ! (newValue instanceof NamedElement || notification.getOldValue() instanceof NamedElement ) ) {
// return;
// }
// // Check diagram modification
// // There is 4 sources: View::persistedChildren and View::transientChildren
// // Diagram::persistedChildren and Diagram::transientChildren
// Object feature = notification.getFeature();
// if( feature == UMLPackage.eINSTANCE.getNamedElement()
// || feature == NotationPackage.eINSTANCE.getView_TransientChildren()
// || feature == NotationPackage.eINSTANCE.getDiagram_PersistedEdges()
// || feature == NotationPackage.eINSTANCE.getDiagram_TransientEdges() ) {
// // LayerOperator::layers || LayersStack::layers
// // check the event type.
// switch(notification.getEventType()) {
// case Notification.SET:
//
// break;
// case Notification.ADD:
// // A view is added
// fireValueChangedEvent(notification);
// break;
// case Notification.REMOVE:
// // A layer is removed
// fireDiagramViewRemovedEvent(notification);
// break;
// }
// }
};
/**
* This Adapter is for {@link LayersTreeEventNotifier}.
*
* @see org.eclipse.emf.common.notify.impl.AdapterImpl#isAdapterForType(java.lang.Object)
*
* @param type
* @return
*/
@Override
public boolean isAdapterForType(Object type) {
return type == UmlNamedElementChangedEventNotifier.class;
}
/**
* Constructor.
*
* @param layersModel
*/
public UmlNamedElementChangedEventNotifier() {
}
/**
* Dispose the synchronizer
*/
public void dispose() {
if (isDisposed()) {
return;
}
isDisposed = true;
listeners.clear();
}
/**
* Return true if the object is disposed.
*
* @return
*/
public boolean isDisposed() {
return isDisposed == true;
}
/**
* Add the specified listener to the list of listener.
* Do not add it if the listener is already in the list.
*
* @param listener
*/
public void addEventListener(IUmlNamedElementChangedEventListener listener) {
if (listener == null) {
return;
}
// Check if exist
if (listeners.contains(listener)) {
return;
}
listeners.add(listener);
}
/**
* Remove the specified listener from the list of listeners.
*
* @param listener
*/
public void removeEventListener(IUmlNamedElementChangedEventListener listener) {
listeners.remove(listener);
}
/**
* Called by events when a {@link LayersStack} is added to the {@link LayersStackApplication}
*
* @param msg
*/
protected void fireValueChangedEvent(Notification msg) {
for (IUmlNamedElementChangedEventListener listener : listeners) {
listener.valueChanged(msg);
}
}
}