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

com.emc.mongoose.common.io.collection.CircularListOutput Maven / Gradle / Ivy

The newest version!
package com.emc.mongoose.common.io.collection;

import org.apache.commons.collections4.list.UnmodifiableList;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

/**
 The data items input which may be written infinitely (if underlying collection allows that).
 */
public class CircularListOutput
extends ListOutput {

	protected int capacity, i = 0;

	public CircularListOutput(final List itemList, final int capacity)
	throws IllegalArgumentException {
		super(itemList);
		if(ArrayList.class.isInstance(itemList)) {
			ArrayList.class.cast(itemList).ensureCapacity(capacity);
		}
		if(capacity < 1) {
			throw new IllegalArgumentException("Capacity should be > 0");
		}
		this.capacity = capacity;
	}

	/**
	 @param item the data item to put
	 @throws IOException if the destination collection fails to add the data item
	 */
	@Override
	public boolean put(final T item)
	throws IOException {
		if(items.size() < capacity) {
			if(!super.put(item)) {
				return false;
			}
		} else {
			if(i >= capacity) {
				i = 0;
			}
			items.set(i, item);
		}
		i ++;
		return true;
	}

	/**
	 Bulk circular put method
	 @param buffer the list of the items to put in a batch mode
	 @throws IOException if the destination collection fails to add the data items
	 @return the size of the buffer to put
	 */
	@Override
	public int put(final List buffer, final int from, final int to)
	throws IOException {
		//
		int n = to - from;
		if(buffer.size() > n) {
			return put(buffer.subList(from, to), 0, n);
		}
		//
		n = buffer.size();
		if(n < capacity) {
			// buffer may be placed entirely into the capacitor
			final int limit = capacity - items.size(); // how many free space is in the capacitor;
			if(n > limit) {
				// should remove some items from the beginning of the capacitor in order to place
				// the buffer entirely
				items.removeAll(items.subList(0, n - limit));
			}
			for(final T item : buffer) {
				items.add(item);
			}
		} else {
			// only a tail part of the buffer may be placed into the capacitor
			items.clear(); // discard all the items in the capacitor
			for(final T item : buffer.subList(n - capacity, n)) {
				items.add(item);
			}
		}
		return n;
	}

	/**
	 @return the corresponding input
	 @throws IOException doesn't throw
	 */
	@Override
	public CircularListInput getInput()
	throws IOException {
		return new CircularListInput<>(new UnmodifiableList<>(items));
	}

	@Override
	public final String toString() {
		return "circularItemOutput<" + items.hashCode() + ">";
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy