| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 | /*=============================================================================  Library: CTK  Copyright (c) German Cancer Research Center,    Division of Medical and Biological Informatics  Licensed under the Apache License, Version 2.0 (the "License");  you may not use this file except in compliance with the License.  You may obtain a copy of the License at    http://www.apache.org/licenses/LICENSE-2.0  Unless required by applicable law or agreed to in writing, software  distributed under the License is distributed on an "AS IS" BASIS,  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the License for the specific language governing permissions and  limitations under the License.=============================================================================*/#ifndef CTKEACACHEMAP_P_H#define CTKEACACHEMAP_P_H/** * This is the interface of a simple cache map.*/template<class K, class V, class Impl>struct ctkEACacheMap{  virtual ~ctkEACacheMap() {}  /**   * Return the value for the key in case there is one in the cache.   *   * @param key The key to look-up   *   * @return The value for the given key in case there is one in the cache,   *         <tt>null</tt> otherwise   */  const V value(const K& key) const  {    return static_cast<const Impl*>(this)->value(key);  }  const V value(const K& key, const V& defaultValue) const  {    return static_cast<const Impl*>(this)->value(key, defaultValue);    }  /**   * Add a value for the key to this cache.   *   * @param key The key for the value   * @param value The value to add to the cache   */  void insert(const K& key, const V& value)  {    static_cast<Impl*>(this)->insert(key, value);  }  /**   * Remove a key and its value from the cache.   *   * @param key The key to remove   *   * @return The value of the key in case there is one in the cache, <tt>null</tt>   *         otherwise   */  const V remove(const K& key)  {    return static_cast<Impl*>(this)->remove(key);  }  /**   * Returns the number of key-value pairs in this cache.   *   * @return The number of key-value pairs in this cache   */  int size() const  {    return static_cast<const Impl*>(this)->size();  }  /**   * Remove all entries of the cache.   */  void clear()  {    static_cast<Impl*>(this)->clear();  }};#endif // CTKEACACHEMAP_P_H
 |