Pod::From::Cache
Pod::From::Cache
Description
This is a replacement for Pod::To::Cached, which will be mothballed.
It provides only two methods and has far fewer dependencies. It relies only
on the CompUnit Modules.Caution Caution
Pod::From::Cache relies on the Precomp Modules which are designed to provide precompiled
code as quickly as possible. Once a cache has been loaded it is
difficult to make changes to the cache in the same program. Consequently it is
not possible to change a source on file and for the change to be detected in the same program.
Synopsis
use v6.d;
use Pod::From::Cache;
my $cache = Pod::From::Cache.new;
# used the default values of
# - :extensions = <rakudoc pod pod6 p6 pm pm6>
# - :doc-source = 'docs',
# - :cache-path = 'rakudoc_cache'
say "Files changed since the cache was last refreshed";
say '(None)' unless +$cache.list-files;
.say for $cache.list-files;
# Get and use pod in a source
dd $cache.pod( $cache.sources[0] );
rm-cache( 'rakudoc_cache' );
# removes the cache directory using OS dependent methods.
Initialisation
When an instance of Pod::From::Cache is created, it recursively descends the directory
starting at :doc-source and extracts all files that match the extensions in the list
given by :extensions.
If a Precomp repository exists under the directory given by :cache-path, then any source
that is newer than the source in the cache is renewed, and a list of refreshed-pods is collected.
If a repository does not exist, then all files will be added to it.
The list of refreshed files can be obtained as either
$cache.list-filesor$cache.refreshed-pods
All of the files found by the recursive descent can be found in
$cache.sources.
Once $cache is instantiated, then the pod for a source file can be obtained as
$cache.pod( 'Language/Raku-101.pod' );Progress
my Pod::From::Cache $p .= new( :progress( &count ) );
# somewhere else
sub count(:$start, :$end) { # show a start, then decrease, or inverse thereof } Optionally a closure with signature (:start, :end) can be provided that will show progress in some way.
This is provided because large Pod6 files take considerable time to process.
:startis the number of files to be processed.:decis when a file has been processed.
Ignore Files
It is possible to place a file .ignore-cache in the directory specified by :doc-source (by default docs).
An ignore list can be provided via :ignore when the object is instantiated.
Each line should be the name of a file (and the path relative to the :doc-source directory) that is to be ignored.
Any file exactly matching a file in .ignore-cache will not be included in the sources added
to the cache.
If the .pod method is called with a file matching a name in .ignore-cache, it will return Nil, rather
than a pod tree.
Exceptions
The following exceptions are thrown.
X::Pod::From::Cache::NoPodInCache
An attempt has been made to extract pod from a file not in Sources
X::Pod::From::Cache::NoSources
No sources matching extentions were found under doc-sources directory
X::Pod::From::Cache::BadSource
An error was caught when compiling a file. Probably a compile error. The error is given in the Exception message.