net.maizegenetics.plugindef.Plugin Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tassel Show documentation
Show all versions of tassel Show documentation
TASSEL is a software package to evaluate traits associations, evolutionary patterns, and linkage
disequilibrium.
/*
* Plugin.java
*
*/
package net.maizegenetics.plugindef;
import net.maizegenetics.util.ProgressListener;
import javax.swing.*;
import java.awt.*;
import java.lang.reflect.Constructor;
import java.util.Map;
import org.apache.log4j.Logger;
/**
*
* @author Terry Casstevens
*/
public interface Plugin extends PluginListener, ProgressListener, Runnable {
enum PARAMETER_PROPERTIES {Plugin, Parameter, Required, Default, Description}
/**
* Returns menu that can be added to main menu bar.
*
* @return menu
*/
public JMenu getMenu();
/**
* Performs function of this plugin.
*
* @param input input
*
* @return resulting data set or null.
*/
public DataSet performFunction(DataSet input);
/**
* For the new Generic Plugin Parameter design, performFunction() will
* automatically call this. Therefore, coders of Plugins should override
* this instead of performFunction().
*
* @param input input
*
* @return resulting data set or null.
*/
public DataSet processData(DataSet input);
/**
* Returns parameter value for given parameter key.
*
* @param key key
*
* @return value
*/
public Object getParameter(Enum key);
/**
* Returns parameter value for given parameter key.
*
* @param key key
*
* @return value
*/
public Object getParameter(String key);
/**
* Sets parameter value for a given plugin
*
* @param param parameter
* @param value value
*
* @return this plugin
*/
public Plugin setParameter(PluginParameter> param, Object value);
/**
* Sets parameter value for given parameter key.
*
* @param key key
* @param value value
*
* @return this plugin
*/
public Plugin setParameter(String key, Object value);
/**
* Sets parameter value for given parameter key.
*
* @param key key
* @param value value
*
* @return this plugin
*/
public Plugin setParameter(String key, String value);
/**
* Sets all parameter values to default.
*/
public void setParametersToDefault();
/**
* Get map of plugin parameters. Key is command line name
* and value is current value.
*
* @return map of parameter values
*/
public Map pluginParameters();
/**
* Sets up this plugin to receive input from another plugin.
*
* @param input input
*/
public void receiveInput(Plugin input);
/**
* GUI Panel for this plugin.
*
* @return panel
*/
public JPanel getPanel();
/**
* If interactive = true, the plugin will create dialogs and panels to
* interacts with the user
*
* @return boolean
*/
public boolean isInteractive();
/**
* Parent Frame for this plugin. Can be null.
*
* @return frame
*/
public Frame getParentFrame();
/**
* Icon for this plugin to be used in buttons, etc.
*
* @return ImageIcon
*/
public ImageIcon getIcon();
/**
* Button name for this plugin to be used in buttons, etc.
*
* @return String
*/
public String getButtonName();
/**
* Tool Tip Text for this plugin
*
* @return String
*/
public String getToolTipText();
/**
* Adds listener to this plugin.
*
* @param listener listener to add
*/
public void addListener(PluginListener listener);
/**
* Set whether this plugin is threaded.
*
* @param threaded whether to be threaded.
*/
public void setThreaded(boolean threaded);
/**
* Attempt to cancel processing.
*
* @return true if plugin will cancel itself.
*/
public boolean cancel();
/**
* Allows self-describing Plugins to use args to set parameters specific to
* itself.
*
* @param args arguments
*/
public void setParameters(String[] args);
/**
* Returns Citation for this plugin.
*
* @return Citation
*/
public String getCitation();
/**
* Returns description of the plugin.
*
* @return description
*/
public String pluginDescription();
/**
* Returns URL to User Manual.
*
* @return URL
*/
public String pluginUserManualURL();
/**
* Gets the Usage Statement for this Plugin.
*
* @return Usage Statement
*/
public String getUsage();
public boolean wasCancelled();
static final Logger myLogger = Logger.getLogger(Plugin.class);
public static Plugin getPluginInstance(String className, Frame frame) {
return getPluginInstance(className, frame, false);
}
/**
* Gets instance of Plugin
*
* @param className class name
* @param frame frame (can be null)
* @param isInteractive is interactive
*
* @return Plugin
*/
public static Plugin getPluginInstance(String className, Frame frame, boolean isInteractive) {
try {
Class currentMatch = Class.forName(className);
Constructor constructor = currentMatch.getConstructor(Frame.class, boolean.class);
return (Plugin) constructor.newInstance(frame, isInteractive);
} catch (Exception ex) {
try {
Class currentMatch = Class.forName(className);
Constructor constructor = currentMatch.getConstructor(Frame.class);
return (Plugin) constructor.newInstance(frame);
} catch (NoSuchMethodException nsme) {
myLogger.warn("Self-describing Plugins should implement this constructor: " + className);
myLogger.warn("public Plugin(Frame parentFrame, boolean isInteractive) {");
myLogger.warn(" super(parentFrame, isInteractive);");
myLogger.warn("}");
return null;
} catch (Exception e) {
myLogger.debug(e.getMessage(), e);
return null;
}
}
}
/**
* Returns whether given class name is Plugin.
*
* @param className class name
*
* @return true if class is Plugin
*/
public static boolean isPlugin(String className) {
try {
Class currentMatch = Class.forName(className);
return !currentMatch.isInterface() && Plugin.class.isAssignableFrom(currentMatch);
} catch (Exception ex) {
return false;
} catch (Error err) {
return false;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy