CPANPLUS
view release on metacpan or search on metacpan
inc/bundle/Module/Pluggable/Object.pm view on Meta::CPAN
$directory = abs2rel($directory, $sp);
# If we have a mixed-case package name, assume case has been preserved
# correctly. Otherwise, root through the file to locate the case-preserved
# version of the package name.
my @pkg_dirs = ();
if ( $name eq lc($name) || $name eq uc($name) ) {
my $pkg_file = catfile($sp, $directory, "$name$suffix");
open PKGFILE, "<$pkg_file" or die "search_paths: Can't open $pkg_file: $!";
my $in_pod = 0;
while ( my $line = <PKGFILE> ) {
$in_pod = 1 if $line =~ m/^=\w/;
$in_pod = 0 if $line =~ /^=cut/;
next if ($in_pod || $line =~ /^=cut/); # skip pod text
next if $line =~ /^\s*#/; # and comments
if ( $line =~ m/^\s*package\s+(.*::)?($name)\s*;/i ) {
@pkg_dirs = split /::/, $1 if defined $1;;
$name = $2;
last;
}
}
close PKGFILE;
}
# then create the class name in a cross platform way
$directory =~ s/^[a-z]://i if($^O =~ /MSWin32|dos/); # remove volume
my @dirs = ();
if ($directory) {
($directory) = ($directory =~ /(.*)/);
@dirs = grep(length($_), splitdir($directory))
unless $directory eq curdir();
for my $d (reverse @dirs) {
my $pkg_dir = pop @pkg_dirs;
last unless defined $pkg_dir;
$d =~ s/\Q$pkg_dir\E/$pkg_dir/i; # Correct case
}
} else {
$directory = "";
}
my $plugin = join '::', $searchpath, @dirs, $name;
next unless $plugin =~ m!(?:[a-z\d]+)[a-z\d]*!i;
$self->handle_finding_plugin($plugin, \@plugins)
}
# now add stuff that may have been in package
# NOTE we should probably use all the stuff we've been given already
# but then we can't unload it :(
push @plugins, $self->handle_innerpackages($searchpath);
} # foreach $searchpath
return @plugins;
}
sub _is_editor_junk {
my $self = shift;
my $name = shift;
# Emacs (and other Unix-y editors) leave temp files ending in a
# tilde as a backup.
return 1 if $name =~ /~$/;
# Emacs makes these files while a buffer is edited but not yet
# saved.
return 1 if $name =~ /^\.#/;
# Vim can leave these files behind if it crashes.
return 1 if $name =~ /^[._].*\.s[a-w][a-z]$/;
return 0;
}
sub handle_finding_plugin {
my $self = shift;
my $plugin = shift;
my $plugins = shift;
my $no_req = shift || 0;
return unless $self->_is_legit($plugin);
unless (defined $self->{'instantiate'} || $self->{'require'}) {
push @$plugins, $plugin;
return;
}
$self->{before_require}->($plugin) || return if defined $self->{before_require};
unless ($no_req) {
my $tmp = $@;
my $res = eval { require_module($plugin) };
my $err = $@;
$@ = $tmp;
if ($err) {
if (defined $self->{on_require_error}) {
$self->{on_require_error}->($plugin, $err) || return;
} else {
return;
}
}
}
$self->{after_require}->($plugin) || return if defined $self->{after_require};
push @$plugins, $plugin;
}
sub find_files {
my $self = shift;
my $search_path = shift;
my $file_regex = $self->{'file_regex'} || qr/\.pm$/;
# find all the .pm files in it
# this isn't perfect and won't find multiple plugins per file
#my $cwd = Cwd::getcwd;
my @files = ();
{ # for the benefit of perl 5.6.1's Find, localize topic
local $_;
File::Find::find( { no_chdir => 1,
follow => $self->{'follow_symlinks'},
wanted => sub {
# Inlined from File::Find::Rule C< name => '*.pm' >
return unless $File::Find::name =~ /$file_regex/;
(my $path = $File::Find::name) =~ s#^\\./##;
push @files, $path;
}
( run in 1.385 second using v1.01-cache-2.11-cpan-5b529ec07f3 )