/* * This file is licensed under the MIT License (MIT). * * Copyright (c) 2014 Daniel Ennis * * 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 DEALINGS IN * THE SOFTWARE. */ package co.aikar.util; import java.util.AbstractMap; import java.util.Collection; import java.util.Map; import java.util.Set; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; /** * Implements a Most Recently Used cache in front of a backing map, to quickly access the last accessed result. * * @param Key Type of the Map * @param Value Type of the Map */ @Deprecated(forRemoval = true) public class MRUMapCache extends AbstractMap { final Map backingMap; Object cacheKey; V cacheValue; public MRUMapCache(@NotNull final Map backingMap) { this.backingMap = backingMap; } public int size() {return backingMap.size();} public boolean isEmpty() {return backingMap.isEmpty();} public boolean containsKey(@Nullable Object key) { return key != null && key.equals(cacheKey) || backingMap.containsKey(key); } public boolean containsValue(@Nullable Object value) { return value != null && value == cacheValue || backingMap.containsValue(value); } @Nullable public V get(@Nullable Object key) { if (cacheKey != null && cacheKey.equals(key)) { return cacheValue; } cacheKey = key; return cacheValue = backingMap.get(key); } @Nullable public V put(@Nullable K key, @Nullable V value) { cacheKey = key; return cacheValue = backingMap.put(key, value); } @Nullable public V remove(@Nullable Object key) { if (key != null && key.equals(cacheKey)) { cacheKey = null; } return backingMap.remove(key); } public void putAll(@NotNull Map m) {backingMap.putAll(m);} public void clear() { cacheKey = null; cacheValue = null; backingMap.clear(); } @NotNull public Set keySet() {return backingMap.keySet();} @NotNull public Collection values() {return backingMap.values();} @NotNull public Set> entrySet() {return backingMap.entrySet();} /** * Wraps the specified map with a most recently used cache * * @param map Map to be wrapped * @param Key Type of the Map * @param Value Type of the Map * @return Map */ @NotNull public static Map of(@NotNull Map map) { return new MRUMapCache(map); } }