/*******************************************************************************
* Copyright (c) 2006, 2007 g-Eclipse Consortium
* 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
*
* Initial development of the original code was made for the g-Eclipse project
* funded by European Union project number: FP6-IST-034327
* http://www.geclipse.eu/
*
* Contributors:
* RUR (http://acet.rdg.ac.uk/)
* - Ashish Thandavan - initial API and implementation
******************************************************************************/
package eu.geclipse.workflow.provider;
import eu.geclipse.workflow.model.IInputPort;
import eu.geclipse.workflow.model.IWorkflowPackage;
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.common.util.ResourceLocator;
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;
/**
* This is the item provider adapter for a
* {@link eu.geclipse.workflow.model.IInputPort} object. <!-- begin-user-doc --> <!--
* end-user-doc -->
*
* @generated
*/
public class InputPortItemProvider extends PortItemProvider
implements IEditingDomainItemProvider, IStructuredItemContentProvider,
ITreeItemContentProvider, IItemLabelProvider, IItemPropertySource
{
/**
* This constructs an instance from a factory and a notifier. <!--
* begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
public InputPortItemProvider( 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( this.itemPropertyDescriptors == null ) {
super.getPropertyDescriptors( object );
addLinksPropertyDescriptor( object );
}
return this.itemPropertyDescriptors;
}
/**
* This adds a property descriptor for the Links feature. <!-- begin-user-doc
* --> <!-- end-user-doc -->
*
* @generated
*/
protected void addLinksPropertyDescriptor( Object object ) {
this.itemPropertyDescriptors.add( createItemPropertyDescriptor( ( ( ComposeableAdapterFactory )this.adapterFactory ).getRootAdapterFactory(),
getResourceLocator(),
getString( "_UI_IInputPort_links_feature" ), //$NON-NLS-1$
getString( "_UI_PropertyDescriptor_description", //$NON-NLS-1$
"_UI_IInputPort_links_feature", //$NON-NLS-1$
"_UI_IInputPort_type" ), //$NON-NLS-1$
IWorkflowPackage.Literals.IINPUT_PORT__LINKS,
true,
false,
true,
null,
null,
null ) );
}
/**
* This returns InputPort.gif. <!-- begin-user-doc --> <!-- end-user-doc -->
*
* @generated NOT
*/
@Override
public Object getImage( Object object ) {
return overlayImage( object,
getResourceLocator().getImage( "full/obj16/InputPort" ) ); //$NON-NLS-1$
}
/**
* This returns the label text for the adapted class. <!-- begin-user-doc -->
* <!-- end-user-doc -->
*/
@Override
public String getText( Object object ) {
IInputPort inPort = ( IInputPort )object;
String label = ""; //$NON-NLS-1$
String portName = inPort.getNode().getName();
// String portFileName = inPort.getFileName();
if( !( portName == null || portName.length() == 0 ) )
label += " belonging to " + portName; //$NON-NLS-1$
// label += " belonging to " + portName + ";" + portFileName; //$NON-NLS-1$
return label == null || label.length() == 0
? getString( "_UI_IInputPort_type" ) //$NON-NLS-1$
: getString( "_UI_IInputPort_type" ) //$NON-NLS-1$
+ " " //$NON-NLS-1$
+ 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 );
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 );
}
/**
* Return the resource locator for this item provider's resources. <!--
* begin-user-doc --> <!-- end-user-doc -->
*
* @generated
*/
@Override
public ResourceLocator getResourceLocator() {
return WorkflowEditPlugin.INSTANCE;
}
}