NAME

Tree::Path::Class - Tree for Path::Class objects

VERSION

version 0.002

SYNOPSIS

use Tree::Path::Class;
use Path::Class;

my $tree  = Tree::Path::Class->new( dir('/parent/dir') );
my $child = Tree::Path::Class->new( file('child/file') );
$tree->add_child($child);

print $child->path->stringify;
# /parent/dir/child/file

DESCRIPTION

This module subclasses Tree to only accept Path::Class::Dir or Path::Class::File values, and provides a path attribute for retrieving the full path of a tree branch or leaf.

ATTRIBUTES

path

A read-only accessor that returns the tree's full Path::Class::Dir or Path::Class::File object, with all parents prepended.

METHODS

FOREIGNBUILDARGS

Coerces the parameter passed to new() into a Path::Class::Dir or Path::Class::File before passing it on to the superclass constructor.

add_child

Works just like the superclass' method. Plain Tree nodes will be recursively recreated as Tree::Path::Class nodes when added.

SUPPORT

Perldoc

You can find documentation for this module with the perldoc command.

perldoc Tree::Path::Class

Websites

The following websites have more information about this module, and may be of help to you. As always, in addition to those websites please use your favorite search engine to discover more resources.

Bugs / Feature Requests

Please report any bugs or feature requests through the web interface at https://github.com/mjgardner/Tree-Path-Class/issues. You will be automatically notified of any progress on the request by the system.

Source Code

The code is open to the world, and available for you to hack on. Please feel free to browse it and play with it, or whatever. If you want to contribute patches, please send me a diff or prod me to pull from your repository :)

https://github.com/mjgardner/Tree-Path-Class

git clone git://github.com/mjgardner/Tree-Path-Class.git

AUTHOR

Mark Gardner <mjgardner@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2012 by GSI Commerce.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.