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=b5705d5a76e6d144a6bcb4862e4dabc7d155d1f9;hpb=7188da95cfb6dc2bf140eb8ac7e4dc99a0761a97;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 b5705d5..2123986 100644 --- a/src/main/java/net/pterodactylus/sonitus/data/source/MultiSource.java +++ b/src/main/java/net/pterodactylus/sonitus/data/source/MultiSource.java @@ -21,10 +21,13 @@ import static com.google.common.base.Preconditions.checkNotNull; import java.io.EOFException; import java.io.IOException; +import java.util.Collections; +import java.util.List; import java.util.concurrent.atomic.AtomicReference; import java.util.logging.Logger; -import net.pterodactylus.sonitus.data.Metadata; +import net.pterodactylus.sonitus.data.AbstractControlledComponent; +import net.pterodactylus.sonitus.data.Controller; import net.pterodactylus.sonitus.data.Source; import net.pterodactylus.sonitus.data.event.SourceFinishedEvent; @@ -38,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()); @@ -52,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; } @@ -76,19 +83,24 @@ public class MultiSource implements Source { sourceChanged = true; this.source.notifyAll(); } + metadataUpdated(source.metadata()); logger.info(String.format("Next Source set: %s", source)); } } // - // SOURCE METHODS + // CONTROLLED METHODS // @Override - public Metadata metadata() { - return source.get().metadata(); + public List> controllers() { + return Collections.emptyList(); } + // + // SOURCE METHODS + // + @Override public byte[] get(int bufferSize) throws EOFException, IOException { while (true) {