1
0
mirror of https://github.com/DanilaFe/abacus synced 2025-01-09 15:54:13 -08:00

Add comments and clear appropriate cache.

This commit is contained in:
Danila Fedorin 2017-07-27 10:58:11 -07:00
parent 07dd9d0a1a
commit 78e2d50f89

View File

@ -35,6 +35,19 @@ public class PluginManager {
cachedFunctions = new HashMap<>(); cachedFunctions = new HashMap<>();
} }
/**
* Searches the plugin list for a certain value, retrieving the Plugin's
* list of items of the type using the setFunction and getting the value
* of it is available via getFunction. If the value is contained
* in the cache, it returns the cached value instead.
* @param plugins the plugin list to search.
* @param cache the cache to use
* @param setFunction the function to retrieve a set of available T's from the plugin
* @param getFunction the function to get the T value under the given name
* @param name the name to search for
* @param <T> the type of element being search
* @return the retrieved element, or null if it was not found.
*/
private static <T> T searchCached(Collection<Plugin> plugins, Map<String, T> cache, private static <T> T searchCached(Collection<Plugin> plugins, Map<String, T> cache,
java.util.function.Function<Plugin, Set<String>> setFunction, java.util.function.Function<Plugin, Set<String>> setFunction,
java.util.function.BiFunction<Plugin, String, T> getFunction, java.util.function.BiFunction<Plugin, String, T> getFunction,
@ -77,6 +90,7 @@ public class PluginManager {
public void addInstantiated(Plugin plugin){ public void addInstantiated(Plugin plugin){
plugin.load(); plugin.load();
cachedFunctions.clear(); cachedFunctions.clear();
cachedOperators.clear();
plugins.add(plugin); plugins.add(plugin);
} }