This is the README file for CPANPLUS, Ameliorated interface to the Comprehensive Perl Archive Network, by Jos Boumans. Please type "perldoc CPANPLUS" after installation to see the module usage information. For shell usage, please consult "perldoc cpanp"; the FAQ is available as "perldoc CPANPLUS::FAQ". You may also want to read the 'ChangeLog' file, which describes new features, bugfixes and additional notes for this release. ### PLEASE NOTE ################################################### CPANPLUS will be shipped alongside CPAN.pm in the 5.10 core. Although you should *NOT* expect it to work just like CPAN.pm, there is a compatible shell available. See perldoc CPANPLUS::Shell after installation You are strongly urged to configure CPANPLUS now, since otherwise non-privileged (non-root) users may be unable to use CPANPLUS until you configure it properly. ################################################################### * Installation CPANPLUS uses the standard perl module install process: perl Makefile.PL make # or 'nmake' on Windows make test make install * Notes for Windows users If you are using Microsoft Windows, you will probably need the 'nmake' utility before installation. It's available at: http://download.microsoft.com/download/vc15/Patch/1.52/W95/EN-US/nmake15.exe If you are connected to the internet, "perl Makefile.PL" is capable of automatically fetch it, and install into your Perl/bin directory. You will see a message like this: The required 'nmake' executable not found, fetching it... However, if you are not yet online, or wish to install 'nmake' into another directory, then please download the file manually, save it to a directory in %PATH (e.g. C:\WINDOWS\COMMAND), then launch the MS-DOS command line shell, "cd" to that directory, and run "nmake15.exe" from there; that will create the 'nmake.exe' file. You may then resume the installation process above, but replace 'make' with 'nmake' in the last three lines. * Notes on CPAN testing CPANPLUS offers several features to query and report module testing results. For example, typing "cpanp -c DBI" in the command line (or "c DBI" in the CPANPLUS default shell) will display the test results of latest DBI package. If you wish to report module test results as part of installation process, please answer "Y" to the 'Report tests results? [y/N]:' question during the interactive configuration. You can also type "s edit" in the CPANPLUS Default Shell to edit the config file manually, or just enter "s conf cpantest 1" and "s save" to save the settings. Please consult the CPAN Tester's Website (http://testers.cpan.org/) for detailed information. * Contact CPANPLUS has several mailing lists you can write to: - General suggestions: <cpanplus-info@lists.sourceforge.net> - Bug reporting: <cpanplus-bugs@lists.sourceforge.net> - Development list: <cpanplus-devel@lists.sourceforge.net> News and project updates are available at http://cpanplus.sf.net/. * Copyright Copyright 2001, 2002, 2003, 2004 by Jos Boumans <kane@cpan.org>. All rights reserved. You can redistribute and/or modify this bundle under the same terms as Perl itself. See <http://www.perl.com/perl/misc/Artistic.html>. * CPANPLUS Abbreviated Manpage NAME CPANPLUS - Command-line access to the CPAN interface SYNOPSIS cpanp cpanp -i Some::Module perl -MCPANPLUS -eshell perl -MCPANPLUS -e'fetch Some::Module' ### for programmatic interfacing, see below ### DESCRIPTION The "CPANPLUS" library is an API to the "CPAN" mirrors and a collection of interactive shells, commandline programs, daemons, etc, that use this API. This documentation will discuss all of these briefly and direct you to the appropriate tool to use for the job at hand. INTERFACES COMMANDLINE The "CPANPLUS" library comes with several command line tools; "cpanp" This is the commandline tool to start the default interactive shell (see "SHELLS" below), or to do one-off commands. See "cpanp -h" for details. "cpan2dist.pl" This is a commandline tool to convert any distribution from "CPAN" into a package in the format of your choice, like for example ".deb" or "FreeBSD ports". See "cpan2dist.pl -h" for details. "cpanpd.pl" This is a daemon that acts as a remote backend to your default shell. This allows you to administrate multiple perl installations on multiple machines using only one frontend. See "cpanpd.pl -h" for details. SHELLS Interactive shells are there for when you want to do multiple queries, browse the "CPAN" mirrors, consult a distributions "README", etc. The "CPANPLUS" library comes with a variety of possible shells. You can install third party shells from the "CPAN" mirrors if the default one is not to your liking. CPANPLUS::Shell::Default This is the standard shell shipped with "CPANPLUS". The commands cpanp and perl -MCPANPLUS -eshell should fire it up for you. Type "h" at the prompt to see how to use it. CPANPLUS::Shell::Classic This is the emulation shell that looks and feels just like the old "CPAN.pm" shell. API All the above tools are written using the "CPANPLUS" API. If you have any needs that aren't already covered by the above tools, you might consider writing your own. To do this, use the "CPANPLUS::Backend" mod- ule. It implements the full "CPANPLUS" API. Consult the "CPANPLUS::Backend" documentation on how to use it. PLUGINS There are various plugins avaiable for "CPANPLUS". Below is a short listing of just a few of these plugins; Various shells As already available in the "0.04x" series, "CPANPLUS" provides various shells (as described in the "SHELL" section above). There are also 3rd party shells you might get from a "cpan" mirror near you like: CPANPLUS::Shell::Curses A shell using "libcurses" CPANPLUS::Shell::Tk A shell using the graphical tooklit "Tk" Various package manager plugins As already available in the "0.04x" series, "CPANPLUS" can provide a hook to install modules via the package manager of your choice. Look in the "CPANPLUS::Dist::" namespace on "cpan" to see what's available. Installing such a plugin will allow you to create pack- ages of that type using the "cpan2dist" program provided with "CPANPLUS" or by saying, to create for example, debian distribu- tions: cpanp -i Acme::Bleach --format=debian There are a few package manager plugins available and/or planned already, they include, but are not limited to: CPANPLUS::Dist::Ports Allows you to create packages for "FreeBSD ports". CPANPLUS::Dist::Deb Allows you to create ".deb" packages for "Debian linux". CPANPLUS::Dist::MDK Allows you to create packages for "MandrakeLinux". CPANPLUS::Dist::PPM Allows you to create packages in the "PPM" format, commonly used by "ActiveState Perl". CPANPLUS Remote Daemon New in the "0.05x" series is the "CPANPLUS Daemon". This applica- tion allows you to remotely control several machines running the "CPANPLUS Daemon", thus enabling you to update several machines at once, or updating machines from the comfort of your own desktop. This is done using "CPANPLUS::Shell::Default"'s "dispatch_on_input" method. See the "CPANPLUS::Shell::Default" manpage for details on that method. Scriptable Shell New in the "0.05x" series is the possibility of scripting the default shell. This can be done by using it's "dispatch_on_input" method. See the "CPANPLUS::Shell::Default" manpage for details on that method. Also, soon it will be possible to have a ".rc" file for the default shell, making aliases for all your commonly used functions. For exmpale, you could alias 'd' to do this: d --fetchdir=/my/downloads or you could make the re-reading of your sourcefiles force a refetch of those files at all times: x --update_source