X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsonitus%2Fdata%2Fsource%2FMultiSource.java;h=21239863299dce47bc6ed726a400a8a21ac71433;hb=cbeadf6d9eea57ab98cacd60e2419dd3c18bef89;hp=a1d0202f957aabbfd48ad4491eee317db61d0472;hpb=09f8bd2297dc864e24baa67c65be97104e00c320;p=sonitus.git
diff --git a/src/main/java/net/pterodactylus/sonitus/data/source/MultiSource.java b/src/main/java/net/pterodactylus/sonitus/data/source/MultiSource.java
index a1d0202..2123986 100644
--- a/src/main/java/net/pterodactylus/sonitus/data/source/MultiSource.java
+++ b/src/main/java/net/pterodactylus/sonitus/data/source/MultiSource.java
@@ -26,8 +26,8 @@ import java.util.List;
import java.util.concurrent.atomic.AtomicReference;
import java.util.logging.Logger;
+import net.pterodactylus.sonitus.data.AbstractControlledComponent;
import net.pterodactylus.sonitus.data.Controller;
-import net.pterodactylus.sonitus.data.Metadata;
import net.pterodactylus.sonitus.data.Source;
import net.pterodactylus.sonitus.data.event.SourceFinishedEvent;
@@ -41,7 +41,7 @@ import com.google.inject.Inject;
*
* @author David âBombeâ Roden
*/
-public class MultiSource implements Source {
+public class MultiSource extends AbstractControlledComponent implements Source {
/** The logger. */
private static final Logger logger = Logger.getLogger(MultiSource.class.getName());
@@ -55,8 +55,12 @@ public class MultiSource implements Source {
/** Whether the source was changed. */
private boolean sourceChanged;
+ /**
+ * Creates a new multi source.
+ */
@Inject
public MultiSource(EventBus eventBus) {
+ super("Multisource");
this.eventBus = eventBus;
}
@@ -79,6 +83,7 @@ public class MultiSource implements Source {
sourceChanged = true;
this.source.notifyAll();
}
+ metadataUpdated(source.metadata());
logger.info(String.format("Next Source set: %s", source));
}
}
@@ -88,11 +93,6 @@ public class MultiSource implements Source {
//
@Override
- public String name() {
- return "Multisource";
- }
-
- @Override
public List> controllers() {
return Collections.emptyList();
}
@@ -102,11 +102,6 @@ public class MultiSource implements Source {
//
@Override
- public Metadata metadata() {
- return source.get().metadata();
- }
-
- @Override
public byte[] get(int bufferSize) throws EOFException, IOException {
while (true) {
try {