Vim documentation: vital/System/Cache/Memory
main help file
vital/System/Cache/Memory.txt A dictionary instance based cache system
Maintainer: Alisue <lambdalisue@hashnote.net>
==============================================================================
CONTENTS Vital.System.Cache.Memory-contents
Introductions Vital.System.Cache.Memory-intro
Usage Vital.System.Cache.Memory-usage
Functions Vital.System.Cache.Memory-functions
Methods Vital.System.Cache.Memory-methods
==============================================================================
INTRODUCTIONS Vital.System.Cache.Memory-intro
Vital.System.Cache.Memory is a dictionary instance based cache system.
==============================================================================
USAGE Vital.System.Cache.Memory-usage
Vital.System.Cache.Memory have all required API of unified cache system and
values are stored in a Dictionary instance.
In the following example, Vital.System.Cache.Memory is used for memorize the
calculated values.
let s:V = vital#{plugin-name}#new()
let s:C = s:V.import('System.Cache.Memory')
let s:factorial_cache = s:C.new()
function! s:factorial(n)
if a:n == 0
return 1
elseif s:factorial_cache.has(a:n)
return s:factorial_cache.get(a:n)
else
let x = s:factorial(a:n - 1) * a:n
call s:factorial_cache.set(a:n, x)
return x
endif
endfunction
echo s:factorial(10)
==============================================================================
FUNCTIONS Vital.System.Cache.Memory-functions
new([{options}]) Vital.System.Cache.Memory.new()
Create a new instance of System.Cache.Memory.
No {options} will be used.
==============================================================================
METHODS Vital.System.Cache.Memory-methods
cache_key({obj}) Vital.System.Cache.Memory-instance.cache_key()
See Vital.System.Cache.Base-instance.cache_key()
has({name}) Vital.System.Cache.Memory-instance.has()
Return 1 if the cache instance has {name} in its cache dictionary.
Otherwise 0.
{name} (required)
A name of the cache. An actual cache key will be created via
Vital.System.Cache.Memory-instance.cache_key() method thus {name} is
not required to be String.
Vital.System.Cache.Memory-instance.get()
get({name}[, {default}])
Return a cached value of {name} in a cache dictionary. It returns
{default} if no value is found.
{name} (required)
A name of the cache. An actual cache key will be created via
Vital.System.Cache.Memory-instance.cache_key() method thus {name} is
not required to be String.
{default} (optional)
A default value. It will be returned when no value is found in the
cache dictionary.
set({name}, {value}) Vital.System.Cache.Memory-instance.set()
Save {value} into a cache dictionary as {name}.
{name} (required)
A name of the cache. An actual cache key will be created via
Vital.System.Cache.Memory-instance.cache_key() method thus {name} is
not required to be String.
{value} (required)
A value of the cache.
keys() Vital.System.Cache.Memory-instance.keys()
Return a list of cache keys
remove({name}) Vital.System.Cache.Memory-instance.remove()
Remove {name} from a cache dictionary. It does nothing when the
specified {name} is not found in the cache.
{name} (required)
A name of the cache. An actual cache key will be created via
Vital.System.Cache.Memory-instance.cache_key() method thus {name} is
not required to be String.
clear() Vital.System.Cache.Memory-instance.clear()
Clear a cache dictionary.
on_changed() Vital.System.Cache.Memory-instance.on_changed()
A user defined hook method. This method is called when the content of
the cache is changed, namely after the following methods:
- Vital.System.Cache.Memory-instance.set()
- Vital.System.Cache.Memory-instance.remove()
- Vital.System.Cache.Memory-instance.clear()
==============================================================================
vim:tw=78:fo=tcq2mM:ts=8:ft=help:norl
top - main help file - tag index