com.github.akurilov.commons.io.collection.LimitedQueueBuffer 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.IOException;
import java.io.InterruptedIOException;
import java.util.List;
import java.util.concurrent.BlockingQueue;
/**
* The blocking queue wrapped in order to act as output from the tail and as input from the head.
*/
public class LimitedQueueBuffer
implements IoBuffer {
private T lastItem = null;
protected final BlockingQueue queue;
public LimitedQueueBuffer(final BlockingQueue queue) {
this.queue = queue;
}
/**
Non-blocking put implementation
@param item the item to put
*/
@Override
public boolean put(final T item) {
return queue.offer(item);
}
/**
Non-blocking bulk put implementation
@param buffer the buffer containing the items to put
@return the count of the items been written, may return less count than specified if not enough
free capacity is in the queue
@throws IOException doesn't throw
*/
@Override
public int put(final List buffer, final int from, final int to)
throws IOException {
int i = from;
while(i < to && queue.offer(buffer.get(i))) {
i ++;
}
return i - from;
}
@Override
public final int put(final List items)
throws IOException {
return put(items, 0, items.size());
}
/**
@return self
@throws IOException doesn't throw
*/
@Override
public LimitedQueueBuffer getInput()
throws IOException {
return this;
}
/**
Non-blocking get implementation
@return the item or null if the buffer is empty
@throws IOException doesn't throw
*/
@Override
public T get()
throws IOException {
return queue.poll();
}
/**
Non-blocking bulk get implementation
@param maxCount the count limit
@param buffer buffer for the items
@return the count of the items been get
@throws IOException if something goes wrong
*/
@Override
public int get(final List buffer, final int maxCount)
throws IOException {
try {
return queue.drainTo(buffer, maxCount);
} catch(final UnsupportedOperationException | IllegalArgumentException e) {
throw new IOException(e);
}
}
@Override
public long skip(final long itemsCount)
throws IOException {
try {
T item;
long i = 0;
for(; i < itemsCount; i++) {
item = queue.take();
if(item.equals(lastItem)) {
break;
}
}
return i;
} catch (final InterruptedException e) {
throw new InterruptedIOException(e.getMessage());
}
}
@Override
public final boolean isEmpty() {
return queue.isEmpty();
}
@Override
public final int size() {
return queue.size();
}
/**
Does nothing
@throws IOException doesn't throw
*/
@Override
public void reset()
throws IOException {
}
/**
Does nothing
@throws IOException doesn't throw
*/
@Override
public void close()
throws IOException {
queue.clear();
}
@Override
public String toString() {
return "queueBuffer#" + hashCode() + "";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy