PRIORITIES

Ensure the Store does not overwrite files.
Extract versioning stuff to a separate dist.
Command to unregister a pkg/dist
Command to examine the delta between two stacks or revisions
Add versioning to the stack props
Add stack props and repos props to the dump META
Create command to load repository from a dump
Try to ensure integrity of commits
Refactor the Initializer class

#--------------------------

Attribute to indicate of package was explicitly requested for stack
Improve locking mechanism (one lock per stack, maybe in db).
Consider using natural keys for package/dists.
Consider pinning at dist level, not pkg
Command to list dependors and dependants
Command to verify prereqs on a stack
Write test cases for Stack operations
Command to list outdated packages
Command options to specify provided/required packages (maybe not)
Stack property: strict (no overlapping dists) ??
Stack property: target perl
Stack property: source repositories
Stack property: allow devel releases
Repo property: log level
Repo property: default sources
Repo property: default target perl
Repo property: defautl devel option
Prettier stack listing and stack prop listing
Re-examine log levels for messages
Should we throw() or just log->fatal()
Should we have an heirarchy of exception classes
Verify archive checksums during 'verify'
Add hooks before/after adding and pulling
Give revisions properties ??
Allow revisions to be tagged
Mark stacks as merged after merge
Mark stacks as deleted after delete
Warn if an unmerged stack is being deleted
Way to pin/unpin all packages in a stack
Make the Store transactional
Rewrite tests with Test::Class

LESS IMPORTANT

Documentation review

Need to add the 'documentation' key to all my attributes. Also, need to figure out how to get Pod::Weaver to consolidate

API documentation
Support target_perl option

So you can specify which perl to compute dependencies with. Because the perl you want to deploy with may not be the one that you use to run Pinto.

More robust list action

Actually, I think it is good enough for now

Query language?

Not yet -- no clear use case.

IDEAS FOR COOL NEW ACTIONS

look: Unpack archive in temp dir and launch shell there
ack: Do an ack command across all distributions
news: list recent additions. maybe something from Changes file

OTHER STUFF TODO

In no particular order...

Create a hook mechanism to do stuff before or after an Action

Like to notify people when the repository contents have changed. Or to kick off a build when the repository changes.

Enable plugins for visiting and filtering. See CPAN::Mini and CPAN::Mini::Visit.
Standardize API, using named parameters except where it makes sense not to.
Write a tutorial to explain different ways for using Pinto in the development/deployment cycle. ++
Generate a RECENT file. This could just contain the files added in the last action (if any).
Improve Perl::Critic compliance.
Document, document, document.
Tests, tests, tests.
Look for better ways to use Moose roles.
Profile and look for performance optimizations.
Add --package option to the Add action

To excplicitly declare what packages the archive provides, in cases where the META is whack or the packages can't be discovered.

STUFF DISCUSSED WITH RJBS

Features inspired by XPAN

Implement a "dry-run" feature.

Whenever Pinto fetches a .tar.gz, it first puts in a temporary directory (I think). After the packages and prereqs have been extracted, only then does it actually place it in the repository. So if --dryrun is enabled, don't put it in the repository. Also, if --dryrun is enabled, roll back the database transaction. There might be multiple layers of transactions going on, so we'll have to roll back at the right level. Finally, each Action must return 0 if --dryrun is enabled, to indicate that the repository state has not changed and does not need to be committed to VCS.

Warn when an imported/added package conflicts with a pinned package.

Each time a package is added, Pinto looks at all the other packages with the same name and sorts them according to version number, whether it is pinned, and whether it is "local" or "foreign". From that, it determines what the "latest" version is and marks that to be included in the index. So that would probably be the time to warn if an incoming prereq is blocked by an older pinned package.

Other housekeeping chores that need to be done...

Optimize generation of CHECKSUMS files.

At the moment, I'm using Adreas' module, which generates a CHECKSUMS file by recomputing md5s for everything in the directory. I think this is because PAUSE is paranoid about keeping accurate CHECKSUMS. But this makes importing/adding/mirroring slow if the author's directory already contains a lot of dists. Better to just compute the md5 for the new dist and append it to the ones that are already in the CHECKSUMS file.

Come up with a strategy for schema migration.

I'm using SQLite and DBIx::Class. Every time the database schema changes, I break compatibility with all the existing repos (if there are any). So I need some way for Pinto to upgrade its own schema. I know there are frameworks for doing this but I just haven't learned them. Or maybe just use something like KiokuDB.

Document the architecture.

Pinto has a pretty well-defined architecture -- there are distinct layers and separations of concern. It may not be the *right* architecture, but it is definitely there. I need to capture it on paper so I (and others) can reason about it.

Document the API.

Only the command-line interface has any real documentation. The internal API has started to become stable and needs to get some documentation love.

Grand wishes...

Make Pinto extensible in the way that Dist::Zilla is.

For example, I can imagine roles like BeforeAddition/AfterAddition and BeforeRemoval/AfterRemoval that provide hooks where plugins can make stuff happen when a dist is added or removed from the repository. Stuff like publish the POD to a website, or tweet a notification, or fire off a build, or run a local metacpan. But that all may be premature.