edu.cmu.tetradapp.editor.SubgraphSelection Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
// For information as to what this class does, see the Javadoc, below. //
// Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, //
// 2007, 2008, 2009, 2010, 2014, 2015, 2022 by Peter Spirtes, Richard //
// Scheines, Joseph Ramsey, and Clark Glymour. //
// //
// This program is free software; you can redistribute it and/or modify //
// it under the terms of the GNU General Public License as published by //
// the Free Software Foundation; either version 2 of the License, or //
// (at your option) any later version. //
// //
// This program is distributed in the hope that it will be useful, //
// but WITHOUT ANY WARRANTY; without even the implied warranty of //
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the //
// GNU General Public License for more details. //
// //
// You should have received a copy of the GNU General Public License //
// along with this program; if not, write to the Free Software //
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA //
///////////////////////////////////////////////////////////////////////////////
package edu.cmu.tetradapp.editor;
import edu.cmu.tetrad.graph.Edge;
import edu.cmu.tetrad.graph.Node;
import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.Transferable;
import java.awt.datatransfer.UnsupportedFlavorException;
import java.io.IOException;
import java.rmi.MarshalledObject;
import java.util.List;
/**
* Holds a list of graph nodes for cut/paste operations. Note that a deep clone of the graph elements list is made on
* creation, and once the data is retrieved, it is deleted.
*
* @author josephramsey
*/
class SubgraphSelection implements Transferable {
/**
* Supported dataflavors--only one.
*/
private final DataFlavor[] dataFlavors = {
new DataFlavor(SubgraphSelection.class, "Subgraph Selection")};
/**
* The list of graph nodes that constitutes the selection.
*/
private List graphElements;
/**
* Constructs a new selection with the given list of graph nodes.
*/
public SubgraphSelection(List graphElements) {
if (graphElements == null) {
throw new NullPointerException(
"List of graph elements must " + "not be null.");
}
for (Object graphElement : graphElements) {
if (!(graphElement instanceof Node ||
graphElement instanceof Edge)) {
throw new IllegalArgumentException("Model node list contains " +
"an object that is not a Node or an Edge: " +
graphElement);
}
}
Object result;
try {
result = new MarshalledObject(graphElements).get();
} catch (Exception e1) {
e1.printStackTrace();
throw new IllegalStateException("Could not clone.");
}
this.graphElements = (List) result;
}
/**
* @param flavor the requested flavor for the data
* @return an object which represents the data to be transferred. The class of the object returned is defined by
* the representation class of the flavor.
* @throws IOException if the data is no longer available in the requested flavor.
* @throws UnsupportedFlavorException if the requested data flavor is not supported.
* @see DataFlavor#getRepresentationClass
*/
public Object getTransferData(DataFlavor flavor)
throws UnsupportedFlavorException, IOException {
if (!isDataFlavorSupported(flavor)) {
throw new UnsupportedFlavorException(flavor);
}
List returnList = this.graphElements;
this.graphElements = null;
return returnList;
}
/**
* @param flavor the requested flavor for the data
* @return whether or not the specified data flavor is supported for this object.
*/
public boolean isDataFlavorSupported(DataFlavor flavor) {
return flavor.equals(getTransferDataFlavors()[0]);
}
/**
* @return an array of DataFlavor objects indicating the flavors the data can be provided in. The array should be
* ordered according to preference for providing the data (from most richly descriptive to least descriptive).
*/
public DataFlavor[] getTransferDataFlavors() {
return this.dataFlavors;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy