Beefy Boxes and Bandwidth Generously Provided by pair Networks
We don't bite newbies here... much

Re^2: How to see what is available in Module::Namespace::*

by ikegami (Pope)
on Sep 21, 2009 at 19:45 UTC ( #796599=note: print w/replies, xml ) Need Help??

in reply to Re: How to see what is available in Module::Namespace::*
in thread How to see what is available in Module::Namespace::*

That only searches one of @INC's directories, and it has portability issues. Fix:

use Path::Class qw( dir ); use Scalar::Util qw( reftype ); my $base_pkg = __PACKAGE__ . '::Plugins'; my %plugins; my @subdirs = split(/::/, $base_pkg); for (@INC) { next if reftype($_); ++$plugins{"{$base_pkg}::$_"} for grep /^\.pm\z/, map $_->basename(), grep !$_->is_dir(), dir($_, @subdirs)->children(); } ( my $base_dir = $base_pkg ) =~ s{::}{/}g; ++$plugins{"{$base_pkg}::$_"} for map m{^\Q$base_dir\E/([^/]+)\.pm\z}, keys(%INC); my @plugins = sort keys(%plugins); # Load them all! for my $plugin (@plugins) { eval("require \E$plugin\Q") or die("Loading plugin $plugin: $@"); }

You gotta be careful that the file name case matches the package name case on case-agnostic systems. You've got a problem if there's a caseless system out there. Maybe some heuristics would help (such as scanning the .pm for a matching package statement and use its case).

Scanning %INC is useful for getting around the problem of a package manager creating a virtual file system using a reference in @INC.

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://796599]
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others imbibing at the Monastery: (3)
As of 2020-07-04 10:18 GMT
Find Nodes?
    Voting Booth?

    No recent polls found