NAME
    CPAN::Cache - Abstract locally-cached logical subset of a CPAN mirror

DESCRIPTION
    There have been any number of scripts and modules written that contain
    as part of their functionality some form of locally stored partial
    mirror of the CPAN dataset.

    CPAN::Cache does the same thing, except that in addition it has the
    feature that the downloading and storage of CPAN data is all that it
    does, so it should not introduce any additional dependencies or bloat,
    and should be much easier to reuse that existing modules, which
    generally are more task-specific.

    The intent is that this module will be usable by everything that is in
    the business of pulling modules from CPAN, storing them locally, and
    doing something with them.

    In this way, it really does little other than mirror data from a remote
    URI, except that CPAN::Cache also provides some additional intelligence
    about which files are and are not static (will never change) which
    aren't, and is typed specifically as a mirror of CPAN, instead of any
    other sort of mirror.

    By building this module as a seperate distribution, it is hoped we can
    improve seperation of concerns in the CPAN-related modules and ensure
    cleaner, smaller, and more robust tools that interact with the CPAN in
    the most correct ways.

METHODS
  new
      my $cache = CPAN::Cache->new(
          remote_uri => 'http://search.cpan.org/CPAN/',
          local_dir  => '/tmp/cpan',
          );

  remote_uri
    The "remote_uri" accessor returns a URI object for the remote CPAN
    repository.

  local_dir
    The "local_dir" accessor returns the filesystem path for the root root
    directory of the CPAN cache.

  file path/to/file.txt
    The "file" method takes the path of a file within the repository, and
    returns a URI::ToDisk object representing it's location on both the
    server, and on the local filesystem.

    Paths should always be provided in unix/web format, not the local
    filesystem's format.

    Returns a HTML::ToDisk or throws an exception if passed a bad path.

  get path/to/file.txt
    The "get" method takes the path of a file within the repository, and
    fetches it from the remote repository, storing it at the appropriate
    local path.

    Paths should always be provided in unix/web format, not the local
    filesystem's format.

    Returns the URI::ToDisk for the file if retrieved successfully, false
    false if the file does not exist within the repository, or throws an
    exception on error.

  mirror path/to/file.txt
    The "mirror" method takes the path of a file within the repository, and
    mirrors it from the remote repository, storing it at the appropriate
    local path.

    Using this method if preferable for items like indexs for which want to
    ensure you have the current version, but do not want to freshly download
    each time.

    Paths should always be provided in unix/web format, not the local
    filesystem's format.

    Returns the URI::ToDisk for the file if mirrored successfully, false if
    the file did not exist in the repository, or throws an exception on
    error.

  static
    The "static" method determines whether a given path within CPAN is able
    to change or not.

    In the CPAN, some files such as index files and checksum can change,
    while other files such as the tarball files will be static, and once
    committed to the repository will never be changed (altough they may be
    deleted).

    In a caching scenario, this means that if the file exists locally, we
    will never need to return to the server to check for a new version, we
    enables additional optimisations for CPAN-related algorithms.

    Returns true if the file will never change, false if not, or throws an
    exception on error.

TO DO
    - Write a proper test suite, not just a compile test (even though this
    was taken from working JSAN code)

SUPPORT
    Bugs should be reported via the CPAN bug tracker

    <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=CPAN-Cache>

    For other issues, contact the author.

AUTHOR
    Adam Kennedy <adamk@cpan.org>

SEE ALSO
    CPAN::Index, CPAN::Mini, DBIx::Class

COPYRIGHT
    Copyright 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.