/*******************************************************************************
* Copyright (c) 2000, 2005 IBM Corporation and others.
* 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
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.gef.dnd;
import org.eclipse.swt.dnd.DragSource;
import org.eclipse.swt.dnd.DragSourceEvent;
import org.eclipse.swt.dnd.DragSourceListener;
import org.eclipse.swt.dnd.Transfer;
import org.eclipse.swt.dnd.TransferData;
/**
* A DragSourceListener that maintains and delegates to a set of {@link
* TransferDragSourceListener}s. Each TransferDragSourceListener can then be implemented
* as if it were the DragSource's only DragSourceListener.
* <P>
* When a native Drag is started, a subset of all <code>TransferDragSourceListeners</code>
* is generated and stored in a list of <i>active</i> listeners. This subset is calculated
* by forwarding {@link DragSourceListener#dragStart(DragSourceEvent)} to every listener,
* and inspecting changes to the {@link DragSourceEvent#doit doit} field. The
* <code>DragSource</code>'s set of supported Transfer types ({@link
* DragSource#setTransfer(Transfer[])}) is updated to reflect the Transfer types
* corresponding to the active listener subset.
* <P>
* If and when {@link #dragSetData(DragSourceEvent)} is called, a single
* <code>TransferDragSourceListener</code> is chosen, and only it is allowed to set the
* drag data. The chosen listener is the first listener in the subset of active listeners
* whose Transfer supports ({@link Transfer#isSupportedType(TransferData)}) the dataType
* on the <code>DragSourceEvent</code>.
*/
public class DelegatingDragAdapter
extends org.eclipse.jface.util.DelegatingDragAdapter
{
/**
* Adds the given TransferDragSourceListener. The set of Transfer types is updated to
* reflect the change.
*
* @param listener the new listener
* @deprecated
*/
public void addDragSourceListener(TransferDragSourceListener listener) {
super.addDragSourceListener(listener);
}
/**
* Combines the <code>Transfer</code>s from every TransferDragSourceListener.
* @return the combined <code>Transfer</code>s
* @deprecated call getTransfers() instead.
*/
public Transfer[] getTransferTypes() {
return super.getTransfers();
}
/**
* Adds the given TransferDragSourceListener. The set of Transfer types is updated to
* reflect the change.
* @param listener the listener being removed
* @deprecated
*/
public void removeDragSourceListener(TransferDragSourceListener listener) {
super.removeDragSourceListener(listener);
}
}