Filename | /home/ss5/perl5/perlbrew/perls/perl-5.22.0/lib/site_perl/5.22.0/Class/Accessor/Fast.pm |
Statements | Executed 26 statements in 190µs |
Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
---|---|---|---|---|---|
10 | 1 | 1 | 14µs | 14µs | make_accessor | Class::Accessor::Fast::
1 | 1 | 1 | 7µs | 852µs | BEGIN@2 | Class::Accessor::Fast::
1 | 1 | 1 | 5µs | 6µs | BEGIN@3 | Class::Accessor::Fast::
0 | 0 | 0 | 0s | 0s | __ANON__[:12] | Class::Accessor::Fast::
0 | 0 | 0 | 0s | 0s | __ANON__[:23] | Class::Accessor::Fast::
0 | 0 | 0 | 0s | 0s | __ANON__[:39] | Class::Accessor::Fast::
0 | 0 | 0 | 0s | 0s | make_ro_accessor | Class::Accessor::Fast::
0 | 0 | 0 | 0s | 0s | make_wo_accessor | Class::Accessor::Fast::
0 | 0 | 0 | 0s | 0s | _current_statement | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | _custom_delimiter | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | _terminators | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | _tokens | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | _tokens_in_custom_delimiter | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | keep_comments | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | keep_empty_statements | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | keep_extra_spaces | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | keep_terminators | SQL::SplitStatement::
0 | 0 | 0 | 0s | 0s | slash_terminates | SQL::SplitStatement::
Line | State ments |
Time on line |
Calls | Time in subs |
Code |
---|---|---|---|---|---|
1 | package Class::Accessor::Fast; | ||||
2 | 2 | 20µs | 2 | 852µs | # spent 852µs (7+845) within Class::Accessor::Fast::BEGIN@2 which was called:
# once (7µs+845µs) by base::import at line 2 # spent 852µs making 1 call to Class::Accessor::Fast::BEGIN@2
# spent 845µs making 1 call to base::import, recursion: max depth 1, sum of overlapping time 845µs |
3 | 2 | 147µs | 2 | 8µs | # spent 6µs (5+2) within Class::Accessor::Fast::BEGIN@3 which was called:
# once (5µs+2µs) by base::import at line 3 # spent 6µs making 1 call to Class::Accessor::Fast::BEGIN@3
# spent 2µs making 1 call to strict::import |
4 | 1 | 300ns | $Class::Accessor::Fast::VERSION = '0.34'; | ||
5 | |||||
6 | # spent 14µs within Class::Accessor::Fast::make_accessor which was called 10 times, avg 1µs/call:
# 10 times (14µs+0s) by Class::Accessor::_mk_accessors at line 72 of Class/Accessor.pm, avg 1µs/call | ||||
7 | 10 | 1µs | my($class, $field) = @_; | ||
8 | |||||
9 | return sub { | ||||
10 | return $_[0]->{$field} if scalar(@_) == 1; | ||||
11 | return $_[0]->{$field} = scalar(@_) == 2 ? $_[1] : [@_[1..$#_]]; | ||||
12 | 10 | 19µs | }; | ||
13 | } | ||||
14 | |||||
15 | |||||
16 | sub make_ro_accessor { | ||||
17 | my($class, $field) = @_; | ||||
18 | |||||
19 | return sub { | ||||
20 | return $_[0]->{$field} if @_ == 1; | ||||
21 | my $caller = caller; | ||||
22 | $_[0]->_croak("'$caller' cannot alter the value of '$field' on objects of class '$class'"); | ||||
23 | }; | ||||
24 | } | ||||
25 | |||||
26 | |||||
27 | sub make_wo_accessor { | ||||
28 | my($class, $field) = @_; | ||||
29 | |||||
30 | return sub { | ||||
31 | if (@_ == 1) { | ||||
32 | my $caller = caller; | ||||
33 | $_[0]->_croak("'$caller' cannot access the value of '$field' on objects of class '$class'"); | ||||
34 | } | ||||
35 | else { | ||||
36 | return $_[0]->{$field} = $_[1] if @_ == 2; | ||||
37 | return (shift)->{$field} = \@_; | ||||
38 | } | ||||
39 | }; | ||||
40 | } | ||||
41 | |||||
42 | |||||
43 | 1 | 2µs | 1; | ||
44 | |||||
45 | __END__ |