/usr/share/perl5/Config/MVP/Reader/Hash.pm is in libconfig-mvp-perl 2.200008-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 74 75 76 77 78 79 80 81 82 83 84 85 86 87 | package Config::MVP::Reader::Hash;
# ABSTRACT: a reader that tries to cope with a plain old hashref
$Config::MVP::Reader::Hash::VERSION = '2.200008';
use Moose;
extends 'Config::MVP::Reader';
#pod =head1 SYNOPSIS
#pod
#pod my $sequence = Config::MVP::Reader::Hash->new->read_config( \%config );
#pod
#pod =head1 DESCRIPTION
#pod
#pod In some ways, this is the L<Config::MVP::Reader> of last resort. Given a
#pod hashref, it attempts to interpret it as a Config::MVP::Sequence. Because
#pod hashes are generally unordered, order can't be relied upon unless the hash tied
#pod to have order (presumably with L<Tie::IxHash>). The hash keys are assumed to
#pod be section names and will be used as the section package moniker unless a
#pod L<__package> entry is found.
#pod
#pod =cut
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
=encoding UTF-8
=head1 NAME
Config::MVP::Reader::Hash - a reader that tries to cope with a plain old hashref
=head1 VERSION
version 2.200008
=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) 2014 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
|