Filename | /opt/perl-5.18.1/lib/site_perl/5.18.1/darwin-thread-multi-2level/Moose/Meta/Attribute/Native.pm |
Statements | Executed 36 statements in 329µs |
Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
---|---|---|---|---|---|
1 | 1 | 1 | 11µs | 11µs | BEGIN@2 | Moose::Meta::Attribute::Native::
1 | 1 | 1 | 9µs | 39µs | BEGIN@9 | Moose::Meta::Attribute::Native::
0 | 0 | 0 | 0s | 0s | __ANON__[:30] | Moose::Meta::Attribute::Native::
Line | State ments |
Time on line |
Calls | Time in subs |
Code |
---|---|---|---|---|---|
1 | package Moose::Meta::Attribute::Native; | ||||
2 | # spent 11µs within Moose::Meta::Attribute::Native::BEGIN@2 which was called:
# once (11µs+0s) by Moose::BEGIN@46 at line 4 | ||||
3 | 1 | 7µs | $Moose::Meta::Attribute::Native::AUTHORITY = 'cpan:STEVAN'; | ||
4 | 1 | 42µs | 1 | 11µs | } # spent 11µs making 1 call to Moose::Meta::Attribute::Native::BEGIN@2 |
5 | { | ||||
6 | 2 | 1µs | $Moose::Meta::Attribute::Native::VERSION = '2.1005'; | ||
7 | } | ||||
8 | |||||
9 | 2 | 195µs | 2 | 68µs | # spent 39µs (9+30) within Moose::Meta::Attribute::Native::BEGIN@9 which was called:
# once (9µs+30µs) by Moose::BEGIN@46 at line 9 # spent 39µs making 1 call to Moose::Meta::Attribute::Native::BEGIN@9
# spent 30µs making 1 call to Exporter::import |
10 | |||||
11 | 1 | 2µs | my @trait_names = qw(Bool Counter Number String Array Hash Code); | ||
12 | |||||
13 | 1 | 700ns | for my $trait_name (@trait_names) { | ||
14 | 7 | 5µs | my $trait_class = "Moose::Meta::Attribute::Native::Trait::$trait_name"; | ||
15 | 7 | 13µs | 7 | 552µs | my $meta = Class::MOP::Class->initialize( # spent 552µs making 7 calls to Class::MOP::Class::initialize, avg 79µs/call |
16 | "Moose::Meta::Attribute::Custom::Trait::$trait_name" | ||||
17 | ); | ||||
18 | 7 | 9µs | 7 | 614µs | if ($meta->find_method_by_name('register_implementation')) { # spent 614µs making 7 calls to Class::MOP::Class::find_method_by_name, avg 88µs/call |
19 | my $class = $meta->name->register_implementation; | ||||
20 | Moose->throw_error( | ||||
21 | "An implementation for $trait_name already exists " . | ||||
22 | "(found '$class' when trying to register '$trait_class')" | ||||
23 | ); | ||||
24 | } | ||||
25 | $meta->add_method(register_implementation => sub { | ||||
26 | # resolve_metatrait_alias will load classes anyway, but throws away | ||||
27 | # their error message; we WANT to die if there's a problem | ||||
28 | load_class($trait_class); | ||||
29 | return $trait_class; | ||||
30 | 7 | 41µs | 7 | 422µs | }); # spent 422µs making 7 calls to Class::MOP::Mixin::HasMethods::add_method, avg 60µs/call |
31 | } | ||||
32 | |||||
33 | 1 | 14µs | 1; | ||
34 | |||||
35 | # ABSTRACT: Delegate to native Perl types | ||||
36 | |||||
37 | __END__ |