2013-11-22 18:26:22 +00:00
|
|
|
/*
|
2014-01-11 00:30:39 +00:00
|
|
|
******************************************************************************
|
|
|
|
* Copyright (C) 2014, International Business Machines Corporation and
|
2013-11-22 18:26:22 +00:00
|
|
|
* others. All Rights Reserved.
|
2014-01-11 00:30:39 +00:00
|
|
|
******************************************************************************
|
2013-11-22 18:26:22 +00:00
|
|
|
*
|
|
|
|
* File LRUCACHE.H
|
2014-01-11 00:30:39 +00:00
|
|
|
******************************************************************************
|
2013-11-22 18:26:22 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __LRU_CACHE_H__
|
|
|
|
#define __LRU_CACHE_H__
|
|
|
|
|
|
|
|
#include "unicode/uobject.h"
|
2014-01-11 00:30:39 +00:00
|
|
|
#include "sharedobject.h"
|
2013-11-22 18:26:22 +00:00
|
|
|
|
|
|
|
struct UHashtable;
|
|
|
|
|
|
|
|
U_NAMESPACE_BEGIN
|
|
|
|
|
|
|
|
/**
|
|
|
|
* LRUCache keyed by locale ID.
|
|
|
|
*/
|
|
|
|
|
2013-11-22 20:42:19 +00:00
|
|
|
class U_COMMON_API LRUCache : public UObject {
|
2014-01-11 00:30:39 +00:00
|
|
|
public:
|
2013-11-22 18:26:22 +00:00
|
|
|
template<typename T>
|
2014-01-11 00:30:39 +00:00
|
|
|
void get(const char *localeId, const T *&ptr, UErrorCode &status) {
|
|
|
|
const T *value = (const T *) _get(localeId, status);
|
2013-11-22 18:26:22 +00:00
|
|
|
if (U_FAILURE(status)) {
|
|
|
|
return;
|
|
|
|
}
|
2014-01-11 00:30:39 +00:00
|
|
|
SharedObject::copyPtr(value, ptr);
|
2013-11-22 18:26:22 +00:00
|
|
|
}
|
|
|
|
UBool contains(const char *localeId) const;
|
|
|
|
virtual ~LRUCache();
|
2014-01-11 00:30:39 +00:00
|
|
|
protected:
|
|
|
|
virtual SharedObject *create(const char *localeId, UErrorCode &status)=0;
|
2013-11-22 23:08:24 +00:00
|
|
|
LRUCache(int32_t maxSize, UErrorCode &status);
|
2014-01-11 00:30:39 +00:00
|
|
|
private:
|
|
|
|
class CacheEntry : public UMemory {
|
|
|
|
public:
|
|
|
|
CacheEntry *moreRecent;
|
|
|
|
CacheEntry *lessRecent;
|
|
|
|
char *localeId;
|
|
|
|
const SharedObject *cachedData;
|
|
|
|
UErrorCode status; // This is the error if any from creating
|
|
|
|
// cachedData.
|
|
|
|
CacheEntry();
|
|
|
|
~CacheEntry();
|
|
|
|
|
|
|
|
void unlink();
|
|
|
|
void reset();
|
|
|
|
void init(
|
|
|
|
char *adoptedLocId, SharedObject *dataToAdopt, UErrorCode err);
|
|
|
|
private:
|
|
|
|
CacheEntry(const CacheEntry& other);
|
|
|
|
CacheEntry &operator=(const CacheEntry& other);
|
|
|
|
};
|
2013-11-22 18:26:22 +00:00
|
|
|
LRUCache();
|
|
|
|
LRUCache(const LRUCache &other);
|
|
|
|
LRUCache &operator=(const LRUCache &other);
|
2014-01-11 00:30:39 +00:00
|
|
|
|
|
|
|
// TODO (Travis Keep): Consider replacing both of these end nodes with a
|
|
|
|
// single sentinel.
|
|
|
|
CacheEntry *mostRecentlyUsedMarker;
|
|
|
|
CacheEntry *leastRecentlyUsedMarker;
|
2013-11-22 18:26:22 +00:00
|
|
|
UHashtable *localeIdToEntries;
|
|
|
|
int32_t maxSize;
|
|
|
|
|
2014-01-11 00:30:39 +00:00
|
|
|
void moveToMostRecent(CacheEntry *cacheEntry);
|
|
|
|
void init(char *localeId, CacheEntry *cacheEntry);
|
|
|
|
const SharedObject *_get(const char *localeId, UErrorCode &status);
|
2013-11-22 18:26:22 +00:00
|
|
|
};
|
|
|
|
|
2014-01-11 00:30:39 +00:00
|
|
|
typedef SharedObject *CreateFunc(const char *localeId, UErrorCode &status);
|
2013-11-22 18:26:22 +00:00
|
|
|
|
2013-11-22 20:42:19 +00:00
|
|
|
class U_COMMON_API SimpleLRUCache : public LRUCache {
|
2013-11-22 18:26:22 +00:00
|
|
|
public:
|
|
|
|
SimpleLRUCache(
|
|
|
|
int32_t maxSize,
|
|
|
|
CreateFunc cf,
|
|
|
|
UErrorCode &status) :
|
2013-11-22 23:08:24 +00:00
|
|
|
LRUCache(maxSize, status), createFunc(cf) {
|
2013-11-22 18:26:22 +00:00
|
|
|
}
|
2013-11-22 19:13:02 +00:00
|
|
|
virtual ~SimpleLRUCache();
|
2013-11-22 18:26:22 +00:00
|
|
|
protected:
|
2014-01-11 00:30:39 +00:00
|
|
|
virtual SharedObject *create(const char *localeId, UErrorCode &status);
|
2013-11-22 18:26:22 +00:00
|
|
|
private:
|
2014-01-11 00:30:39 +00:00
|
|
|
CreateFunc *createFunc;
|
2013-11-22 18:26:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
U_NAMESPACE_END
|
|
|
|
|
|
|
|
#endif
|