|
NAMEModule::Load - runtime require of both modules and filesSYNOPSISuse Module::Load; my $module = 'Data::Dumper'; load Data::Dumper; # loads that module, but not import any functions # -> cannot use 'Dumper' function load 'Data::Dumper'; # ditto load $module # tritto autoload Data::Dumper; # loads that module and imports the default functions # -> can use 'Dumper' function my $script = 'some/script.pl' load $script; load 'some/script.pl'; # use quotes because of punctuations load thing; # try 'thing' first, then 'thing.pm' load CGI, ':all'; # like 'use CGI qw[:standard]' DESCRIPTION"Module::Load" eliminates the need to know whether you are trying to require either a file or a module.If you consult "perldoc -f require" you will see that "require" will behave differently when given a bareword or a string. In the case of a string, "require" assumes you are wanting to load a file. But in the case of a bareword, it assumes you mean a module. This gives nasty overhead when you are trying to dynamically require modules at runtime, since you will need to change the module notation ("Acme::Comment") to a file notation fitting the particular platform you are on. "Module::Load" eliminates the need for this overhead and will just DWYM. Difference between "load" and "autoload""Module::Load" imports the two functions - "load" and "autoload""autoload" imports the default functions automatically, but "load" do not import any functions. "autoload" is usable under "BEGIN{};". Both the functions can import the functions that are specified. Following codes are same. load File::Spec::Functions, qw/splitpath/; autoload File::Spec::Functions, qw/splitpath/; FUNCTIONS
RulesAll functions have the following rules to decide what it thinks you want:
IMPORTS THE FUNCTIONS'load' and 'autoload' are imported by default, but 'load_remote' and 'autoload_remote' are not imported.To use 'load_remote' or 'autoload_remote', specify at 'use'.
CaveatsBecause of a bug in perl (#19213), at least in version 5.6.1, we have to hardcode the path separator for a require on Win32 to be "/", like on Unix rather than the Win32 "\". Otherwise perl will not read its own %INC accurately double load files if they are required again, or in the worst case, core dump."Module::Load" cannot do implicit imports, only explicit imports. (in other words, you always have to specify explicitly what you wish to import from a module, even if the functions are in that modules' @EXPORT) SEE ALSOModule::Runtime provides functions for loading modules, checking the validity of a module name, converting a module name to partial ".pm" path, and related utility functions."require" in perlfunc <https://metacpan.org/pod/perlfunc#require> and "use" in perlfunc <https://metacpan.org/pod/perlfunc#use>. Mojo::Loader is a "class loader and plugin framework", and is included in the Mojolicious <https://metacpan.org/release/Mojolicious> distribution. Module::Loader is a module for finding and loading modules in a given namespace, inspired by "Mojo::Loader". ACKNOWLEDGEMENTSThanks to Jonas B. Nielsen for making explicit imports work.BUG REPORTSPlease report bugs or other issues to <bug-module-load@rt.cpan.org>.AUTHORThis module by Jos Boumans <kane@cpan.org>.COPYRIGHTThis library is free software; you may redistribute and/or modify it under the same terms as Perl itself.
Visit the GSP FreeBSD Man Page Interface. |