← Index
NYTProf Performance Profile   « line view »
For examples/Atom-timer.pl
  Run on Mon Aug 12 14:45:28 2013
Reported on Mon Aug 12 14:46:15 2013

Filename/Users/dde/perl5/perlbrew/perls/5.18.0t/lib/site_perl/5.18.0/darwin-thread-multi-2level/Moose/Meta/Attribute/Native.pm
StatementsExecuted 38 statements in 230µs
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
1118µs8µsMoose::Meta::Attribute::Native::::BEGIN@2Moose::Meta::Attribute::Native::BEGIN@2
1116µs26µsMoose::Meta::Attribute::Native::::BEGIN@9Moose::Meta::Attribute::Native::BEGIN@9
0000s0sMoose::Meta::Attribute::Native::::__ANON__[:30]Moose::Meta::Attribute::Native::__ANON__[:30]
Call graph for these subroutines as a Graphviz dot language file.
Line State
ments
Time
on line
Calls Time
in subs
Code
1package Moose::Meta::Attribute::Native;
2
# spent 8µs within Moose::Meta::Attribute::Native::BEGIN@2 which was called: # once (8µs+0s) by Moose::BEGIN@46 at line 4
BEGIN {
314µs $Moose::Meta::Attribute::Native::AUTHORITY = 'cpan:STEVAN';
4128µs18µs}
# spent 8µs making 1 call to Moose::Meta::Attribute::Native::BEGIN@2
5{
62900ns $Moose::Meta::Attribute::Native::VERSION = '2.1005';
7}
8
92142µs245µs
# spent 26µs (6+20) within Moose::Meta::Attribute::Native::BEGIN@9 which was called: # once (6µs+20µs) by Moose::BEGIN@46 at line 9
use Class::Load qw(load_class);
# spent 26µs making 1 call to Moose::Meta::Attribute::Native::BEGIN@9 # spent 20µs making 1 call to Exporter::import
10
1111µsmy @trait_names = qw(Bool Counter Number String Array Hash Code);
12
131400nsfor my $trait_name (@trait_names) {
1473µs my $trait_class = "Moose::Meta::Attribute::Native::Trait::$trait_name";
1578µs7355µs my $meta = Class::MOP::Class->initialize(
# spent 355µs making 7 calls to Class::MOP::Class::initialize, avg 51µs/call
16 "Moose::Meta::Attribute::Custom::Trait::$trait_name"
17 );
1876µs7387µs if ($meta->find_method_by_name('register_implementation')) {
# spent 387µs making 7 calls to Class::MOP::Class::find_method_by_name, avg 55µ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
2811µs112.5ms load_class($trait_class);
# spent 12.5ms making 1 call to Class::Load::load_class
2913µs return $trait_class;
30724µs7281µs });
# spent 281µs making 7 calls to Class::MOP::Mixin::HasMethods::add_method, avg 40µs/call
31}
32
3319µs1;
34
35# ABSTRACT: Delegate to native Perl types
36
37__END__