package dataBase;

import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedList;

import javax.imageio.ImageIO;

import util.simpleIO.Out;

import dataBase.search.DataList;

/**
 * LRU Buffer/Cache for images.
 * Watch out for memory consumption with large images!!!
 * 
 * @author Kristofer Schweiger
 */
public class PictureBuffer {
	
	public static int bufferSize = 20;
	private LinkedList<PictureBufferElement> buffer = new LinkedList<PictureBufferElement>();
	
	public PictureBuffer(){
		//buffer = new DataList<PictureBufferElement>(bufferSize, comp);
		//buffer.tolerance = bufferTolerance;
	}
	
	public BufferedImage getPicture(File f) throws IOException{
		
		BufferedImage image;
		
		// --- try A: find image ---
		//
		image = getPicturefromBuffer(f);
		if(image!=null)
			return image;		// found in buffer!
		
		// --- or B: load image ---
		//
		image     = ImageIO.read(f);					// do not sync for IO-Operation!!!
		PictureBufferElement el = new PictureBufferElement(image, f);
		
		synchronized(this){
			
			buffer.addFirst(el);
			//Out.pl(">> Loaded pic '"+el.file.getName()+"'");
			
			while(buffer.size() > bufferSize)
				buffer.removeLast();
			
			return image;
		}
		
		
	}
	
	/**
	 * Get picture from Buffer only
	 * @param f
	 * @return
	 * @throws IOException
	 */
	public BufferedImage getPicturefromBuffer(File f) throws IOException {
		
		synchronized(this){
			Iterator<PictureBufferElement> it = buffer.iterator();
			while(it.hasNext()){
				
				PictureBufferElement el = it.next();
				//Out.pl(">> Iterate...");
				
				if(el.file.equals(f)){
					
					//Out.pl(">> Found pic '"+el.file.getName()+"'");
					it.remove();
					buffer.addFirst(el);
					return el.image;
				}
			}
		}
		
		return null;
	}
	
}
