All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.akurilov.commons.io.collection.LimitedQueueBuffer Maven / Gradle / Ivy

package com.github.akurilov.commons.io.collection;

import java.io.InterruptedIOException;
import java.util.List;
import java.util.concurrent.BlockingQueue;

import static com.github.akurilov.commons.lang.Exceptions.throwUnchecked;

/**
 * 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
	 */
	@Override
	public int put(final List buffer, final int from, final int to) {
		int i = from;
		while(i < to && queue.offer(buffer.get(i))) {
			i ++;
		}
		return i - from;
	}
	
	@Override
	public final int put(final List items) {
		return put(items, 0, items.size());
	}

	/**
	 @return self
	 */
	@Override
	public LimitedQueueBuffer getInput() {
		return this;
	}

	/**
	 Non-blocking get implementation
	 @return the item or null if the buffer is empty
	 */
	@Override
	public T get() {
		return queue.poll();
	}

	/**
	 Non-blocking bulk get implementation
	 @param maxCount the count limit
	 @param buffer buffer for the items
	 @throws UnsupportedOperationException
	 @throws IllegalArgumentException
	 @return the count of the items been get
	 */
	@Override
	public int get(final List buffer, final int maxCount)
	throws UnsupportedOperationException, IllegalArgumentException {
		return queue.drainTo(buffer, maxCount);
	}
	
	@Override
	public long skip(final long itemsCount) {
		try {
			T item;
			long i = 0;
			for(; i < itemsCount; i++) {
				item = queue.take();
				if(item.equals(lastItem)) {
					break;
				}
			}
			return i;
		} catch (final InterruptedException e) {
			throwUnchecked(e);
			return 0;
		}
	}
	
	@Override
	public final boolean isEmpty() {
		return queue.isEmpty();
	}
	
	@Override
	public final int size() {
		return queue.size();
	}

	/**
	 Does nothing
	 */
	@Override
	public void reset() {
	}

	/**
	 Does nothing
	 */
	@Override
	public void close() {
		queue.clear();
	}
	
	@Override
	public String toString() {
		return "queueBuffer#" + hashCode() + "";
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy