NAME
MooseX::ConfigCascade::Util - utility module for MooseX::ConfigCascade
SYNOPSIS
use MooseX::ConfigCascade::Util;
MooseX::ConfigCascade::Util->path( # set the path to the config file
'/path/to/config.json'
);
MooseX::ConfigCascade::Util->conf( # set the config hash directly
\%conf
);
MooseX::ConfigCascade::Util->parser( # set the sub that parses the
# config file
$subroutine_reference
);
DESCRIPTION
This is module is the workhorse of MooseX::ConfigCascade. See the MooseX::ConfigCascade documentation for a general overview of how to implement MooseX::ConfigCascade in your project.
METHODS
MooseX provides an attribute 'conf' which stores a hash of config directives, and 2 attributes path and parser which control how conf is loaded
conf
This is a hashref containing config information. See the documentation for MooseX::ConfigCascade to learn how this should be structured. It can be set directly
MooseX::ConfigCascade::Util->conf( \%conf );
Alternatively it is set indirectly when 'path' is changed
path
Call this to set the path to your config file. For more information about the format of your config file, see the documentation for MooseX::ConfigCascade.
MooseX::ConfigCascade::Util->path( '/path/to/my_config.json' );
When path is changed it reads the specified file and overwrites conf with the new values. Any new objects created after that will get the new values.
parser
This is the subroutine responsible for converting the file specified in path to a hashref. Setting this to a new value means you can use MooseX::ConfigCascade with a config file of arbitrary format. But look at the expected format of this sub below, and use with caution:
Your parser subroutine should collect path from the input arguments, do whatever is necessary to convert the file, and finally output the hashref which will be stored in conf':
my $parser = sub {
my $path = shift;
open my $fh, '<', $path or die "Could not open $path: $!";
my %conf;
# .... read the values into %conf
return \%conf;
}
SEE ALSO
MooseX::ConfigCascade::Util Moose MooseX::ClassAttribute
AUTHOR
Tom Gracey <tomgracey@gmail.com>
COPYRIGHT AND LICENSE
Copyright (C) 2017 by Tom Gracey
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.