import java.util.concurrent.ExecutorService;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicReference;
+import java.util.function.Supplier;
import net.pterodactylus.fcp.PluginInfo;
import net.pterodactylus.fcp.ProtocolError;
*/
public class ReloadPluginCommandImpl implements ReloadPluginCommand {
- private static final RandomIdentifierGenerator IDENTIFIER = new RandomIdentifierGenerator();
private final ListeningExecutorService threadPool;
private final ConnectionSupplier connectionSupplier;
- private final ReloadPlugin reloadPlugin = new ReloadPlugin(IDENTIFIER.generate());
+ private final ReloadPlugin reloadPlugin;
- public ReloadPluginCommandImpl(ExecutorService threadPool, ConnectionSupplier connectionSupplier) {
+ public ReloadPluginCommandImpl(ExecutorService threadPool, ConnectionSupplier connectionSupplier, Supplier<String> identifierGenerator) {
this.threadPool = MoreExecutors.listeningDecorator(threadPool);
this.connectionSupplier = connectionSupplier;
+ reloadPlugin = new ReloadPlugin(identifierGenerator.get());
}
@Override
}
@Override
+ public ReloadPluginCommand addToConfig() {
+ reloadPlugin.setStore(true);
+ return this;
+ }
+
+ @Override
public Executable<Optional<PluginInfo>> plugin(String pluginClassName) {
reloadPlugin.setPluginName(pluginClassName);
return this::execute;
}
private Optional<PluginInfo> executeDialog() throws IOException, ExecutionException, InterruptedException {
- try (ReloadPluginDialog loadPluginDialog = new ReloadPluginDialog()) {
- return loadPluginDialog.send(reloadPlugin).get();
+ try (ReloadPluginDialog reloadPluginDialog = new ReloadPluginDialog()) {
+ return reloadPluginDialog.send(reloadPlugin).get();
}
}