1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
package Config::MVP::Reader::Hash;
BEGIN {
$Config::MVP::Reader::Hash::VERSION = '2.101650';
}
use Moose;
extends 'Config::MVP::Reader';
# ABSTRACT: a reader that tries to cope with a plain old hashref
sub read_into_assembler {
my ($self, $location, $assembler) = @_;
confess "no hash given to $self" unless my $hash = $location;
for my $name (keys %$hash) {
my $payload = { %{ $hash->{ $name } } };
my $package = delete($payload->{__package}) || $name;
$assembler->begin_section($package, $name);
for my $key (%$payload) {
my $val = $payload->{ $key };
my @values = ref $val ? @$val : $val;
$assembler->add_value($key => $_) for @values;
}
$assembler->end_section;
}
return $assembler->sequence;
}
no Moose;
__PACKAGE__->meta->make_immutable;
1;
__END__
=pod
=head1 NAME
Config::MVP::Reader::Hash - a reader that tries to cope with a plain old hashref
=head1 VERSION
version 2.101650
=head1 SYNOPSIS
my $sequence = Config::MVP::Reader::Hash->new->read_config( \%config );
=head1 DESCRIPTION
In some ways, this is the L<Config::MVP::Reader> of last resort. Given a
hashref, it attempts to interpret it as a Config::MVP::Sequence. Because
hashes are generally unordered, order can't be relied upon unless the hash tied
to have order (presumably with L<Tie::IxHash>). The hash keys are assumed to
be section names and will be used as the section package moniker unless a
L<__package> entry is found.
=head1 AUTHOR
Ricardo Signes <rjbs@cpan.org>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2010 by Ricardo Signes.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut
|