projects
/
sonitus.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add metadata listeners to components.
[sonitus.git]
/
src
/
main
/
java
/
net
/
pterodactylus
/
sonitus
/
data
/
source
/
MultiSource.java
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
..
1d8f289
100644
(file)
--- a/
src/main/java/net/pterodactylus/sonitus/data/source/MultiSource.java
+++ b/
src/main/java/net/pterodactylus/sonitus/data/source/MultiSource.java
@@
-21,11
+21,16
@@
import static com.google.common.base.Preconditions.checkNotNull;
import java.io.EOFException;
import java.io.IOException;
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 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.Metadata;
import net.pterodactylus.sonitus.data.Source;
+import net.pterodactylus.sonitus.data.event.MetadataUpdated;
import net.pterodactylus.sonitus.data.event.SourceFinishedEvent;
import com.google.common.eventbus.EventBus;
import net.pterodactylus.sonitus.data.event.SourceFinishedEvent;
import com.google.common.eventbus.EventBus;
@@
-38,7
+43,7
@@
import com.google.inject.Inject;
*
* @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
*/
*
* @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
*/
-public class MultiSource implements Source {
+public class MultiSource
extends AbstractControlledComponent
implements Source {
/** The logger. */
private static final Logger logger = Logger.getLogger(MultiSource.class.getName());
/** The logger. */
private static final Logger logger = Logger.getLogger(MultiSource.class.getName());
@@
-52,6
+57,12
@@
public class MultiSource implements Source {
/** Whether the source was changed. */
private boolean sourceChanged;
/** Whether the source was changed. */
private boolean sourceChanged;
+ /**
+ * Creates a new multi source.
+ *
+ * @param eventBus
+ * The event bus
+ */
@Inject
public MultiSource(EventBus eventBus) {
this.eventBus = eventBus;
@Inject
public MultiSource(EventBus eventBus) {
this.eventBus = eventBus;
@@
-76,11
+87,27
@@
public class MultiSource implements Source {
sourceChanged = true;
this.source.notifyAll();
}
sourceChanged = true;
this.source.notifyAll();
}
+ fireMetadataUpdated(source.metadata());
+ eventBus.post(new MetadataUpdated(this, source.metadata()));
logger.info(String.format("Next Source set: %s", source));
}
}
//
logger.info(String.format("Next Source set: %s", source));
}
}
//
+ // CONTROLLED METHODS
+ //
+
+ @Override
+ public String name() {
+ return "Multisource";
+ }
+
+ @Override
+ public List<Controller<?>> controllers() {
+ return Collections.emptyList();
+ }
+
+ //
// SOURCE METHODS
//
// SOURCE METHODS
//