/**************************************************************************
* ERA - Eclipse Requirements Analysis
* ==============================================
* Copyright (C) 2009-2013 by Georg Blaschke, Christoph P. Neumann
* and Bernd Haberstumpf (http://era.origo.ethz.ch)
**************************************************************************
* Licensed under the Eclipse Public License - v 1.0 (the "License");
* you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.eclipse.org/org/documents/epl-v10.html
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
**************************************************************************
*/
package era.foss.erf.provider;
import era.foss.erf.ErfFactory;
import era.foss.erf.ErfPackage;
import era.foss.erf.SpecHierarchy;
import java.util.Collection;
import java.util.List;
import org.eclipse.emf.common.notify.AdapterFactory;
import org.eclipse.emf.common.notify.Notification;
import org.eclipse.emf.ecore.EStructuralFeature;
import org.eclipse.emf.edit.provider.ComposeableAdapterFactory;
import org.eclipse.emf.edit.provider.IEditingDomainItemProvider;
import org.eclipse.emf.edit.provider.IItemLabelProvider;
import org.eclipse.emf.edit.provider.IItemPropertyDescriptor;
import org.eclipse.emf.edit.provider.IItemPropertySource;
import org.eclipse.emf.edit.provider.IStructuredItemContentProvider;
import org.eclipse.emf.edit.provider.ITreeItemContentProvider;
import org.eclipse.emf.edit.provider.ItemPropertyDescriptor;
import org.eclipse.emf.edit.provider.ViewerNotification;
/**
* This is the item provider adapter for a {@link era.foss.erf.SpecHierarchy} object.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public class SpecHierarchyItemProvider extends AccessControlledElementItemProvider implements
IEditingDomainItemProvider, IStructuredItemContentProvider, ITreeItemContentProvider, IItemLabelProvider,
IItemPropertySource {
/**
* This constructs an instance from a factory and a notifier.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public SpecHierarchyItemProvider( AdapterFactory adapterFactory ) {
super( adapterFactory );
}
/**
* This returns the property descriptors for the adapted class.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public List<IItemPropertyDescriptor> getPropertyDescriptors( Object object ) {
if( itemPropertyDescriptors == null ) {
super.getPropertyDescriptors( object );
addTableInternalPropertyDescriptor( object );
addObjectPropertyDescriptor( object );
}
return itemPropertyDescriptors;
}
/**
* This adds a property descriptor for the Table Internal feature.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected void addTableInternalPropertyDescriptor( Object object ) {
itemPropertyDescriptors.add( createItemPropertyDescriptor( ((ComposeableAdapterFactory)adapterFactory).getRootAdapterFactory(),
getResourceLocator(),
getString( "_UI_SpecHierarchy_tableInternal_feature" ),
getString( "_UI_PropertyDescriptor_description",
"_UI_SpecHierarchy_tableInternal_feature",
"_UI_SpecHierarchy_type" ),
ErfPackage.Literals.SPEC_HIERARCHY__TABLE_INTERNAL,
true,
false,
false,
ItemPropertyDescriptor.BOOLEAN_VALUE_IMAGE,
null,
null ) );
}
/**
* This adds a property descriptor for the Object feature.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected void addObjectPropertyDescriptor( Object object ) {
itemPropertyDescriptors.add( createItemPropertyDescriptor( ((ComposeableAdapterFactory)adapterFactory).getRootAdapterFactory(),
getResourceLocator(),
getString( "_UI_SpecHierarchy_object_feature" ),
getString( "_UI_PropertyDescriptor_description",
"_UI_SpecHierarchy_object_feature",
"_UI_SpecHierarchy_type" ),
ErfPackage.Literals.SPEC_HIERARCHY__OBJECT,
true,
false,
true,
null,
null,
null ) );
}
/**
* This specifies how to implement {@link #getChildren} and is used to deduce an appropriate feature for an
* {@link org.eclipse.emf.edit.command.AddCommand}, {@link org.eclipse.emf.edit.command.RemoveCommand} or
* {@link org.eclipse.emf.edit.command.MoveCommand} in {@link #createCommand}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Collection<? extends EStructuralFeature> getChildrenFeatures( Object object ) {
if( childrenFeatures == null ) {
super.getChildrenFeatures( object );
childrenFeatures.add( ErfPackage.Literals.SPEC_HIERARCHY__CHILDREN );
}
return childrenFeatures;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EStructuralFeature getChildFeature( Object object, Object child ) {
// Check the type of the specified child object and return the proper feature to use for
// adding (see {@link AddCommand}) it as a child.
return super.getChildFeature( object, child );
}
/**
* This returns SpecHierarchy.gif.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Object getImage( Object object ) {
return overlayImage( object, getResourceLocator().getImage( "full/obj16/SpecHierarchy" ) );
}
/**
* This returns the label text for the adapted class.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public String getText( Object object ) {
String label = ((SpecHierarchy)object).getID();
return label == null || label.length() == 0
? getString( "_UI_SpecHierarchy_type" )
: getString( "_UI_SpecHierarchy_type" ) + " " + label;
}
/**
* This handles model notifications by calling {@link #updateChildren} to update any cached
* children and by creating a viewer notification, which it passes to {@link #fireNotifyChanged}.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void notifyChanged( Notification notification ) {
updateChildren( notification );
switch (notification.getFeatureID( SpecHierarchy.class )) {
case ErfPackage.SPEC_HIERARCHY__TABLE_INTERNAL:
fireNotifyChanged( new ViewerNotification( notification, notification.getNotifier(), false, true ) );
return;
case ErfPackage.SPEC_HIERARCHY__CHILDREN:
fireNotifyChanged( new ViewerNotification( notification, notification.getNotifier(), true, false ) );
return;
}
super.notifyChanged( notification );
}
/**
* This adds {@link org.eclipse.emf.edit.command.CommandParameter}s describing the children
* that can be created under this object.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected void collectNewChildDescriptors( Collection<Object> newChildDescriptors, Object object ) {
super.collectNewChildDescriptors( newChildDescriptors, object );
newChildDescriptors.add( createChildParameter( ErfPackage.Literals.SPEC_HIERARCHY__CHILDREN,
ErfFactory.eINSTANCE.createSpecHierarchy() ) );
}
}