2017-07-25 21:50:30 -07:00
|
|
|
package org.nwapw.abacus.plugin;
|
|
|
|
|
2017-07-25 21:57:14 -07:00
|
|
|
import org.nwapw.abacus.function.Function;
|
2017-07-25 21:50:30 -07:00
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* A plugin class that can be externally implemented and loaded via the
|
|
|
|
* plugin manager. Plugins provide functionality to the calculator
|
|
|
|
* with the "hasFunction" and "getFunction" functions,
|
|
|
|
* and can use "registerFunction" and "functionFor" for
|
|
|
|
* loading internally.
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
public abstract class Plugin {
|
|
|
|
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* A hash map of functions mapped to their string names.
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
private HashMap<String, Function> functions;
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* The plugin manager in which to search for functions
|
|
|
|
* not inside this package,
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
private PluginManager manager;
|
|
|
|
|
|
|
|
private Plugin(){ }
|
|
|
|
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* Creates a new plugin with the given PluginManager.
|
|
|
|
* @param manager the manager controlling this plugin.
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
public Plugin(PluginManager manager) {
|
|
|
|
this.manager = manager;
|
|
|
|
functions = new HashMap<>();
|
|
|
|
}
|
|
|
|
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* Determines whether the current plugin provides the given function name.
|
|
|
|
* @param functionName the name of the function provided.
|
|
|
|
* @return true of the function exists, false if it doesn't.
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
public final boolean hasFunction(String functionName) {
|
|
|
|
return functions.containsKey(functionName);
|
|
|
|
}
|
|
|
|
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* Gets a function under the given function name.
|
|
|
|
* @param functionName the name of the function to get
|
|
|
|
* @return the function, or null if this plugin doesn't provide it.
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
public final Function getFunction(String functionName) {
|
|
|
|
return functions.get(functionName);
|
|
|
|
}
|
|
|
|
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* To be used in load(). Registers a function abstract class with the
|
|
|
|
* plugin internally, which makes it accessible to the plugin manager.
|
|
|
|
* @param name the name to register by.
|
|
|
|
* @param toRegister the function implementation.
|
|
|
|
* @return true if the function was registered successfully, false if not.
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
protected final boolean registerFunction(String name, Function toRegister) {
|
|
|
|
if(functionFor(name) == null){
|
|
|
|
functions.put(name, toRegister);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* Searches the PluginManager for the given function name.
|
|
|
|
* This can be used by the plugins internally in order to call functions
|
|
|
|
* they do not provide.
|
|
|
|
* @param name then name for which to search
|
|
|
|
* @return the resulting function, or null if none was found for that name.
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
protected final Function functionFor(String name) {
|
2017-07-26 10:10:37 -07:00
|
|
|
return manager.functionFor(name);
|
2017-07-25 21:50:30 -07:00
|
|
|
}
|
|
|
|
|
2017-07-26 10:10:37 -07:00
|
|
|
/**
|
|
|
|
* Abstract method to be overridden by plugin implementation, in which the plugins
|
|
|
|
* are supposed to register the functions they provide and do any other
|
|
|
|
* necessary setup.
|
|
|
|
*/
|
2017-07-25 21:50:30 -07:00
|
|
|
public abstract void load();
|
|
|
|
|
|
|
|
}
|