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.