- /*
 - * @(#)StringSelection.java 1.14 01/02/09
 - *
 - * Copyright 1996-2001 Sun Microsystems, Inc. All Rights Reserved.
 - *
 - * This software is the proprietary information of Sun Microsystems, Inc.
 - * 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 <code>DataFlavor.stringFlavor</code>
 - * and all equivalent flavors. Support for <code>DataFlavor.plainTextFlavor
 - * </code> and all equivalent flavors is <b>deprecated</b>. No other
 - * DataFlavors 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. <code>DataFlavor.stringFlavor</code> is properly supported.
 - * Support for <code>DataFlavor.plainTextFlavor</code> is
 - * <b>deprecated</b>.
 - *
 - * @return an array of length two, whose elements are <code>DataFlavor.
 - * stringFlavor</code> and <code>DataFlavor.plainTextFlavor</code>.
 - */
 - 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 <code>flavor</code> is equal to
 - * <code>DataFlavor.stringFlavor</code> or
 - * <code>DataFlavor.plainTextFlavor</code> false if <code>flavor</code>
 - * is not one of the above flavors
 - * @throws NullPointerException if flavor is <code>null</code>
 - */
 - 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 <code>DataFlavor.stringFlavor</code>,
 - * or an equivalent flavor, the String representing the selection is
 - * returned. If the desired flavor is </code>DataFlavor.plainTextFlavor
 - * </code>, or an equivalent flavor, a Reader is returned. <b>Note:<b>
 - * The behavior of this method for </code>DataFlavor.plainTextFlavor</code>
 - * and equivalent DataFlavors is inconsistent with the definition of
 - * <code>DataFlavor.plainTextFlavor</code>.
 - *
 - * @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 <code>DataFlavor.stringFlavor</code>
 - * or <code>DataFlavor.plainTextFlavor</code>.
 - * @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 <code>null</code>
 - * @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);
 - } else {
 - throw new UnsupportedFlavorException(flavor);
 - }
 - }
 - public void lostOwnership(Clipboard clipboard, Transferable contents) {
 - }
 - }