Take me over?
NAME
Code::TidyAll::CacheModel - caching model for Cody::TidyAll
SYNOPSIS
my $cache_model = Cody::TidyAll::CacheModel->new(
cache_engine => Code::TidyAll::Cache->new(...),
path => "/path/to/file/to/cache",
);
# check cache
print "Yes!" if $cache_model->is_cached;
# update cache
$cache_model->clear_file_contents;
$cache_model->update;
# update the cache when you know the file contents
$cache_model->file_contents( $new_content );
$cache_model->update;
# force removal from cache
$cache_model->remove;
DESCRIPTION
A cache model for Code::TidyAll. Different subclasses can employ different caching techniques.
The basic model implemented here is simple; It stores in the cache a hash key of the file contents keyed by a hash key of the file's path.
Attributes
- full_path (required, ro)
-
The full path to the file on disk
- path (required, ro)
-
The local path to the file (i.e. what the cache system will consider the canonical name of the file)
- cache_engine (optional, default undef, ro)
-
A
Code::TidyAll::Cache
compatible instance, or, if no caching is required undef. - base_sig (optional, default empty string, ro)
-
A base signature.
- file_contents (optional, default loads file contents from disk, rw)
- is_cached (optional, default computed, rw)
-
A flag indicating if this is cached. By default checks that the cache key and cache value match the cache.
Methods
- cache_key
-
The computed cache key for the file
- cache_value
-
The computed cache value for the file
- update
-
Updates the cache
- remove
-
Attempts to remove the value from the cache