summaryrefslogtreecommitdiff
path: root/cache.c
blob: 6c3f99a2804336324b80cefd9ef3c6ddb526834b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/*
 * $Id: cache.c,v 1.2 2004/06/18 16:08:11 lordjaxom Exp $
 */

#include "cache.h"
#include "bitmap.h"

cText2SkinCache::cText2SkinCache(int MaxItems) {
	mMaxItems = MaxItems;
}

cText2SkinCache::~cText2SkinCache() {
	Flush();
}

void cText2SkinCache::Delete(const key_type &Key, data_type &Data) {
	delete Data;
}

void cText2SkinCache::Flush(void) {
	mUsage.clear();
	item_iterator it = mItems.begin();
	for (; it != mItems.end(); ++it)
		Delete((*it).first, (*it).second);
	mItems.clear();
}

void cText2SkinCache::Reset(void) {
	item_iterator it = mItems.begin();
	for (; it != mItems.end(); ++it)
		(*it).second->Reset();
}

cText2SkinCache::data_type &cText2SkinCache::operator[](const key_type &Key) {
	item_iterator it = mItems.find(Key);
	if (it != mItems.end()) {
		usage_iterator ut = mUsage.begin();
		for (; ut != mUsage.end(); ++ut) {
			if ((*ut) == Key) {
				mUsage.erase(ut);
				break;
			}
		}
		mUsage.push_back(Key);
	} else {
		if ((int)mItems.size() == mMaxItems) {
			usage_iterator ut = mUsage.begin();
			Delete(*ut, mItems[*ut]);
			mItems.erase(*ut);
			mUsage.erase(mUsage.begin());
		}
		it = mItems.insert(item_map::value_type(Key, data_type())).first;
		mUsage.push_back(Key);
	}
	return (*it).second;
}