Provided by: libcode-tidyall-perl_0.83~ds-1_all bug

NAME

       Code::TidyAll::CacheModel - Caching model for Code::TidyAll

VERSION

       version 0.83

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 a hash key of the file contents
       keyed by a hash key of the file's path.

METHODS

       This class has the following methods:

   Code::TidyAll::CacheModel->new(%params)
       The constructor accepts the following attributes:

       •   full_path

           The full path to the cache file on disk. This is required.

       •   path

           The local path to the file (i.e. what the cache system will consider the canonical
           name of the file).

       •   cache_engine

           A "Code::TidyAll::Cache" compatible instance. This can be omitted if no caching is
           actually being done.

       •   base_sig

           A base signature. This defaults to an empty string.

       •   file_contents

           The contents of the file being cached. This can be omitted, in which case it will be
           loaded as needed.

       •   is_cached

           A boolean indicating if this file is cached. By default this is computed by checking
           that the cache key and cache value match what is in the cache.

   $model->full_path
       The value passed to the constructor.

   $model->path
       The value passed to the constructor.

   $model->cache_engine
       The value passed to the constructor.

   $model->base_sig
       The value passed to the constructor or the default value, an empty string.

   $model->file_contents
       The file contents, which will be loaded from the file system if needed.

   $model->is_cached
       A boolean indicating whether the path is currently in the cache.

   $model->cache_key
       The computed cache key for the file.

   $model->cache_value
       The computed cache value for the file.

   $model->update
       Updates the cache.

   $model->remove
       Attempts to remove the value from the cache.

SUPPORT

       Bugs may be submitted at <https://github.com/houseabsolute/perl-code-tidyall/issues>.

SOURCE

       The source code repository for Code-TidyAll can be found at
       <https://github.com/houseabsolute/perl-code-tidyall>.

AUTHORS

       •   Jonathan Swartz <swartz@pobox.com>

       •   Dave Rolsky <autarch@urth.org>

COPYRIGHT AND LICENSE

       This software is copyright (c) 2011 - 2022 by Jonathan Swartz.

       This is free software; you can redistribute it and/or modify it under the same terms as
       the Perl 5 programming language system itself.

       The full text of the license can be found in the LICENSE file included with this
       distribution.