NAME
MooseX::Types::Path::Class - A Path::Class type library for Moose
VERSION
version 0.09
SYNOPSIS
package
MyClass;
use
Moose;
has
'dir'
=> (
is
=>
'ro'
,
isa
=>
'Path::Class::Dir'
,
required
=> 1,
coerce
=> 1,
);
has
'file'
=> (
is
=>
'ro'
,
isa
=>
'Path::Class::File'
,
required
=> 1,
coerce
=> 1,
);
# these attributes are coerced to the
# appropriate Path::Class objects
MyClass->new(
dir
=>
'/some/directory/'
,
file
=>
'/some/file'
);
DESCRIPTION
MooseX::Types::Path::Class creates common Moose types, coercions and option specifications useful for dealing with Path::Class objects as Moose attributes.
Coercions (see Moose::Util::TypeConstraints) are made from both Str
and ArrayRef
to both Path::Class::Dir and Path::Class::File objects. If you have MooseX::Getopt installed, the Getopt
option type ("=s") will be added for both Path::Class::Dir and Path::Class::File.
EXPORTS
None of these are exported by default. They are provided via MooseX::Types.
- Dir, File
-
These exports can be used instead of the full class names. Example:
Note that there are no quotes around
Dir
orFile
. - is_Dir($value), is_File($value)
-
Returns true or false based on whether $value is a valid
Dir
orFile
. - to_Dir($value), to_File($value)
-
Attempts to coerce $value to a
Dir
orFile
. Returns the coerced value or false if the coercion failed.
SEE ALSO
MooseX::Types::Path::Class::MoreCoercions, MooseX::FileAttribute, MooseX::Types::URI
DEPENDENCIES
Moose, MooseX::Types, Path::Class
SUPPORT
Bugs may be submitted through the RT bug tracker (or bug-MooseX-Types-Path-Class@rt.cpan.org).
There is also a mailing list available for users of this distribution, at http://lists.perl.org/list/moose.html.
There is also an irc channel available for users of this distribution, at #moose
on irc.perl.org
.
AUTHOR
Todd Hepler <thepler@employees.org>
CONTRIBUTORS
Karen Etheridge <ether@cpan.org>
Jonathan Rockway <jon@jrock.us>
Yuval Kogman <nothingmuch@woobling.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2007 by Todd Hepler.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.