Class Smarty_CacheResource_KeyValueStore
Smarty Cache Handler Base for Key/Value Storage Implementations This class implements the functionality required to use simple key/value stores for hierarchical cache groups. key/value stores like memcache or APC do not support wildcards in keys, therefore a cache group cannot be cleared like "a|*" - which is no problem to filesystem and RDBMS implementations. This implementation is based on the concept of invalidation. While one specific cache can be identified and cleared, any range of caches cannot be identified. For this reason each level of the cache group hierarchy can have its own value in the store. These values are nothing but microtimes, telling us when a particular cache group was cleared for the last time. These keys are evaluated for every cache read to determine if the cache has been invalidated since it was created and should hence be treated as inexistent. Although deep hierarchies are possible, they are not recommended. Try to keep your cache groups as shallow as possible. Anything up 3-5 parents should be ok. So »a|b|c« is a good depth where »a|b|c|d|e|f|g|h|i|j|k« isn't. Try to join correlating cache groups: if your cache groups look somewhat like »a|b|$page|$items|$whatever« consider using »a|b|c|$page-$items-$whatever« instead.
- Smarty_CacheResource
- Smarty_CacheResource_KeyValueStore
Package: Smarty\Cacher
Author: Rodney Rehm
Located at plugins/smarty/smarty_source/sysplugins/smarty_cacheresource_keyvaluestore.php
public
|
#
populate(
populate Cached Object with meta data from Resource |
public
|
#
populateTimestamp(
populate Cached Object with timestamp and exists from Resource |
public
boolean
|
#
process(
Read the cached template and process the header |
public
boolean
|
#
writeCachedContent(
Write the rendered template output to cache |
public
integer
|
|
public
integer
|
|
protected
string
|
#
getTemplateUid(
Get template's unique ID |
protected
string
|
|
protected
boolean
|
|
protected
|
|
protected
float
|
|
protected
|
#
invalidate( string $cid = null, string $resource_name = null, string $cache_id = null, string $compile_id = null, string $resource_uid = null )
Invalidate CacheID |
protected
float
|
#
getLatestInvalidationTimestamp( string $cid, string $resource_name = null, string $cache_id = null, string $compile_id = null, string $resource_uid = null )
Determine the latest timestamp known to the invalidation chain |
protected
array
|
#
listInvalidationKeys( string $cid, string $resource_name = null, string $cache_id = null, string $compile_id = null, string $resource_uid = null )
Translate a CacheID into the list of applicable InvalidationKeys. Splits "some|chain|into|an|array" into array( '#clearAll#', 'some', 'some|chain', 'some|chain|into', ... ) |
public
boolean
|
#
hasLock(
Check is cache is locked for this template |
public
boolean|
|
|
public
boolean|
|
|
abstract protected
array
|
|
abstract protected
boolean
|
|
abstract protected
boolean
|
|
protected
boolean
|
getCachedContent(),
invalidLoadedCache(),
load(),
locked()
|
protected
array
|
$contents
cache for contents |
#
array()
|
protected
array
|
$timestamps
cache for timestamps |
#
array()
|
$resources,
$sysplugins
|