Module::AutoINC - Download and install CPAN/PPM modules upon first use.
perl -MModule::AutoINC <script>
When Module::AutoINC is loaded, it will add itself to @INC and catch any requests for missing resources. If a Perl module is requested that has not been installed, then this will attempt to load it. Under Active State Perl (or any Perl where PPM is available), PPM will attempt to install it. Otherwise CPAN will be queried and, assuming that the module exists on CPAN, CPAN::Shell will be invoked to install it. Execution of the script continues after the requisite module has been installed.
Module::AutoINC is a slightly useful tool designed to streamline the process of installing the modules required by a script. By loading the Module::AutoINC module (usually via a "-MModule::AutoINC" command-line option), the user is registering a handler that will catch any attempt to use a module that does not exist on the local machine. In this case, the CPAN::Shell module will be invoked to search for the specified module and, if found, an attempt will be made to install the module. If successful, the module will be loaded and execution will continue as normal.
You can modify the behavior of the module slightly using several import symbols. All import symbols are case-insensitive.
If you import the special symbol 'force' then the installation of the module(s) will be forced. The definition of a 'forced' installation varies depending on whether you are installing using PPM or CPAN. See the relevant documentation for each system for more information.
You can override the installation method detection using the import symbols, 'cpan' or 'ppm'. 'cpan' will cause CPAN to be used for module installation no matter whether PPM is available or not. 'ppm' will attempt to install the module using PPM regardless of whether ppm is findable by Module::AutoINC. Of course, you should know what you are doing if you use these import symbols.
perl -MModule::AutoINC -MLingua::Num2Word=cardinal -le 'print cardinal("en", 42)'
...will download and install Lingua::Num2Word and Lingua::EN::Num2Word.
perl -MModule::AutoINC=cpan -MLingua::Num2Word=cardinal -le 'print cardinal("de", 42)'
...will then download and install (using CPAN, even under ActiveState Perl) Lingua::DE::Num2Word (German).
perl -MModule::AutoINC=force -MLingua::Num2Word=cardinal -le 'print cardinal("es", 42)'
...will then download and install (forcefully) Lingua::ES::Numeros (Spanish).
The description for the Acme::RemoteINC CPAN module ("Slowest Possible Module Loading") prompted me to write this module. The only thing slower than loading precompiled modules via FTP is loading module source code from FTP and compiling it. Except maybe carrier pigeons.
As you can see from the CAVEATS section, there is a fair amount of set-up work required and it will not work for all modules. This makes it relatively useless, especially in a production environment. But it's a cool hack, and could potentially be useful under very limited circumstances.
Since we use a number of CPAN modules in our scripts at work setting up new systems with the range of modules can be onerous especially for those who are not very experienced with Perl and it's nuances. Don's CPAN::AutoINC was a good start on a solution, but since we use a mix of Linux and Windows systems I wanted something that would handle ActiveState Perl as well as vanilla Perl transparently.
Don Schwarz's original version. Did CPAN installs only.
Mike MacKenzie, <firstname.lastname@example.org> Original CPAN::AutoINC: Don Schwarz, <email@example.com>
Copyright 2006 by Language Weaver, Inc.
Based on CPAN::AutoINC
Copyright 2004 by Don Schwarz
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.