| 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 | Class::Accessor::Fast::make_accessor |
| 1 | 1 | 1 | 7µs | 852µs | Class::Accessor::Fast::BEGIN@2 |
| 1 | 1 | 1 | 5µs | 6µs | Class::Accessor::Fast::BEGIN@3 |
| 0 | 0 | 0 | 0s | 0s | Class::Accessor::Fast::__ANON__[:12] |
| 0 | 0 | 0 | 0s | 0s | Class::Accessor::Fast::__ANON__[:23] |
| 0 | 0 | 0 | 0s | 0s | Class::Accessor::Fast::__ANON__[:39] |
| 0 | 0 | 0 | 0s | 0s | Class::Accessor::Fast::make_ro_accessor |
| 0 | 0 | 0 | 0s | 0s | Class::Accessor::Fast::make_wo_accessor |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::_current_statement |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::_custom_delimiter |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::_terminators |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::_tokens |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::_tokens_in_custom_delimiter |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::keep_comments |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::keep_empty_statements |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::keep_extra_spaces |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::keep_terminators |
| 0 | 0 | 0 | 0s | 0s | SQL::SplitStatement::slash_terminates |
| 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__ |