use Scalar::Util directly
[gitmo/Mouse.git] / lib / Mouse / Role.pm
CommitLineData
f9e68395 1#!/usr/bin/env perl
2package Mouse::Role;
3use strict;
4use warnings;
b32e8fb9 5use base 'Exporter';
f9e68395 6
8da998d9 7use Carp 'confess';
6c169c50 8use Scalar::Util 'blessed';
f9e68395 9
a2227e71 10use Mouse::Meta::Role;
11
b32e8fb9 12our @EXPORT = qw(before after around has extends with requires excludes confess blessed);
13
14sub before {
15 my $meta = Mouse::Meta::Role->initialize(caller);
16
17 my $code = pop;
18 for (@_) {
19 $meta->add_before_method_modifier($_ => $code);
20 }
21}
22
23sub after {
24 my $meta = Mouse::Meta::Role->initialize(caller);
25
26 my $code = pop;
27 for (@_) {
28 $meta->add_after_method_modifier($_ => $code);
f9e68395 29 }
b32e8fb9 30}
31
32sub around {
33 my $meta = Mouse::Meta::Role->initialize(caller);
34
35 my $code = pop;
36 for (@_) {
37 $meta->add_around_method_modifier($_ => $code);
38 }
39}
40
41sub has {
42 my $meta = Mouse::Meta::Role->initialize(caller);
43
44 my $name = shift;
45 my %opts = @_;
46
47 $meta->add_attribute($name => \%opts);
48}
49
50sub extends { confess "Roles do not support 'extends'" }
51
b1b81553 52sub with {
53 my $meta = Mouse::Meta::Role->initialize(caller);
54 my $role = shift;
4aaa2ed6 55 my $args = shift || {};
56 confess "Mouse::Role only supports 'with' on individual roles at a time" if @_ || !ref $args;
b1b81553 57
58 Mouse::load_class($role);
4aaa2ed6 59 $role->meta->apply($meta, %$args);
b1b81553 60}
b32e8fb9 61
59089ec3 62sub requires {
63 my $meta = Mouse::Meta::Role->initialize(caller);
64 Carp::croak "Must specify at least one method" unless @_;
65 $meta->add_required_methods(@_);
66}
b32e8fb9 67
2badb84a 68sub excludes { confess "Mouse::Role does not currently support 'excludes'" }
b32e8fb9 69
70sub import {
71 strict->import;
72 warnings->import;
73
74 my $caller = caller;
75 my $meta = Mouse::Meta::Role->initialize(caller);
76
77 no strict 'refs';
78 no warnings 'redefine';
79 *{$caller.'::meta'} = sub { $meta };
80
81 Mouse::Role->export_to_level(1, @_);
82}
f9e68395 83
b32e8fb9 84sub unimport {
85 my $caller = caller;
e71d8033 86
b32e8fb9 87 no strict 'refs';
88 for my $keyword (@EXPORT) {
89 delete ${ $caller . '::' }{$keyword};
f9e68395 90 }
b32e8fb9 91}
f9e68395 92
931;
94
cadd5b5e 95__END__
96
97=head1 NAME
98
99Mouse::Role
100
101=head1 KEYWORDS
102
103=head2 meta -> Mouse::Meta::Role
104
105Returns this role's metaclass instance.
106
107=head2 before (method|methods) => Code
108
109Sets up a "before" method modifier. See L<Moose/before> or
110L<Class::Method::Modifiers/before>.
111
112=head2 after (method|methods) => Code
113
114Sets up an "after" method modifier. See L<Moose/after> or
115L<Class::Method::Modifiers/after>.
116
117=head2 around (method|methods) => Code
118
119Sets up an "around" method modifier. See L<Moose/around> or
120L<Class::Method::Modifiers/around>.
121
122=head2 has (name|names) => parameters
123
124Sets up an attribute (or if passed an arrayref of names, multiple attributes) to
125this role. See L<Mouse/has>.
126
127=head2 confess error -> BOOM
128
129L<Carp/confess> for your convenience.
130
131=head2 blessed value -> ClassName | undef
132
133L<Scalar::Util/blessed> for your convenience.
134
135=head1 MISC
136
137=head2 import
138
139Importing Mouse::Role will give you sugar.
140
141=head2 unimport
142
143Please unimport Mouse (C<no Mouse::Role>) so that if someone calls one of the
144keywords (such as L</has>) it will break loudly instead breaking subtly.
145
146=cut
147