NAME
CPAN::Index::Loader - Populates the CPAN index SQLite database
DESCRIPTION
This package implements all the functionality required to download the CPAN index data, parse it, and populate the SQLite database file.
Because it involves loading a number of otherwise unneeded modules, this package is not loaded by default with the rest of CPAN::Index, but may be loaded on-demand if needed.
METHODS
new
my $loader = CPAN::Index::Loader->new(
remote_uri => 'http://search.cpan.org/CPAN',
local_dir => '/tmp/cpanindex',
);
cache
The cache
accessor returns a CPAN::Cache object that represents the CPAN cache.
remote_uri
The remote_uri
accessor return a URI object for the location of the CPAN mirror.
local_dir
The local_dir
accessor returns the filesystem path for the root directory of the local CPAN file cache.
local_file
my $path = $loader->local_file('01mailrc.txt.gz');
The local_file
method takes the name of a file in the CPAN and returns the local path to the file.
Returns a path string, or throws an exception on error.
local_handle
my $path = $loader->local_handle('01mailrc.txt.gz');
The local_handle
method takes the name of a file in the CPAN and returns an IO::Handle to the file.
Returns an IO::Handle, most likely an IO::Handle, or throws an exception on error.
load_index
The load_index
takes a single param of the schema to load, locates the three main index files based on the local_dir
path, and then loads the index from those files.
Returns the total number of records added.
load_authors
CPAN::Index::Loader->load_authors( $schema, $handle );
The load_authors
method populates the package
table from the CPAN 01mailrc.txt.gz file.
The author
table in the SQLite database should already be empty before this method is called.
Returns the number of authors added to the database, or throws an exception on error.
load_packages
CPAN::Index::Loader->load_packages( $schema, $handle );
The load_packages
method populates the package
table from the CPAN 02packages.details.txt.gz file.
The package
table in the SQLite database should already be empty before this method is called.
Returns the number of packages added to the database, or throws an exception on error.
SUPPORT
Bugs should be reported via the CPAN bug tracker
http://rt.cpan.org/NoAuth/ReportBug.html?Queue=CPAN-Index
For other issues, contact the author.
AUTHOR
Adam Kennedy <cpan@ali.as>
Parts based on various modules by Leon Brocard <acme@cpan.org>
SEE ALSO
Related: CPAN::Index, CPAN
Based on: Parse::CPAN::Authors, Parse::CPAN::Packages
COPYRIGHT
Copyright (c) 2006 Adam Kennedy.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
The full text of the license can be found in the LICENSE file included with this module.