// $Id: cache.hh,v 4.10 2006/10/01 11:23:32 shane Exp $ // Copyright (c) 2001,2002 RIPE NCC // // All Rights Reserved // // Permission to use, copy, modify, and distribute this software and its // documentation for any purpose and without fee is hereby granted, // provided that the above copyright notice appear in all copies and that // both that copyright notice and this permission notice appear in // supporting documentation, and that the name of the author not be // used in advertising or publicity pertaining to distribution of the // software without specific, written prior permission. // // THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING // ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS; IN NO EVENT SHALL // AUTHOR BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY // DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN // AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF // OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. // // // Copyright (c) 1994 by the University of Southern California // All rights reserved. // // Permission to use, copy, modify, and distribute this software and its // documentation in source and binary forms for lawful non-commercial // purposes and without fee is hereby granted, provided that the above // copyright notice appear in all copies and that both the copyright // notice and this permission notice appear in supporting documentation, // and that any documentation, advertising materials, and other materials // related to such distribution and use acknowledge that the software was // developed by the University of Southern California, Information // Sciences Institute. The name of the USC may not be used to endorse or // promote products derived from this software without specific prior // written permission. // // THE UNIVERSITY OF SOUTHERN CALIFORNIA DOES NOT MAKE ANY // REPRESENTATIONS ABOUT THE SUITABILITY OF THIS SOFTWARE FOR ANY // PURPOSE. THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR // IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, // TITLE, AND NON-INFRINGEMENT. // // IN NO EVENT SHALL USC, OR ANY OTHER CONTRIBUTOR BE LIABLE FOR ANY // SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES, WHETHER IN CONTRACT, TORT, // OR OTHER FORM OF ACTION, ARISING OUT OF OR IN CONNECTION WITH, THE USE // OR PERFORMANCE OF THIS SOFTWARE. // // Questions concerning this software should be directed to // ratoolset@isi.edu. // // Author(s): WeeSan Lee #ifndef CACHE_H #define CACHE_H #include "gnug++/CacheKey.CacheValue.AVLMap.h" template class Cache : public CacheKeyCacheValueAVLMap { protected: // Modified from void CacheKeyCacheValueAVLMap::_kill #define LTHREADBIT 4 #define RTHREADBIT 8 void _kill(CacheKeyCacheValueAVLNode* t) { if (t != 0) { if (!(t->stat & LTHREADBIT)) _kill(t->lt); if (!(t->stat & RTHREADBIT)) _kill(t->rt); if (t->cont.data()) delete (V)t->cont.data(); delete t; } } public: Cache(void) : CacheKeyCacheValueAVLMap(cDefaultValue) {} // Add stuff into cache bool add(K aKey, V aValue) { (*this)[(CacheKey)(intptr_t)aKey] = CacheValue(aValue); return true; } ~Cache(void) { clear(); } // Retrieve stuff from cache bool query(K aKey, V &arValue) { CacheValue *pcValue = &(*this)[(CacheKey)(intptr_t)aKey]; // if not found, it always return default value: cDefaultValue // we never increase count of default value, so, it's safe to determine // cache miss by just checking the reference count to see if it's 0 if (pcValue->refCount()) { pcValue->incRefCount(); arValue = (V)pcValue->data(); return true; } else return false; } void nullify(K aKey) { CacheValue *pcValue = &(*this)[(CacheKey)(intptr_t)aKey]; pcValue->pvData = NULL; } // Override the function on the base class void clear(void) { _kill(root); count = 0; root = 0; } }; #endif // CACHE_H