/*******************************************************************************
* This file is protected by Copyright.
* Please refer to the COPYRIGHT file distributed with this source distribution.
*
* This file is part of REDHAWK IDE.
*
* 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
*******************************************************************************/
// BEGIN GENERATED CODE
package gov.redhawk.monitor.model.ports.provider;
import gov.redhawk.monitor.model.ports.util.PortsAdapterFactory;
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.ITableItemLabelProvider;
import org.eclipse.emf.edit.provider.ITreeItemContentProvider;
/**
* 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.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public class PortsItemProviderAdapterFactory extends PortsAdapterFactory implements ComposeableAdapterFactory, IChangeNotifier, IDisposable {
/**
* This keeps track of the root adapter factory that delegates to this adapter factory.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected ComposedAdapterFactory parentAdapterFactory;
/**
* This is used to implement {@link org.eclipse.emf.edit.provider.IChangeNotifier}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected IChangeNotifier changeNotifier = new ChangeNotifier();
/**
* This keeps track of all the supported types checked by {@link #isFactoryForType isFactoryForType}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected Collection<Object> supportedTypes = new ArrayList<Object>();
/**
* This constructs an instance.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public PortsItemProviderAdapterFactory() {
supportedTypes.add(IEditingDomainItemProvider.class);
supportedTypes.add(IStructuredItemContentProvider.class);
supportedTypes.add(ITreeItemContentProvider.class);
supportedTypes.add(IItemLabelProvider.class);
supportedTypes.add(IItemPropertySource.class);
supportedTypes.add(ITableItemLabelProvider.class);
}
/**
* This keeps track of the one adapter used for all {@link gov.redhawk.monitor.model.ports.PortMonitor} instances.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected PortMonitorItemProvider portMonitorItemProvider;
/**
* This creates an adapter for a {@link gov.redhawk.monitor.model.ports.PortMonitor}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Adapter createPortMonitorAdapter() {
if (portMonitorItemProvider == null) {
portMonitorItemProvider = new PortMonitorItemProvider(this);
}
return portMonitorItemProvider;
}
/**
* This keeps track of the one adapter used for all {@link gov.redhawk.monitor.model.ports.PortConnectionMonitor}
* instances.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected PortConnectionMonitorItemProvider portConnectionMonitorItemProvider;
/**
* This creates an adapter for a {@link gov.redhawk.monitor.model.ports.PortConnectionMonitor}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Adapter createPortConnectionMonitorAdapter() {
if (portConnectionMonitorItemProvider == null) {
portConnectionMonitorItemProvider = new PortConnectionMonitorItemProvider(this);
}
return portConnectionMonitorItemProvider;
}
/**
* This keeps track of the one adapter used for all {@link gov.redhawk.monitor.model.ports.MonitorRegistry}
* instances.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected MonitorRegistryItemProvider monitorRegistryItemProvider;
/**
* This creates an adapter for a {@link gov.redhawk.monitor.model.ports.MonitorRegistry}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Adapter createMonitorRegistryAdapter() {
if (monitorRegistryItemProvider == null) {
monitorRegistryItemProvider = new MonitorRegistryItemProvider(this);
}
return monitorRegistryItemProvider;
}
/**
* This keeps track of the one adapter used for all {@link gov.redhawk.monitor.model.ports.PortSupplierMonitor}
* instances.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected PortSupplierMonitorItemProvider portSupplierMonitorItemProvider;
/**
* This creates an adapter for a {@link gov.redhawk.monitor.model.ports.PortSupplierMonitor}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Adapter createPortSupplierMonitorAdapter() {
if (portSupplierMonitorItemProvider == null) {
portSupplierMonitorItemProvider = new PortSupplierMonitorItemProvider(this);
}
return portSupplierMonitorItemProvider;
}
/**
* This keeps track of the one adapter used for all {@link gov.redhawk.monitor.model.ports.PortStatisticsProvider}
* instances.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected PortStatisticsProviderItemProvider portStatisticsProviderItemProvider;
/**
* This creates an adapter for a {@link gov.redhawk.monitor.model.ports.PortStatisticsProvider}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Adapter createPortStatisticsProviderAdapter() {
if (portStatisticsProviderItemProvider == null) {
portStatisticsProviderItemProvider = new PortStatisticsProviderItemProvider(this);
}
return portStatisticsProviderItemProvider;
}
/**
* This returns the root adapter factory that contains this factory.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public ComposeableAdapterFactory getRootAdapterFactory() {
return parentAdapterFactory == null ? this : parentAdapterFactory.getRootAdapterFactory();
}
/**
* This sets the composed adapter factory that contains this factory.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void setParentAdapterFactory(ComposedAdapterFactory parentAdapterFactory) {
this.parentAdapterFactory = parentAdapterFactory;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @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.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Adapter adapt(Notifier notifier, Object type) {
return super.adapt(notifier, this);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @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.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void addListener(INotifyChangedListener notifyChangedListener) {
changeNotifier.addListener(notifyChangedListener);
}
/**
* This removes a listener.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void removeListener(INotifyChangedListener notifyChangedListener) {
changeNotifier.removeListener(notifyChangedListener);
}
/**
* This delegates to {@link #changeNotifier} and to {@link #parentAdapterFactory}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @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.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public void dispose() {
if (portMonitorItemProvider != null)
portMonitorItemProvider.dispose();
if (portConnectionMonitorItemProvider != null)
portConnectionMonitorItemProvider.dispose();
if (monitorRegistryItemProvider != null)
monitorRegistryItemProvider.dispose();
if (portSupplierMonitorItemProvider != null)
portSupplierMonitorItemProvider.dispose();
if (portStatisticsProviderItemProvider != null)
portStatisticsProviderItemProvider.dispose();
}
}