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

net.spy.memcached.BaseCacheMap Maven / Gradle / Ivy

There is a newer version: 2.12.3
Show newest version
/**
 * Copyright (C) 2006-2009 Dustin Sallings
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALING
 * IN THE SOFTWARE.
 */

package net.spy.memcached;

import java.util.Collection;
import java.util.Collections;
import java.util.Map;
import java.util.Set;

import net.spy.memcached.transcoders.Transcoder;

/**
 * Base class for a Map interface to memcached.
 *
 * 

* This Map interface makes memcached a bit easier to use for some purposes by * providing a limited Map implementation. *

* *

* Do note that nothing that iterates over the map will work (such is * memcached). All iteration mechanisms will return empty iterators and such. *

* * @param the type of value taken and returned by this Map's underlying * transcoder, and thus taken and returned by this Map. */ public class BaseCacheMap implements Map { private final String keyPrefix; private final Transcoder transcoder; private final MemcachedClientIF client; private final int exp; /** * Build a BaseCacheMap. * * @param c the underlying client * @param expiration the expiration for objects set through this Map * @param prefix a prefix to ensure objects in this map are unique * @param t the transcoder to serialize and deserialize objects */ public BaseCacheMap(MemcachedClientIF c, int expiration, String prefix, Transcoder t) { super(); keyPrefix = prefix; transcoder = t; client = c; exp = expiration; } public void clear() { // TODO: Support a rolling key generation. throw new UnsupportedOperationException(); } private String getKey(String k) { return keyPrefix + k; } public boolean containsKey(Object key) { return get(key) != null; } /** * This method always returns false, as truth cannot be determined without * iteration. */ public boolean containsValue(Object value) { return false; } public Set> entrySet() { return Collections.emptySet(); } public V get(Object key) { V rv = null; try { rv = client.get(getKey((String) key), transcoder); } catch (ClassCastException e) { // Most likely, this is because the key wasn't a String. // Either way, it's a no. } return rv; } public boolean isEmpty() { return false; } public Set keySet() { return Collections.emptySet(); } public void putAll(Map t) { for (Map.Entry me : t.entrySet()) { client.set(getKey(me.getKey()), exp, me.getValue()); } } public V remove(Object key) { V rv = null; try { rv = get(key); client.delete(getKey((String) key)); } catch (ClassCastException e) { // Not a string key. Ignore. } return rv; } public int size() { return 0; } public Collection values() { return Collections.emptySet(); } public V put(String key, V value) { V rv = get(key); client.set(getKey(key), exp, value); return rv; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy