/* * (c) Copyright 2008, 2009 Hewlett-Packard Development Company, LP * All rights reserved. * [See end of file] */ package org.openjena.atlas.lib.cache; import java.util.Iterator ; import org.openjena.atlas.iterator.SingletonIterator ; import org.openjena.atlas.lib.ActionKeyValue ; import org.openjena.atlas.lib.Cache ; import org.openjena.atlas.lib.Lib ; /** A one-slot cache.*/ public class Cache1 implements Cache { private ActionKeyValue dropHandler = null ; private K cacheKey ; private V cacheValue ; public Cache1() { clear() ; } //@Override public boolean containsKey(K key) { if ( cacheKey == null ) return false ; return cacheKey.equals(key) ; } //@Override public V get(K key) { if ( cacheKey == null ) return null ; if ( cacheKey.equals(key) ) return cacheValue ; return null ; } //@Override public void clear() { if ( cacheKey == null ) return ; K k = cacheKey ; V v = cacheValue ; cacheKey = null ; cacheValue = null ; notifyDrop(k, v) ; } //@Override public boolean isEmpty() { return cacheKey == null ; } //@Override public Iterator keys() { return new SingletonIterator(cacheKey) ; } //@Override public V put(K key, V thing) { if ( Lib.equal(cacheKey, key) && Lib.equal(cacheValue, thing) ) // No change. return cacheValue ; // Change K k = cacheKey ; V v = cacheValue ; // Displaces any existing cached key/value pair cacheKey = key ; cacheValue = thing ; notifyDrop(k, v) ; return v ; } //@Override public boolean remove(K key) { if ( cacheKey == null ) return false ; if ( cacheKey.equals(key) ) { clear() ; // Will notify return true ; } return false ; } //@Override public void setDropHandler(ActionKeyValue dropHandler) { this.dropHandler = dropHandler ; } private void notifyDrop(K key, V thing) { if ( dropHandler != null && key != null ) dropHandler.apply(key, thing) ; } //@Override public long size() { return (cacheKey == null) ? 0 : 1 ; } } /* * (c) Copyright 2008, 2009 Hewlett-Packard Development Company, LP * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */