From b086f57f56bf0eb9dab9cf321a0f69aaaae84347 Mon Sep 17 00:00:00 2001 From: Andrew Branson Date: Wed, 30 May 2012 08:37:45 +0200 Subject: Initial Maven Conversion --- source/com/c2kernel/utils/TransientCache.java | 130 -------------------------- 1 file changed, 130 deletions(-) delete mode 100644 source/com/c2kernel/utils/TransientCache.java (limited to 'source/com/c2kernel/utils/TransientCache.java') diff --git a/source/com/c2kernel/utils/TransientCache.java b/source/com/c2kernel/utils/TransientCache.java deleted file mode 100644 index d58617e..0000000 --- a/source/com/c2kernel/utils/TransientCache.java +++ /dev/null @@ -1,130 +0,0 @@ - -package com.c2kernel.utils; -import java.lang.ref.Reference; -import java.util.AbstractMap; -import java.util.AbstractSet; -import java.util.Hashtable; -import java.util.Iterator; -import java.util.Map; -import java.util.Set; -/************************************************************************** - * TransientCache - Uses transient references to allow unused entries to be - * reaped by the java garbage collector. - * - * $Revision: 1.1 $ - * $Date: 2004/04/20 09:37:02 $ - * - * Copyright (C) 2003 CERN - European Organization for Nuclear Research - * All rights reserved. - **************************************************************************/ -public abstract class TransientCache extends AbstractMap { - - private Map> map = new Hashtable>(); - - @Override - public synchronized Set> entrySet() { - Map newMap = new Hashtable(); - Iterator>> iter = map.entrySet().iterator(); - while (iter.hasNext()) { - Entry> me = iter.next(); - Reference ref = me.getValue(); - V o = ref.get(); - if (o == null) { - // Delete cleared reference - iter.remove(); - } else { - // Copy out interior object - newMap.put(me.getKey(), o); - } - } - // Return set of interior objects - return newMap.entrySet(); - } - - @Override - public synchronized V put(K key, V value) { - Reference ref = makeReference(value); - ref = map.put(key, ref); - if (ref != null) - return (ref.get()); - return null; - } - - public abstract Reference makeReference(Object value); - - @Override - public V remove(Object key) { - Iterator>> i = map.entrySet().iterator(); - Entry> correctEntry = null; - if (key == null) { - while (correctEntry == null && i.hasNext()) { - Entry> e = i.next(); - if (e.getKey() == null) - correctEntry = e; - } - } else { - while (correctEntry == null && i.hasNext()) { - Entry> e = i.next(); - if (key.equals(e.getKey())) - correctEntry = e; - } - } - V oldValue = null; - if (correctEntry != null) { - Reference correctReference = correctEntry.getValue(); - oldValue = correctReference.get(); - i.remove(); - } - return oldValue; - } - /** - * - */ - @Override - public void clear() { - map.entrySet().clear(); - } - - private transient Set keySet = null; - - @Override - public Set keySet() { - if (keySet == null) { - keySet = new AbstractSet() { - @Override - public Iterator iterator() { - return new Iterator() { - private Iterator>> i = map.entrySet().iterator(); - - @Override - public boolean hasNext() { - return i.hasNext(); - } - - @Override - public K next() { - return i.next().getKey(); - } - - @Override - public void remove() { - i.remove(); - } - }; - } - - @Override - public int size() { - return TransientCache.this.size(); - } - - @Override - public boolean contains(Object k) { - return TransientCache.this.containsKey(k); - } - }; - } - return keySet; - } - -} -- cgit v1.2.3