From a599824291cdc573749e58eefdc1869253e3233d Mon Sep 17 00:00:00 2001 From: "Benjamin J. Culkin" Date: Mon, 11 Sep 2017 12:35:08 -0300 Subject: Fix misc. compile errors --- .../bjc/utils/ioutils/blocks/BoundBlockReader.java | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) (limited to 'BJC-Utils2/src/main/java/bjc/utils/ioutils/blocks/BoundBlockReader.java') diff --git a/BJC-Utils2/src/main/java/bjc/utils/ioutils/blocks/BoundBlockReader.java b/BJC-Utils2/src/main/java/bjc/utils/ioutils/blocks/BoundBlockReader.java index 3c9a872..b1e82d7 100644 --- a/BJC-Utils2/src/main/java/bjc/utils/ioutils/blocks/BoundBlockReader.java +++ b/BJC-Utils2/src/main/java/bjc/utils/ioutils/blocks/BoundBlockReader.java @@ -2,26 +2,34 @@ package bjc.utils.ioutils.blocks; import java.io.IOException; +import java.util.function.BooleanSupplier; import java.util.function.Supplier; public class BoundBlockReader implements BlockReader { + @FunctionalInterface + public interface Closer { + public void close() throws IOException; + } + private BooleanSupplier checker; private Supplier getter; + private Closer closer; private Block current; private int blockNo; - public BoundBlockReader(BooleanSupplier blockChecker, Supplier blockGetter) { + public BoundBlockReader(BooleanSupplier blockChecker, Supplier blockGetter, Closer blockCloser) { checker = blockChecker; getter = blockGetter; + closer = blockCloser; - blockNo += 1; + blockNo = 0; } @Override public boolean hasNextBlock() { - return blockChecker.getAsBoolean(); + return checker.getAsBoolean(); } @Override @@ -45,4 +53,9 @@ public class BoundBlockReader implements BlockReader { public int getBlockCount() { return blockNo; } + + @Override + public void close() throws IOException { + closer.close(); + } } -- cgit v1.2.3