/*
* Copyright (c) 1996, 2006, Oracle and/or its affiliates. All rights reserved.
* ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*/
package java.awt.datatransfer;
import java.io.*;
/**
* A Transferable
which implements the capability required
* to transfer a String
.
*
* This Transferable
properly supports
* DataFlavor.stringFlavor
* and all equivalent flavors. Support for
* DataFlavor.plainTextFlavor
* and all equivalent flavors is deprecated. No other
* DataFlavor
s are supported.
*
* @see java.awt.datatransfer.DataFlavor#stringFlavor
* @see java.awt.datatransfer.DataFlavor#plainTextFlavor
*/
public class StringSelection implements Transferable, ClipboardOwner {
private static final int STRING = 0;
private static final int PLAIN_TEXT = 1;
private static final DataFlavor[] flavors = {
DataFlavor.stringFlavor,
DataFlavor.plainTextFlavor // deprecated
};
private String data;
/**
* Creates a Transferable
capable of transferring
* the specified String
.
*/
public StringSelection(String data) {
this.data = data;
}
/**
* Returns an array of flavors in which this Transferable
* can provide the data. DataFlavor.stringFlavor
* is properly supported.
* Support for DataFlavor.plainTextFlavor
is
* deprecated.
*
* @return an array of length two, whose elements are DataFlavor.
* stringFlavor
and DataFlavor.plainTextFlavor
*/
public DataFlavor[] getTransferDataFlavors() {
// returning flavors itself would allow client code to modify
// our internal behavior
return (DataFlavor[])flavors.clone();
}
/**
* Returns whether the requested flavor is supported by this
* Transferable
.
*
* @param flavor the requested flavor for the data
* @return true if flavor
is equal to
* DataFlavor.stringFlavor
or
* DataFlavor.plainTextFlavor
; false if flavor
* is not one of the above flavors
* @throws NullPointerException if flavor is null
*/
public boolean isDataFlavorSupported(DataFlavor flavor) {
// JCK Test StringSelection0003: if 'flavor' is null, throw NPE
for (int i = 0; i < flavors.length; i++) {
if (flavor.equals(flavors[i])) {
return true;
}
}
return false;
}
/**
* Returns the Transferable
's data in the requested
* DataFlavor
if possible. If the desired flavor is
* DataFlavor.stringFlavor
, or an equivalent flavor,
* the String
representing the selection is
* returned. If the desired flavor is
* DataFlavor.plainTextFlavor
,
* or an equivalent flavor, a Reader
is returned.
* Note: The behavior of this method for
* DataFlavor.plainTextFlavor
* and equivalent DataFlavor
s is inconsistent with the
* definition of DataFlavor.plainTextFlavor
.
*
* @param flavor the requested flavor for the data
* @return the data in the requested flavor, as outlined above
* @throws UnsupportedFlavorException if the requested data flavor is
* not equivalent to either DataFlavor.stringFlavor
* or DataFlavor.plainTextFlavor
* @throws IOException if an IOException occurs while retrieving the data.
* By default, StringSelection never throws this exception, but a
* subclass may.
* @throws NullPointerException if flavor is null
* @see java.io.Reader
*/
public Object getTransferData(DataFlavor flavor)
throws UnsupportedFlavorException, IOException
{
// JCK Test StringSelection0007: if 'flavor' is null, throw NPE
if (flavor.equals(flavors[STRING])) {
return (Object)data;
} else if (flavor.equals(flavors[PLAIN_TEXT])) {
return new StringReader(data == null ? "" : data);
} else {
throw new UnsupportedFlavorException(flavor);
}
}
public void lostOwnership(Clipboard clipboard, Transferable contents) {
}
}