com.github.akurilov.commons.io.collection.BufferingInputBase Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of java-commons Show documentation
Show all versions of java-commons Show documentation
Common functionality Java library
package com.github.akurilov.commons.io.collection;
import java.io.EOFException;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import static com.github.akurilov.commons.lang.Exceptions.throwUnchecked;
/**
* An abstract input which is designed to load more items when it's needed to get more items.
* Not thread safe.
*/
public abstract class BufferingInputBase
extends ListInput {
protected final int capacity;
public BufferingInputBase(final int capacity) {
super(new ArrayList<>(capacity));
this.capacity = capacity;
}
private int loadMore() {
final var lastItem = size > 0 ? items.get(size - 1) : null;
i = 0;
items.clear();
try {
return size = loadMoreItems(lastItem);
} catch(final IOException e) {
throwUnchecked(e);
}
return 0;
}
/**
Called when the elements buffer is exhausted. Should put more (but not more than "capacity")
new elements into the empty buffer.
@return the count of the items was actually loaded into the "items" buffer or 0 if no more items are available.
*/
protected abstract int loadMoreItems(final T lastItem)
throws IOException;
@Override
public final T get() {
if(i == size) {
if(loadMore() <= 0) {
throwUnchecked(new EOFException());
}
}
return items.get(i ++);
}
@Override
public final int get(final List buffer, final int maxCount) {
var n = size - i;
if(n == 0) {
if(loadMore() <= 0) {
throwUnchecked(new EOFException());
}
}
n = Math.min(size - i, maxCount);
for(var j = i; j < i + n; j ++) {
buffer.add(items.get(j));
}
i += n;
return n;
}
@Override
public void close() {
items.clear();
super.close();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy