Last month I conducted Perl training for IBM Pune team. During conducting the training, I mentioned about modules that are available at CPAN. The obvious question from course participants was, how to install the modules available from CPAN. Here's how.
If you don't have time for the details, here's what to do.
Download the tarball (the .tar.gz file) from CPAN. Unzip and untar the tarball.
# make
# make test
# make install
Or if you have Internet connection available at your system :
# perl -MCPAN -e "install Your::Module"
Well, if you're interested in the full story, then read on.
If you don't have time for the details, here's what to do.
Download the tarball (the .tar.gz file) from CPAN. Unzip and untar the tarball.
# make
# make test
# make install
Or if you have Internet connection available at your system :
# perl -MCPAN -e "install Your::Module"
Well, if you're interested in the full story, then read on.
The Comprehensive Perl Archive Network (CPAN) is a repository of over 250,000 software modules written in the Perl programming language by over 12,000 contributors.
Like all other modern programming languages, Perl provides a way to use external libraries of code. The common subroutines could be then used by several programs. In the Perl culture, these are called modules.
Like all other modern programming languages, Perl provides a way to use external libraries of code. The common subroutines could be then used by several programs. In the Perl culture, these are called modules.
Before we begin with installing a CPAN module, why not check whether it is already installed at the system? Say, we want to check whether module Data::Dumper is installed or not. To do that, we could make an attempt to use the Data::Dumper module. If that turns successful, we have the module installed. If we see an error, that means the module is not present at our system.
$ perl -e "use Data::Dumper;"
$
No error, so module Data::Dumper is already installed!
$ perl -e "use XML::Reader;"
Can't locate XML/Reader.pm in @INC (@INC contains: /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5 .) at -e line 1.
BEGIN failed--compilation aborted at -e line 1.
$
My attempt to use XML::Reader module resulted in an error, indicating that the module is not installed at my system.
Please note : For installing CPAN modules at Linux system, our user account should have root privilege.
There are two ways to install a CPAN module at a Linux system.
Method 1 : Manual installation by downloading the tarball from CPAN and build from source code using make
Method 2 : Automated installation using the CPAN shell. This requires connection to Internet.
To begin with, let's see how to install a module using the first (manual installation) method.
Download the tarball from CPAN. A tarball is a gzip compressed tar file, usually ending with .tar.gz in its name. For example, .tar.gz file of XML::Reader module is available at https://cpan.metacpan.org/authors/id/K/KE/KEICHNER/XML-Reader-0.65.tar.gz
Here's how I download the tarball using wget.
# wget https://cpan.metacpan.org/authors/id/K/KE/KEICHNER/XML-Reader-0.65.tar.gz --no-check-certificate
--2018-07-19 13:13:18-- https://cpan.metacpan.org/authors/id/K/KE/KEICHNER/XML-Reader-0.65.tar.gz
Resolving cpan.metacpan.org... 151.101.158.217, 2a04:4e42:25::729
Connecting to cpan.metacpan.org|151.101.158.217|:443... connected.
WARNING: certificate common name e.sni.fastly.netâcpan.metacpan.org
HTTP request sent, awaiting response... 200 OK
Length: 75978 (74K) [application/x-gzip]
Saving to: XML-Reader-0.65.tar.gz
100%[===================================================================================================================>] 75,978 --.-K/s in 0.08s
2018-07-19 13:13:20 (931 KB/s) - XML-Reader-0.65.tar.gz
#
Now unzip and untar XML-Reader-0.65.tar.gz file that we have obtained.
# tar -zxvf XML-Reader-0.65.tar.gz
XML-Reader-0.65
XML-Reader-0.65/README
XML-Reader-0.65/Changes
XML-Reader-0.65/LICENSE
XML-Reader-0.65/dist.ini
XML-Reader-0.65/META.yml
XML-Reader-0.65/MANIFEST
XML-Reader-0.65/Makefile.PL
XML-Reader-0.65/lib/XML
XML-Reader-0.65/lib/XML/Reader.pm
XML-Reader-0.65/lib/XML/Reader_de.pod
XML-Reader-0.65/lib/XML/Reader_fr.pod
XML-Reader-0.65/t
XML-Reader-0.65/t/release-pod-syntax.t
XML-Reader-0.65/t/0010_test_functions.t
XML-Reader-0.65/lib/XML/Reader
XML-Reader-0.65/lib/XML/Reader/Testcases.pm
#
What are these z x v f options of tar command?
From the manual page of tar command :
-z, --gzip
filter the archive through gzip
-x, --extract, --get
extract files from an archive
-v, --verbose
verbosely list files processed
-f, --file=ARCHIVE
use archive file or device ARCHIVE
A directory named XML-Reader-0.65 would be created in the current working directory.
# cd XML-Reader-0.65
#
# ls -l
total 64
-rw-r--r-- 1 root root 14247 Dec 28 2014 Changes
-rw-r--r-- 1 root root 469 Dec 28 2014 dist.ini
drwx------ 3 root root 4096 Jul 19 13:14 lib
-rw-r--r-- 1 root root 18352 Dec 28 2014 LICENSE
-rw-r--r-- 1 root root 1321 Dec 28 2014 Makefile.PL
-rw-r--r-- 1 root root 280 Dec 28 2014 MANIFEST
-rw-r--r-- 1 root root 693 Dec 28 2014 META.yml
-rw-r--r-- 1 root root 402 Dec 28 2014 README
drwxr-xr-x 2 root root 4096 Dec 28 2014 t
#
While in XML-Reader-0.65 directory, execute `perl Makefile.PL` This will check if all the dependencies are installed, and if all the files listed in the MANIFEST file were included. If successful, a Makefile will be generated, without any extension.
# perl Makefile.PL
Checking if your kit is complete...
Looks good
Warning: prerequisite Acme::HTTP 0 not found.
Warning: prerequisite XML::Parsepp 0 not found.
Writing Makefile for XML::Reader
[root@.localhost XML-Reader-0.65]#
In this case, two prerequisite modules Acme::HTTP and XML::Parsepp are not found. So I should install them first and then proceed further. And what if I continue further without installing the prerequisite modules? Okay, let's try that. Next step is to execute `make` in order to compile the source code.
# make
cp lib/XML/Reader_de.pod blib/lib/XML/Reader_de.pod
cp lib/XML/Reader.pm blib/lib/XML/Reader.pm
cp lib/XML/Reader_fr.pod blib/lib/XML/Reader_fr.pod
cp lib/XML/Reader/Testcases.pm blib/lib/XML/Reader/Testcases.pm
Manifying blib/man3/XML::Reader_de.3pm
Manifying blib/man3/XML::Reader::Testcases.3pm
Manifying blib/man3/XML::Reader_fr.3pm
Manifying blib/man3/XML::Reader.3pm
#
Optionally, execute `make test` to run the automated tests.
Although we could skip executing `make test`, this is a recommended step. Result coming from executing the tests is usually a good indicator of the road ahead.
# make test
PERL_DL_NONLAZY=1 /usr/bin/perl "-MExtUtils::Command::MM" "-e" "test_harness(0, 'blib/lib', 'blib/arch')" t/*.t
t/0010_test_functions.t .. 1/54
# Failed test 'use XML::Reader;'
# at t/0010_test_functions.t line 6.
# Tried to use 'XML::Reader'.
# Error: Can't locate Acme/HTTP.pm in @INC (@INC contains: /root/XML-Reader-0.65/blib/lib /root/XML-Reader-0.65/blib/arch /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5 .) at /root/XML-Reader-0.65/blib/lib/XML/Reader.pm line 7.
# BEGIN failed--compilation aborted at /root/XML-Reader-0.65/blib/lib/XML/Reader.pm line 7.
# Compilation failed in require at t/0010_test_functions.t line 6.
# BEGIN failed--compilation aborted at t/0010_test_functions.t line 6.
# Failed test 'Test-001 sub XML::Reader::import is defined'
# at t/0010_test_functions.t line 69.
# Failed test 'Test-002 sub XML::Reader::activate is defined'
# at t/0010_test_functions.t line 69.
...
...
...
# Failed test 'Test-052 sub XML::Reader::Token::extract_proc is defined'
# at t/0010_test_functions.t line 69.
# Failed test 'Test-053 sub XML::Reader::Token::extract_decl is defined'
# at t/0010_test_functions.t line 69.
# Looks like you failed 54 tests of 54.
t/0010_test_functions.t .. Dubious, test returned 54 (wstat 13824, 0x3600)
Failed 54/54 subtests
t/release-pod-syntax.t ... skipped: these tests are for release candidate testing
Test Summary Report
-------------------
t/0010_test_functions.t (Wstat: 13824 Tests: 54 Failed: 54)
Failed tests: 1-54
Non-zero exit status: 54
Files=2, Tests=54, 0 wallclock secs ( 0.03 usr 0.01 sys + 0.13 cusr 0.01 csys = 0.18 CPU)
Result: FAIL
Failed 1/2 test programs. 54/54 subtests failed.
make: *** [test_dynamic] Error 255
#
Executing the automated tests usually produces a long output, which I have cut short in the above listing. In this case, all tests failed. Possibly because the prerequisite modules are not available.
Although tests have failed, I could execute `make install` to install the module in the correct place.
# make install
Installing /usr/local/share/perl5/XML/Reader_de.pod
Installing /usr/local/share/perl5/XML/Reader.pm
Installing /usr/local/share/perl5/XML/Reader_fr.pod
Installing /usr/local/share/perl5/XML/Reader/Testcases.pm
Installing /usr/local/share/man/man3/XML::Reader_de.3pm
Installing /usr/local/share/man/man3/XML::Reader_fr.3pm
Installing /usr/local/share/man/man3/XML::Reader.3pm
Installing /usr/local/share/man/man3/XML::Reader::Testcases.3pm
Appending installation info to /usr/lib64/perl5/perllocal.pod
#
Time to check whether XML::Reader module is now available.
# perl -e "use XML::Reader;"
Can't locate Acme/HTTP.pm in @INC (@INC contains: /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5 .) at /usr/local/share/perl5/XML/Reader.pm line 7.
BEGIN failed--compilation aborted at /usr/local/share/perl5/XML/Reader.pm line 7.
Compilation failed in require at -e line 1.
BEGIN failed--compilation aborted at -e line 1.
#
So we must install the prerequisite module Acme::HTTP
Then another error would tell that prerequisite module XML::Parsepp can't be located. I will have to install XML::Parsepp as well, so that all required prerequisite modules are available.
This could be a long way to home. Before I install the module I intended, I must identify all prerequisite modules and install all of them. A prerequisite module may have its own prerequisite(s). This could be a really long way to home, depending upon how many prerequisites we run into.
There is a way available to make this task easier. By opening a CPAN shell in perl, we could install the required module and all of its prerequisites. The CPAN shell connects to cpan.org, identifies all prerequisites, downloads all prerequisites and the module we want to install, and installs them in appropriate sequence. Voila! All we need is Internet connection to connect to cpan.org
# perl -MCPAN -e "install XML::Reader"
No Internet connection to connect to cpan.org? Well, the only option left is to get the tarballs (the .tar.gz files) from somewhere else and install each of them in the right sequence, as per the dependencies.
And now if you insist on looking at official documentation, why don't you get a terminal and type `perldoc perlmodinstall` or point your web browser to http://perldoc.perl.org/perlmodinstall.html
No comments:
Post a Comment