import org.asamk.signal.DbusConfig;
import org.asamk.signal.DbusReceiveMessageHandler;
-import org.asamk.signal.JsonDbusReceiveMessageHandler;
+import org.asamk.signal.JsonReceiveMessageHandler;
import org.asamk.signal.JsonWriter;
import org.asamk.signal.OutputType;
import org.asamk.signal.OutputWriter;
import org.asamk.signal.PlainTextWriter;
+import org.asamk.signal.ReceiveMessageHandler;
import org.asamk.signal.commands.exceptions.CommandException;
import org.asamk.signal.commands.exceptions.UnexpectedErrorException;
import org.asamk.signal.dbus.DbusSignalControlImpl;
import java.io.IOException;
import java.util.List;
-import java.util.concurrent.TimeUnit;
public class DaemonCommand implements MultiLocalCommand {
try {
t.join();
+ synchronized (this) {
+ wait();
+ }
} catch (InterruptedException ignored) {
}
} catch (DBusException | IOException e) {
logger.info("Exported dbus object: " + objectPath);
- final var thread = new Thread(() -> {
- while (!Thread.interrupted()) {
- try {
- final var receiveMessageHandler = outputWriter instanceof JsonWriter
- ? new JsonDbusReceiveMessageHandler(m, (JsonWriter) outputWriter, conn, objectPath)
- : new DbusReceiveMessageHandler(m, (PlainTextWriter) outputWriter, conn, objectPath);
- m.receiveMessages(1, TimeUnit.HOURS, false, receiveMessageHandler);
- break;
- } catch (IOException e) {
- logger.warn("Receiving messages failed, retrying", e);
- }
- }
- try {
- initThread.join();
- } catch (InterruptedException ignored) {
- }
- signal.close();
- });
+ final var handler = outputWriter instanceof JsonWriter ? new JsonReceiveMessageHandler(m,
+ (JsonWriter) outputWriter) : new ReceiveMessageHandler(m, (PlainTextWriter) outputWriter);
+ m.addReceiveHandler(handler);
- thread.start();
+ final var dbusMessageHandler = new DbusReceiveMessageHandler(m, conn, objectPath);
+ m.addReceiveHandler(dbusMessageHandler);
- return thread;
+ return initThread;
}
}