← 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:14 2013

Filename/Users/dde/perl5/perlbrew/perls/5.18.0t/lib/site_perl/5.18.0/darwin-thread-multi-2level/Moose/Meta/TypeConstraint/Enum.pm
StatementsExecuted 20 statements in 686µs
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
11115µs398µsMoose::Meta::TypeConstraint::Enum::::BEGIN@11Moose::Meta::TypeConstraint::Enum::BEGIN@11
11112µs12µsMoose::Meta::TypeConstraint::Enum::::BEGIN@14Moose::Meta::TypeConstraint::Enum::BEGIN@14
1118µs8µsMoose::Meta::TypeConstraint::Enum::::BEGIN@2Moose::Meta::TypeConstraint::Enum::BEGIN@2
1117µs20µsMoose::Meta::TypeConstraint::Enum::::BEGIN@13Moose::Meta::TypeConstraint::Enum::BEGIN@13
1116µs25µsMoose::Meta::TypeConstraint::Enum::::BEGIN@9Moose::Meta::TypeConstraint::Enum::BEGIN@9
1116µs9µsMoose::Meta::TypeConstraint::Enum::::BEGIN@10Moose::Meta::TypeConstraint::Enum::BEGIN@10
1116µs58µsMoose::Meta::TypeConstraint::Enum::::BEGIN@16Moose::Meta::TypeConstraint::Enum::BEGIN@16
0000s0sMoose::Meta::TypeConstraint::Enum::::__ANON__[:103]Moose::Meta::TypeConstraint::Enum::__ANON__[:103]
0000s0sMoose::Meta::TypeConstraint::Enum::::__ANON__[:35]Moose::Meta::TypeConstraint::Enum::__ANON__[:35]
0000s0sMoose::Meta::TypeConstraint::Enum::::__ANON__[:62]Moose::Meta::TypeConstraint::Enum::__ANON__[:62]
0000s0sMoose::Meta::TypeConstraint::Enum::::constraintMoose::Meta::TypeConstraint::Enum::constraint
0000s0sMoose::Meta::TypeConstraint::Enum::::create_child_typeMoose::Meta::TypeConstraint::Enum::create_child_type
0000s0sMoose::Meta::TypeConstraint::Enum::::equalsMoose::Meta::TypeConstraint::Enum::equals
0000s0sMoose::Meta::TypeConstraint::Enum::::newMoose::Meta::TypeConstraint::Enum::new
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::TypeConstraint::Enum;
2
# spent 8µs within Moose::Meta::TypeConstraint::Enum::BEGIN@2 which was called: # once (8µs+0s) by Moose::Util::TypeConstraints::BEGIN@38 at line 4
BEGIN {
314µs $Moose::Meta::TypeConstraint::Enum::AUTHORITY = 'cpan:STEVAN';
4127µs18µs}
# spent 8µs making 1 call to Moose::Meta::TypeConstraint::Enum::BEGIN@2
5{
62800ns $Moose::Meta::TypeConstraint::Enum::VERSION = '2.1005';
7}
8
9220µs245µs
# spent 25µs (6+19) within Moose::Meta::TypeConstraint::Enum::BEGIN@9 which was called: # once (6µs+19µs) by Moose::Util::TypeConstraints::BEGIN@38 at line 9
use strict;
# spent 25µs making 1 call to Moose::Meta::TypeConstraint::Enum::BEGIN@9 # spent 19µs making 1 call to strict::import
10231µs212µs
# spent 9µs (6+3) within Moose::Meta::TypeConstraint::Enum::BEGIN@10 which was called: # once (6µs+3µs) by Moose::Util::TypeConstraints::BEGIN@38 at line 10
use warnings;
# spent 9µs making 1 call to Moose::Meta::TypeConstraint::Enum::BEGIN@10 # spent 3µs making 1 call to warnings::import
11225µs2781µs
# spent 398µs (15+383) within Moose::Meta::TypeConstraint::Enum::BEGIN@11 which was called: # once (15µs+383µs) by Moose::Util::TypeConstraints::BEGIN@38 at line 11
use metaclass;
# spent 398µs making 1 call to Moose::Meta::TypeConstraint::Enum::BEGIN@11 # spent 383µs making 1 call to metaclass::import
12
13220µs232µs
# spent 20µs (7+13) within Moose::Meta::TypeConstraint::Enum::BEGIN@13 which was called: # once (7µs+13µs) by Moose::Util::TypeConstraints::BEGIN@38 at line 13
use B;
# spent 20µs making 1 call to Moose::Meta::TypeConstraint::Enum::BEGIN@13 # spent 13µs making 1 call to Exporter::import
14240µs112µs
# spent 12µs within Moose::Meta::TypeConstraint::Enum::BEGIN@14 which was called: # once (12µs+0s) by Moose::Util::TypeConstraints::BEGIN@38 at line 14
use Moose::Util::TypeConstraints ();
# spent 12µs making 1 call to Moose::Meta::TypeConstraint::Enum::BEGIN@14
15
162504µs2110µs
# spent 58µs (6+52) within Moose::Meta::TypeConstraint::Enum::BEGIN@16 which was called: # once (6µs+52µs) by Moose::Util::TypeConstraints::BEGIN@38 at line 16
use base 'Moose::Meta::TypeConstraint';
# spent 58µs making 1 call to Moose::Meta::TypeConstraint::Enum::BEGIN@16 # spent 52µs making 1 call to base::import
17
1813µs3292µs__PACKAGE__->meta->add_attribute('values' => (
# spent 274µs making 1 call to Class::MOP::Mixin::HasAttributes::add_attribute # spent 14µs making 1 call to Moose::Meta::TypeConstraint::Enum::meta # spent 5µs making 1 call to Class::MOP::_definition_context
19 accessor => 'values',
20 Class::MOP::_definition_context(),
21));
22
2313µs3268µs__PACKAGE__->meta->add_attribute('_inline_var_name' => (
# spent 255µs making 1 call to Class::MOP::Mixin::HasAttributes::add_attribute # spent 9µs making 1 call to Moose::Meta::TypeConstraint::Enum::meta # spent 5µs making 1 call to Class::MOP::_definition_context
24 accessor => '_inline_var_name',
25 Class::MOP::_definition_context(),
26));
27
28my $inliner = sub {
29 my $self = shift;
30 my $val = shift;
31
32 return 'defined(' . $val . ') '
33 . '&& !ref(' . $val . ') '
34 . '&& $' . $self->_inline_var_name . '{' . $val . '}';
3512µs};
36
371100nsmy $var_suffix = 0;
38
39sub new {
40 my ( $class, %args ) = @_;
41
42 $args{parent} = Moose::Util::TypeConstraints::find_type_constraint('Str');
43 $args{inlined} = $inliner;
44
45 if ( scalar @{ $args{values} } < 1 ) {
46 require Moose;
47 Moose->throw_error("You must have at least one value to enumerate through");
48 }
49
50 for (@{ $args{values} }) {
51 if (!defined($_)) {
52 require Moose;
53 Moose->throw_error("Enum values must be strings, not undef");
54 }
55 elsif (ref($_)) {
56 require Moose;
57 Moose->throw_error("Enum values must be strings, not '$_'");
58 }
59 }
60
61 my %values = map { $_ => 1 } @{ $args{values} };
62 $args{constraint} = sub { $values{ $_[0] } };
63
64 my $var_name = 'enums' . $var_suffix++;;
65 $args{_inline_var_name} = $var_name;
66 $args{inline_environment} = { '%' . $var_name => \%values };
67
68 my $self = $class->SUPER::new(\%args);
69
70 $self->compile_type_constraint()
71 unless $self->_has_compiled_type_constraint;
72
73 return $self;
74}
75
76sub equals {
77 my ( $self, $type_or_name ) = @_;
78
79 my $other = Moose::Util::TypeConstraints::find_type_constraint($type_or_name);
80
81 return unless $other->isa(__PACKAGE__);
82
83 my @self_values = sort @{ $self->values };
84 my @other_values = sort @{ $other->values };
85
86 return unless @self_values == @other_values;
87
88 while ( @self_values ) {
89 my $value = shift @self_values;
90 my $other_value = shift @other_values;
91
92 return unless $value eq $other_value;
93 }
94
95 return 1;
96}
97
98sub constraint {
99 my $self = shift;
100
101 my %values = map { $_ => undef } @{ $self->values };
102
103 return sub { exists $values{$_[0]} };
104}
105
106sub create_child_type {
107 my ($self, @args) = @_;
108 return Moose::Meta::TypeConstraint->new(@args, parent => $self);
109}
110
11116µs1;
112
113# ABSTRACT: Type constraint for enumerated values.
114
115__END__