/** */ package simplepdl.provider; import java.util.ArrayList; import java.util.Collection; import org.eclipse.emf.common.notify.Adapter; import org.eclipse.emf.common.notify.Notification; import org.eclipse.emf.common.notify.Notifier; import org.eclipse.emf.edit.provider.ChangeNotifier; import org.eclipse.emf.edit.provider.ComposeableAdapterFactory; import org.eclipse.emf.edit.provider.ComposedAdapterFactory; import org.eclipse.emf.edit.provider.IChangeNotifier; import org.eclipse.emf.edit.provider.IDisposable; import org.eclipse.emf.edit.provider.IEditingDomainItemProvider; import org.eclipse.emf.edit.provider.IItemLabelProvider; import org.eclipse.emf.edit.provider.IItemPropertySource; import org.eclipse.emf.edit.provider.INotifyChangedListener; import org.eclipse.emf.edit.provider.IStructuredItemContentProvider; import org.eclipse.emf.edit.provider.ITreeItemContentProvider; import simplepdl.util.SimplepdlAdapterFactory; /** * This is the factory that is used to provide the interfaces needed to support Viewers. * The adapters generated by this factory convert EMF adapter notifications into calls to {@link #fireNotifyChanged fireNotifyChanged}. * The adapters also support Eclipse property sheets. * Note that most of the adapters are shared among multiple instances. * * * @generated */ public class SimplepdlItemProviderAdapterFactory extends SimplepdlAdapterFactory implements ComposeableAdapterFactory, IChangeNotifier, IDisposable { /** * This keeps track of the root adapter factory that delegates to this adapter factory. * * * @generated */ protected ComposedAdapterFactory parentAdapterFactory; /** * This is used to implement {@link org.eclipse.emf.edit.provider.IChangeNotifier}. * * * @generated */ protected IChangeNotifier changeNotifier = new ChangeNotifier(); /** * This keeps track of all the supported types checked by {@link #isFactoryForType isFactoryForType}. * * * @generated */ protected Collection supportedTypes = new ArrayList(); /** * This constructs an instance. * * * @generated */ public SimplepdlItemProviderAdapterFactory() { supportedTypes.add(IEditingDomainItemProvider.class); supportedTypes.add(IStructuredItemContentProvider.class); supportedTypes.add(ITreeItemContentProvider.class); supportedTypes.add(IItemLabelProvider.class); supportedTypes.add(IItemPropertySource.class); } /** * This keeps track of the one adapter used for all {@link simplepdl.WorkDefinition} instances. * * * @generated */ protected WorkDefinitionItemProvider workDefinitionItemProvider; /** * This creates an adapter for a {@link simplepdl.WorkDefinition}. * * * @generated */ @Override public Adapter createWorkDefinitionAdapter() { if (workDefinitionItemProvider == null) { workDefinitionItemProvider = new WorkDefinitionItemProvider(this); } return workDefinitionItemProvider; } /** * This keeps track of the one adapter used for all {@link simplepdl.WorkSequence} instances. * * * @generated */ protected WorkSequenceItemProvider workSequenceItemProvider; /** * This creates an adapter for a {@link simplepdl.WorkSequence}. * * * @generated */ @Override public Adapter createWorkSequenceAdapter() { if (workSequenceItemProvider == null) { workSequenceItemProvider = new WorkSequenceItemProvider(this); } return workSequenceItemProvider; } /** * This keeps track of the one adapter used for all {@link simplepdl.Process} instances. * * * @generated */ protected ProcessItemProvider processItemProvider; /** * This creates an adapter for a {@link simplepdl.Process}. * * * @generated */ @Override public Adapter createProcessAdapter() { if (processItemProvider == null) { processItemProvider = new ProcessItemProvider(this); } return processItemProvider; } /** * This keeps track of the one adapter used for all {@link simplepdl.Guidance} instances. * * * @generated */ protected GuidanceItemProvider guidanceItemProvider; /** * This creates an adapter for a {@link simplepdl.Guidance}. * * * @generated */ @Override public Adapter createGuidanceAdapter() { if (guidanceItemProvider == null) { guidanceItemProvider = new GuidanceItemProvider(this); } return guidanceItemProvider; } /** * This keeps track of the one adapter used for all {@link simplepdl.Resource} instances. * * * @generated */ protected ResourceItemProvider resourceItemProvider; /** * This creates an adapter for a {@link simplepdl.Resource}. * * * @generated */ @Override public Adapter createResourceAdapter() { if (resourceItemProvider == null) { resourceItemProvider = new ResourceItemProvider(this); } return resourceItemProvider; } /** * This keeps track of the one adapter used for all {@link simplepdl.Request} instances. * * * @generated */ protected RequestItemProvider requestItemProvider; /** * This creates an adapter for a {@link simplepdl.Request}. * * * @generated */ @Override public Adapter createRequestAdapter() { if (requestItemProvider == null) { requestItemProvider = new RequestItemProvider(this); } return requestItemProvider; } /** * This returns the root adapter factory that contains this factory. * * * @generated */ public ComposeableAdapterFactory getRootAdapterFactory() { return parentAdapterFactory == null ? this : parentAdapterFactory.getRootAdapterFactory(); } /** * This sets the composed adapter factory that contains this factory. * * * @generated */ public void setParentAdapterFactory(ComposedAdapterFactory parentAdapterFactory) { this.parentAdapterFactory = parentAdapterFactory; } /** * * * @generated */ @Override public boolean isFactoryForType(Object type) { return supportedTypes.contains(type) || super.isFactoryForType(type); } /** * This implementation substitutes the factory itself as the key for the adapter. * * * @generated */ @Override public Adapter adapt(Notifier notifier, Object type) { return super.adapt(notifier, this); } /** * * * @generated */ @Override public Object adapt(Object object, Object type) { if (isFactoryForType(type)) { Object adapter = super.adapt(object, type); if (!(type instanceof Class) || (((Class)type).isInstance(adapter))) { return adapter; } } return null; } /** * This adds a listener. * * * @generated */ public void addListener(INotifyChangedListener notifyChangedListener) { changeNotifier.addListener(notifyChangedListener); } /** * This removes a listener. * * * @generated */ public void removeListener(INotifyChangedListener notifyChangedListener) { changeNotifier.removeListener(notifyChangedListener); } /** * This delegates to {@link #changeNotifier} and to {@link #parentAdapterFactory}. * * * @generated */ public void fireNotifyChanged(Notification notification) { changeNotifier.fireNotifyChanged(notification); if (parentAdapterFactory != null) { parentAdapterFactory.fireNotifyChanged(notification); } } /** * This disposes all of the item providers created by this factory. * * * @generated */ public void dispose() { if (workDefinitionItemProvider != null) workDefinitionItemProvider.dispose(); if (workSequenceItemProvider != null) workSequenceItemProvider.dispose(); if (processItemProvider != null) processItemProvider.dispose(); if (guidanceItemProvider != null) guidanceItemProvider.dispose(); if (resourceItemProvider != null) resourceItemProvider.dispose(); if (requestItemProvider != null) requestItemProvider.dispose(); } }