projects
/
sonitus.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Move event and metadata handling into abstract base class.
[sonitus.git]
/
src
/
main
/
java
/
net
/
pterodactylus
/
sonitus
/
data
/
sink
/
FileSink.java
diff --git
a/src/main/java/net/pterodactylus/sonitus/data/sink/FileSink.java
b/src/main/java/net/pterodactylus/sonitus/data/sink/FileSink.java
index
61e0a27
..
be934f3
100644
(file)
--- a/
src/main/java/net/pterodactylus/sonitus/data/sink/FileSink.java
+++ b/
src/main/java/net/pterodactylus/sonitus/data/sink/FileSink.java
@@
-17,24
+17,24
@@
package net.pterodactylus.sonitus.data.sink;
package net.pterodactylus.sonitus.data.sink;
-import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.FileOutputStream;
import java.io.IOException;
+import java.util.Collections;
+import java.util.List;
import java.util.logging.Logger;
import java.util.logging.Logger;
-import net.pterodactylus.sonitus.data.ConnectException;
-import net.pterodactylus.sonitus.data.Connection;
+import net.pterodactylus.sonitus.data.AbstractControlledComponent;
+import net.pterodactylus.sonitus.data.Controller;
+import net.pterodactylus.sonitus.data.Metadata;
import net.pterodactylus.sonitus.data.Sink;
import net.pterodactylus.sonitus.data.Sink;
-import net.pterodactylus.sonitus.data.Source;
-
-import com.google.common.base.Preconditions;
/**
/**
- * {@link Sink} that writes all received data into a file.
+ * {@link net.pterodactylus.sonitus.data.Sink} that writes all received data
+ * into a file.
*
* @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
*/
*
* @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
*/
-public class FileSink implements Sink {
+public class FileSink
extends AbstractControlledComponent
implements Sink {
/** The logger. */
private static final Logger logger = Logger.getLogger(FileSink.class.getName());
/** The logger. */
private static final Logger logger = Logger.getLogger(FileSink.class.getName());
@@
-42,6
+42,9
@@
public class FileSink implements Sink {
/** The path of the file to write to. */
private final String path;
/** The path of the file to write to. */
private final String path;
+ /** The output stream writing to the file. */
+ private FileOutputStream fileOutputStream;
+
/**
* Creates a new file sink that will write to the given path.
*
/**
* Creates a new file sink that will write to the given path.
*
@@
-49,41
+52,42
@@
public class FileSink implements Sink {
* The path of the file to write to
*/
public FileSink(String path) {
* The path of the file to write to
*/
public FileSink(String path) {
+ super(path);
this.path = path;
}
this.path = path;
}
- @Override
- public void connect(Source source) throws ConnectException {
- Preconditions.checkNotNull(source, "source must not be null");
+ //
+ // CONTROLLED METHODS
+ //
- try {
- final FileOutputStream fileOutputStream = new FileOutputStream(path);
- new Thread(new Connection(source) {
+ @Override
+ public List<Controller<?>> controllers() {
+ return Collections.emptyList();
+ }
- @Override
- protected int bufferSize() {
- return 65536;
- }
+ //
+ // SINK METHODS
+ //
-
@Override
-
protected void feed(byte[] buffer
) throws IOException {
-
fileOutputStream.write(buffer
);
-
logger.finest(String.format("FileSink: Wrote %d Bytes.", buffer.length)
);
-
}
+ @Override
+
public void open(Metadata metadata
) throws IOException {
+
fileOutputStream = new FileOutputStream(path
);
+
metadataUpdated(metadata
);
+ }
- @Override
- protected void finish() throws IOException {
- fileOutputStream.close();
- }
- }).start();
- } catch (FileNotFoundException fnfe1) {
- throw new ConnectException(fnfe1);
+ @Override
+ public void close() {
+ try {
+ fileOutputStream.close();
+ } catch (IOException e) {
+ /* ignore. */
}
}
@Override
}
}
@Override
- public void metadataUpdated() {
- /* ignore. */
+ public void process(byte[] buffer) throws IOException {
+ fileOutputStream.write(buffer);
+ logger.finest(String.format("FileSink: Wrote %d Bytes.", buffer.length));
}
}
}
}