release
[gitmo/MooseX-AlwaysCoerce.git] / lib / MooseX / AlwaysCoerce.pm
CommitLineData
7a603ffa 1package MooseX::AlwaysCoerce;
2
3use strict;
4use warnings;
5
ad1917d7 6use namespace::autoclean;
7use Moose ();
2429fb7e 8use MooseX::ClassAttribute ();
ad1917d7 9use Moose::Exporter;
2429fb7e 10use Moose::Util::MetaRole;
ad1917d7 11use Carp;
12
2429fb7e 13Moose::Exporter->setup_import_methods;
ad1917d7 14
7a603ffa 15=head1 NAME
16
17MooseX::AlwaysCoerce - Automatically enable coercions for Moose attributes
18
19=head1 VERSION
20
68bf8463 21Version 0.03
7a603ffa 22
23=cut
24
68bf8463 25our $VERSION = '0.03';
7a603ffa 26
27=head1 SYNOPSIS
28
29 package MyClass;
30
31 use Moose;
32 use MooseX::AlwaysCoerce;
33 use MyTypeLib 'SomeType';
34
ad1917d7 35 has foo => (is => 'rw', isa => SomeType); # coerce => 1 automatically added
36
2429fb7e 37 # same, MooseX::ClassAttribute is automatically applied
ad1917d7 38 class_has bar => (is => 'rw', isa => SomeType);
39
40=head1 DESCRIPTION
41
42Have you ever spent an hour or more trying to figure out "WTF, why did my
43coercion not run?" only to find out that you forgot C<< coerce => 1 >> ?
44
45Just load this module in your L<Moose> class and C<< coerce => 1 >> will be
2429fb7e 46enabled for every attribute and class attribute automatically.
ad1917d7 47
44b44091 48Use C<< coerce => 0 >> to disable a coercion explicitly.
49
ad1917d7 50=cut
51
2429fb7e 52{
53 package MooseX::AlwaysCoerce::Role::Meta::Attribute;
54 use namespace::autoclean;
55 use Moose::Role;
56
57 has coerce => (is => 'rw', default => 1);
58
59 package MooseX::AlwaysCoerce::Role::Meta::Class;
60 use namespace::autoclean;
61 use Moose::Role;
62
63 around add_class_attribute => sub {
64 my $next = shift;
65 my $self = shift;
44b44091 66 my ($what, %opts) = @_;
67
68 $opts{coerce} = 1 unless exists $opts{coerce};
69
70 $self->$next($what, %opts);
2429fb7e 71 };
ad1917d7 72}
73
2429fb7e 74sub init_meta {
75 shift;
76 my %options = @_;
77 my $for_class = $options{for_class};
78
79 MooseX::ClassAttribute->import({ into => $for_class });
80
81 Moose::Util::MetaRole::apply_metaclass_roles(
82 for_class => $for_class,
83 attribute_metaclass_roles =>
84 ['MooseX::AlwaysCoerce::Role::Meta::Attribute'],
85 metaclass_roles =>
86 ['MooseX::AlwaysCoerce::Role::Meta::Class'],
87 );
88
89 return $for_class->meta;
ad1917d7 90}
7a603ffa 91
92=head1 AUTHOR
93
94Rafael Kitover, C<< <rkitover at cpan.org> >>
95
96=head1 BUGS
97
98Please report any bugs or feature requests to C<bug-moosex-alwayscoerce at rt.cpan.org>, or through
99the web interface at L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=MooseX-AlwaysCoerce>. I will be notified, and then you'll
100automatically be notified of progress on your bug as I make changes.
101
102=head1 SUPPORT
103
104You can find more information at:
105
106=over 4
107
108=item * RT: CPAN's request tracker
109
110L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=MooseX-AlwaysCoerce>
111
112=item * AnnoCPAN: Annotated CPAN documentation
113
114L<http://annocpan.org/dist/MooseX-AlwaysCoerce>
115
116=item * CPAN Ratings
117
118L<http://cpanratings.perl.org/d/MooseX-AlwaysCoerce>
119
120=item * Search CPAN
121
122L<http://search.cpan.org/dist/MooseX-AlwaysCoerce/>
123
124=back
125
126=head1 ACKNOWLEDGEMENTS
127
128My own stupidity, for inspiring me to write this module.
129
2429fb7e 130Dave Rolsky, for telling me how to do it the L<Moose> way.
131
7a603ffa 132=head1 COPYRIGHT & LICENSE
133
134Copyright (c) 2009 Rafael Kitover
135
136This program is free software; you can redistribute it and/or modify it
137under the same terms as Perl itself.
138
139=cut
140
1411; # End of MooseX::AlwaysCoerce