import java.io.IOException;
import java.util.concurrent.ExecutionException;
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.ConfigData;
import net.pterodactylus.fcp.ModifyConfig;
*/
public class ModifyConfigCommandImpl implements ModifyConfigCommand {
- private final ModifyConfig modifyConfig = new ModifyConfig(new RandomIdentifierGenerator().generate());
private final ListeningExecutorService threadPool;
private final ConnectionSupplier connectionSupplier;
+ private final ModifyConfig modifyConfig;
- public ModifyConfigCommandImpl(ExecutorService threadPool, ConnectionSupplier connectionSupplier) {
+ public ModifyConfigCommandImpl(ExecutorService threadPool, ConnectionSupplier connectionSupplier, Supplier<String> identifierGenerator) {
this.threadPool = MoreExecutors.listeningDecorator(threadPool);
this.connectionSupplier = connectionSupplier;
+ modifyConfig = new ModifyConfig(identifierGenerator.get());
}
@Override
private class ModifyConfigDialog extends FcpDialog<ConfigData> {
- private final AtomicBoolean finished = new AtomicBoolean();
- private final AtomicReference<ConfigData> configData = new AtomicReference<>();
-
public ModifyConfigDialog() throws IOException {
- super(threadPool, connectionSupplier.get());
- }
-
- @Override
- protected boolean isFinished() {
- return finished.get();
- }
-
- @Override
- protected ConfigData getResult() {
- return configData.get();
+ super(threadPool, connectionSupplier.get(), null);
}
@Override
protected void consumeConfigData(ConfigData configData) {
- this.configData.set(configData);
- finished.set(true);
+ setResult(configData);
}
}