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

com.jpattern.service.log.reader.QueueMessages Maven / Gradle / Ivy

There is a newer version: 3.6.2
Show newest version
package com.jpattern.service.log.reader;

import java.util.List;
import java.util.Vector;

/**
 * @author Francesco Cina 07/ago/2009
 */

public class QueueMessages implements IQueueMessages {

	private static final long serialVersionUID = 1L;

	private int _maxCodaLenght = 1;

	private List messageList = new Vector();
	private Long lastMessageId = 0l;
	private Long firstMessageId = 0l;
	
    public QueueMessages(int maxCodaLength) {
        if (maxCodaLength > 1) {
            _maxCodaLenght = maxCodaLength;
        }
    }

    public int size() {
        return messageList.size();
    }

    public void offer(String aMessage) {
    	synchronized (messageList) {
    		if (messageList.size() >= _maxCodaLenght) {
    			 synchronized (firstMessageId) {
    				 firstMessageId++;
    				 messageList.remove(0);
    			 }
            }
    		synchronized (lastMessageId) {
    			 messageList.add(new QueueMessage(lastMessageId, aMessage, true));
    			 lastMessageId++;
    		}
		}
    }

    public IQueueMessage peek() {
    	synchronized (messageList) {
	        if (messageList.size() == 0) {
	            return new QueueMessage(0, "", false);
	        }
	        return messageList.get(0);
    	}
    }

    public IQueueMessage poll() {
    	synchronized (messageList) {
	        if (messageList.size() == 0) {
	        	return new QueueMessage(0, "", false);
	        }
	        IQueueMessage result = messageList.get(0);
	        messageList.remove(0);
	        return result;
    	}
    }

	public IQueueMessage get(long index) {
		if (index == -1l) {
			return peek();
		}
    	synchronized (messageList) {
	        if (index < firstMessageId || index >= lastMessageId) {
	            return new QueueMessage(index, "", false);
	        }
	        return  messageList.get( (int) (index - firstMessageId) );
    	}
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy