forked from jonathangreen/tuque
-
Notifications
You must be signed in to change notification settings - Fork 38
/
Cache.php
162 lines (148 loc) · 3.79 KB
/
Cache.php
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
<?php
/**
* @file
* Simple set of classes defining caches. An abstract cache is defined so that
* we can use a more interesting caching setup in the future like memcached or
* the native drupal cache.
*/
/**
* Simple abstract Cache defintion providing basic key value caching
* functionality.
*/
abstract class AbstractCache {
/**
* Add data to the cache.
*
* @param string $key
* The key to add to the cache.
* @param mixed $data
* The data to store with the key.
*
* @return boolean
* TRUE if the data was added to the cache. FALSE if $key already exists in
* the cache or if there was an error.
*/
abstract public function add($key, $data);
/**
* Retrieve data from the cache.
*
* @param string $key
* They key to retrieve from the cache.
*
* @return mixed
* FALSE if the data wasn't found in the cache. Otherwise it returns the
* data assoctiated with the key.
*/
abstract public function get($key);
/**
* Set data in the cache.
*
* This will create new keys if they don't already exist, or update existing
* keys.
*
* @param string $key
* The key to add/update.
* @param mixed $data
* The data to store with the key.
*
* @return boolean
* TRUE on success. FALSE on failure.
*/
abstract public function set($key, $data);
/**
* Delete key from the cache.
*
* @param string $key
* The key to delete.
*
* @return boolean
* TRUE if they key existed and was deleted. FALSE otherwise.
*/
abstract public function delete($key);
}
/**
* This is a simple cache that uses a static array to hold the cached values.
* This means that it will cache across instantiations in the same PHP runtime
* but not across runtimes. The cache has 100 slots and uses a simple LIFO
* caching strategy.
*
* @todo Replace this with something more interesting like memcached
* @todo Try some other intersting caching strategies like LRU.
*/
class SimpleCache extends AbstractCache {
const CACHESIZE = 100;
protected static $cache = array();
protected static $entries = array();
protected static $size = SimpleCache::CACHESIZE;
/**
* Set the cache size for the cache. If the size if bigger the cache size
* is just made bigger. If its smaller, the cache is flushed and the cache
* size is made smaller.
*
* @param int $size
* The new size of the cache.
*/
static function setCacheSize($size) {
if ($size > self::$size) {
self::$size = $size;
}
else {
self::$cache = array();
self::$entries = array();
self::$size = $size;
}
}
/**
* Reset the cache flushing it and returning it to its default size.
*/
static function resetCache() {
self::$cache = array();
self::$entries = array();
self::$size = self::CACHESIZE;
}
/**
* @see AbstractCache::get
*/
function get($key) {
if (array_key_exists($key, self::$cache)) {
return self::$cache[$key];
}
return FALSE;
}
/**
* @see AbstractCache::add
*/
function add($key, $data) {
if ($this->get($key) !== FALSE) {
return FALSE;
}
self::$cache[$key] = $data;
$num = array_push(self::$entries, $key);
if ($num > self::$size) {
$evictedkey = array_shift(self::$entries);
unset(self::$cache[$evictedkey]);
}
return TRUE;
}
/**
* @see AbstractCache::set
*/
function set($key, $data) {
if ($this->add($key, $data) === FALSE) {
self::$cache[$key] = $data;
}
return TRUE;
}
/**
* @see AbstractCache::delete
*/
function delete($key) {
if (!array_key_exists($key, self::$cache)) {
return FALSE;
}
$entrykey = array_search($key, self::$entries);
unset(self::$cache[$key]);
unset(self::$entries[$entrykey]);
return TRUE;
}
}