/*
* AndFHEM - Open Source Android application to control a FHEM home automation
* server.
*
* Copyright (c) 2011, Matthias Klass or third-party contributors as
* indicated by the @author tags or express copyright attribution
* statements applied by the authors. All third-party contributions are
* distributed under license by Red Hat Inc.
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU GENERAL PUBLIC LICENSE, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU GENERAL PUBLIC LICENSE
* for more details.
*
* You should have received a copy of the GNU GENERAL PUBLIC LICENSE
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package li.klass.fhem.util;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class Cache<T> {
private final int cacheSize;
private class CacheItem {
private long lastAccess;
private T value;
private CacheItem(T value) {
this.value = value;
this.lastAccess = System.currentTimeMillis();
}
public T access() {
lastAccess = System.currentTimeMillis();
return value;
}
}
private Map<String, CacheItem> cacheItems = new HashMap<String, CacheItem>();
public Cache(int cacheSize) {
this.cacheSize = cacheSize;
}
public boolean containsKey(String item) {
return cacheItems.containsKey(item);
}
public T get(String item) {
return cacheItems.get(item).access();
}
public void put(String key, T value) {
if (containsKey(key)) return;
if (cacheItems.size() >= cacheSize) {
removeOldestEntry();
}
cacheItems.put(key, new CacheItem(value));
}
private void removeOldestEntry() {
String minimumKey = null;
long minimumTime = -1;
Set<String> keys = cacheItems.keySet();
for (String key : keys) {
CacheItem item = cacheItems.get(key);
if (minimumTime == -1 || item.lastAccess < minimumTime) {
minimumKey = key;
minimumTime = item.lastAccess;
}
}
cacheItems.remove(minimumKey);
}
}