blob: 00db707a32b5d7b776712154a0115e9716c8c281 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
package Bot::Games::Trait::Attribute::Formatted;
use Bot::Games::OO::Role;
# when the attribute is being constructed, the accessor methods haven't been
# generated yet, so we need to store the formatter here, and then apply it
# after the accessor methods exist
has formatter => (
is => 'rw',
isa => 'CodeRef',
predicate => 'has_formatter',
);
before _process_options => sub {
my $self = shift;
my ($name, $options) = @_;
warn "only commands will have a formatter applied"
if exists($options->{formatter}) && !$options->{command};
};
after attach_to_class => sub {
my $self = shift;
my ($meta) = @_;
return if $self->has_formatter;
return unless $self->command;
return unless $self->has_type_constraint;
my $tc = $self->type_constraint;
for my $tc_name ($meta->formattable_tcs) {
if ($tc->is_a_type_of($tc_name)) {
$self->formatter($meta->formatter_for($tc_name));
return;
}
}
};
around accessor_metaclass => sub {
my $orig = shift;
my $self = shift;
my $metaclass = $self->$orig(@_);
return $metaclass unless $self->has_formatter;
return Moose::Meta::Class->create_anon_class(
superclasses => [$metaclass],
roles => ['Bot::Games::Trait::Method::Formatted'],
cache => 1,
)->name;
};
after install_accessors => sub {
my $self = shift;
if ($self->has_formatter) {
my $formatter = $self->formatter;
my $method_meta = $self->get_read_method_ref;
$method_meta->formatter($formatter);
}
};
no Bot::Games::OO::Role;
1;
|