diff options
Diffstat (limited to 'rba.model.core.edit/src/rba/core/provider/ContentItemProvider.java')
-rw-r--r-- | rba.model.core.edit/src/rba/core/provider/ContentItemProvider.java | 147 |
1 files changed, 147 insertions, 0 deletions
diff --git a/rba.model.core.edit/src/rba/core/provider/ContentItemProvider.java b/rba.model.core.edit/src/rba/core/provider/ContentItemProvider.java new file mode 100644 index 0000000..76b20c3 --- /dev/null +++ b/rba.model.core.edit/src/rba/core/provider/ContentItemProvider.java @@ -0,0 +1,147 @@ +/** + */ +package rba.core.provider; + +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.IItemPropertyDescriptor; +import org.eclipse.emf.edit.provider.ItemPropertyDescriptor; +import org.eclipse.emf.edit.provider.ViewerNotification; + +import rba.core.Content; +import rba.core.RBACorePackage; + +/** + * This is the item provider adapter for a {@link rba.core.Content} object. + * <!-- begin-user-doc --> <!-- end-user-doc --> + * @generated + */ +public class ContentItemProvider extends AbstractContentItemProvider { + /** + * This constructs an instance from a factory and a notifier. + * <!-- begin-user-doc --> <!-- end-user-doc --> + * @generated + */ + public ContentItemProvider(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); + + addLoserTypePropertyDescriptor(object); + } + return itemPropertyDescriptors; + } + + /** + * This adds a property descriptor for the Loser Type feature. + * <!-- begin-user-doc --> <!-- end-user-doc --> + * @generated + */ + protected void addLoserTypePropertyDescriptor(Object object) { + itemPropertyDescriptors + .add(createItemPropertyDescriptor(((ComposeableAdapterFactory) adapterFactory).getRootAdapterFactory(), + getResourceLocator(), getString("_UI_Content_loserType_feature"), + getString("_UI_PropertyDescriptor_description", "_UI_Content_loserType_feature", + "_UI_Content_type"), + RBACorePackage.Literals.CONTENT__LOSER_TYPE, true, false, false, + ItemPropertyDescriptor.GENERIC_VALUE_IMAGE, 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(RBACorePackage.Literals.CONTENT__STATES); + } + 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); + } + + /** + * <!-- begin-user-doc --> <!-- end-user-doc --> + * @generated + */ + @Override + protected boolean shouldComposeCreationImage() { + return true; + } + + /** + * This returns the label text for the adapted class. + * <!-- begin-user-doc --> <!-- end-user-doc --> + * @generated + */ + @Override + public String getText(Object object) { + String label = ((Content) object).getName(); + return label == null || label.length() == 0 ? getString("_UI_Content_type") + : getString("_UI_Content_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(Content.class)) { + case RBACorePackage.CONTENT__LOSER_TYPE: + fireNotifyChanged(new ViewerNotification(notification, notification.getNotifier(), false, true)); + return; + case RBACorePackage.CONTENT__STATES: + 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); + } + +} |