Banal-Utils
view release on metacpan or search on metacpan
lib/Banal/Utils/Data.pm view on Meta::CPAN
# PUBLIC (exportable) FUNCTIONS
##############################################################################"
#----------------------------------
# Function, not a method!
#----------------------------------
sub banal_get_data {
my $args = {@_};
my $opts = $args->{options} || {};
my $search_upwards_while_not_defined = $opts->{search_upwards_while_not_defined};
# This is where the MAGIC happens. For a full list of options, see the function "normalize_data_root_and_keys()".
my ($root, @keys) = _normalize_data_root_and_keys (@_);
# The data root should have been defined by now.
return unless ($root);
# All this for nothing?
return $root if (scalar(@keys) < 1);
# The reason for the below loop is to allow outer level 'variables' to be used when the variable is not defined at the proper (inner) level.
# Very handy for CONFIGURATION handling scenarios.
my $key = pop @keys;
while (scalar(@keys) >= 0) {
my $value= _banal_basic_get_data_via_key_list(data=>$root, keys=>[@keys, $key]);
return $value if defined($value);
# Continue searching upwards if we are allowed to do so. Return otherwise.
return unless $search_upwards_while_not_defined;
pop @keys;
}
return;
}
#-----------------------------------------------
# FUNCTION (not a method).
t/boilerplate.t view on Meta::CPAN
#!perl -T
use 5.006;
use strict;
use warnings FATAL => 'all';
use Test::More;
plan tests => 3;
sub not_in_file_ok {
my ($filename, %regex) = @_;
open( my $fh, '<', $filename )
or die "couldn't open $filename for reading: $!";
my %violated;
while (my $line = <$fh>) {
while (my ($desc, $regex) = each %regex) {
if ($line =~ $regex) {
push @{$violated{$desc}||=[]}, $.;
t/boilerplate.t view on Meta::CPAN
if (%violated) {
fail("$filename contains boilerplate text");
diag "$_ appears on lines @{$violated{$_}}" for keys %violated;
} else {
pass("$filename contains no boilerplate text");
}
}
sub module_boilerplate_ok {
my ($module) = @_;
not_in_file_ok($module =>
'the great new $MODULENAME' => qr/ - The great new /,
'boilerplate description' => qr/Quick summary of what the module/,
'stub function definition' => qr/function[12]/,
);
}
TODO: {
local $TODO = "Need to replace the boilerplate text";
not_in_file_ok(README =>
"The README is used..." => qr/The README is used/,
"'version information here'" => qr/to provide version information/,
);
not_in_file_ok(Changes =>
"placeholder date/time" => qr(Date/time)
);
module_boilerplate_ok('lib/Banal/Utils.pm');
}
( run in 0.970 second using v1.01-cache-2.11-cpan-cc502c75498 )