← Index
NYTProf Performance Profile   « line view »
For starman worker -M FindBin --max-requests 50 --workers 2 --user=kohadev-koha --group kohadev-koha --pid /var/run/koha/kohadev/plack.pid --daemonize --access-log /var/log/koha/kohadev/plack.log --error-log /var/log/koha/kohadev/plack-error.log -E deployment --socket /var/run/koha/kohadev/plack.sock /etc/koha/sites/kohadev/plack.psgi
  Run on Fri Jan 8 14:31:06 2016
Reported on Fri Jan 8 14:31:36 2016

Filename/usr/lib/x86_64-linux-gnu/perl5/5.20/Class/XSAccessor.pm
StatementsExecuted 2189 statements in 3.67ms
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
32221.44ms2.28msClass::XSAccessor::::importClass::XSAccessor::import
111405µs510µsClass::XSAccessor::::BEGIN@6Class::XSAccessor::BEGIN@6
3211297µs592µsClass::XSAccessor::::_generate_methodClass::XSAccessor::_generate_method
25681251µs251µsClass::XSAccessor::::_make_hashClass::XSAccessor::_make_hash
2811235µs235µsClass::XSAccessor::::newxs_accessorClass::XSAccessor::newxs_accessor (xsub)
321138µs38µsClass::XSAccessor::::CORE:matchClass::XSAccessor::CORE:match (opcode)
41122µs22µsClass::XSAccessor::::newxs_getterClass::XSAccessor::newxs_getter (xsub)
11122µs22µsClass::XSAccessor::::BEGIN@2Class::XSAccessor::BEGIN@2
1119µs20µsClass::XSAccessor::::BEGIN@84Class::XSAccessor::BEGIN@84
1119µs39µsClass::XSAccessor::::BEGIN@5Class::XSAccessor::BEGIN@5
1118µs16µsClass::XSAccessor::::BEGIN@3Class::XSAccessor::BEGIN@3
1116µs12µsClass::XSAccessor::::BEGIN@4Class::XSAccessor::BEGIN@4
1116µs6µsClass::XSAccessor::::BEGIN@7Class::XSAccessor::BEGIN@7
Call graph for these subroutines as a Graphviz dot language file.
Line State
ments
Time
on line
Calls Time
in subs
Code
1package Class::XSAccessor;
2253µs122µs
# spent 22µs within Class::XSAccessor::BEGIN@2 which was called: # once (22µs+0s) by Module::Runtime::require_module at line 2
use 5.008;
# spent 22µs making 1 call to Class::XSAccessor::BEGIN@2
3232µs223µs
# spent 16µs (8+8) within Class::XSAccessor::BEGIN@3 which was called: # once (8µs+8µs) by Module::Runtime::require_module at line 3
use strict;
# spent 16µs making 1 call to Class::XSAccessor::BEGIN@3 # spent 8µs making 1 call to strict::import
4234µs216µs
# spent 12µs (6+5) within Class::XSAccessor::BEGIN@4 which was called: # once (6µs+5µs) by Module::Runtime::require_module at line 4
use warnings;
# spent 12µs making 1 call to Class::XSAccessor::BEGIN@4 # spent 5µs making 1 call to warnings::import
5257µs270µs
# spent 39µs (9+30) within Class::XSAccessor::BEGIN@5 which was called: # once (9µs+30µs) by Module::Runtime::require_module at line 5
use Carp qw/croak/;
# spent 39µs making 1 call to Class::XSAccessor::BEGIN@5 # spent 30µs making 1 call to Exporter::import
62134µs1510µs
# spent 510µs (405+105) within Class::XSAccessor::BEGIN@6 which was called: # once (405µs+105µs) by Module::Runtime::require_module at line 6
use Class::XSAccessor::Heavy;
# spent 510µs making 1 call to Class::XSAccessor::BEGIN@6
72514µs16µs
# spent 6µs within Class::XSAccessor::BEGIN@7 which was called: # once (6µs+0s) by Module::Runtime::require_module at line 7
use XSLoader;
# spent 6µs making 1 call to Class::XSAccessor::BEGIN@7
8
91400nsour $VERSION = '1.19';
10
111302µs1293µsXSLoader::load('Class::XSAccessor', $VERSION);
# spent 293µs making 1 call to XSLoader::load
12
13
# spent 251µs within Class::XSAccessor::_make_hash which was called 256 times, avg 979ns/call: # 32 times (70µs+0s) by Class::XSAccessor::import at line 37, avg 2µs/call # 32 times (30µs+0s) by Class::XSAccessor::import at line 38, avg 931ns/call # 32 times (26µs+0s) by Class::XSAccessor::import at line 39, avg 825ns/call # 32 times (26µs+0s) by Class::XSAccessor::import at line 43, avg 816ns/call # 32 times (26µs+0s) by Class::XSAccessor::import at line 40, avg 800ns/call # 32 times (25µs+0s) by Class::XSAccessor::import at line 41, avg 778ns/call # 32 times (24µs+0s) by Class::XSAccessor::import at line 44, avg 759ns/call # 32 times (24µs+0s) by Class::XSAccessor::import at line 42, avg 753ns/call
sub _make_hash {
1425633µs my $ref = shift;
15
1625673µs if (ref ($ref)) {
17 if (ref($ref) eq 'ARRAY') {
18 $ref = { map { $_ => $_ } @$ref }
19 }
20 } else {
21 $ref = { $ref, $ref };
22 }
23
24256373µs return $ref;
25}
26
27
# spent 2.28ms (1.44+843µs) within Class::XSAccessor::import which was called 32 times, avg 71µs/call: # 28 times (1.26ms+753µs) by DBIx::Class::ResultSet::_result_class or DBIx::Class::ResultSet::result_source or DBIx::Class::ResultSource::_columns or DBIx::Class::ResultSource::_ordered_columns or DBIx::Class::ResultSource::_primaries or DBIx::Class::ResultSource::_relationships or DBIx::Class::ResultSource::_unique_constraints or DBIx::Class::ResultSource::name or DBIx::Class::ResultSource::source_name or DBIx::Class::Row::in_storage or DBIx::Class::SQLMaker::name_sep or DBIx::Class::Storage::DBI::Cursor::storage or DBIx::Class::Storage::DBI::_conn_pid or DBIx::Class::Storage::DBI::_connect_info or DBIx::Class::Storage::DBI::_dbh or DBIx::Class::Storage::DBI::_dbh_autocommit or DBIx::Class::Storage::DBI::_dbh_details or DBIx::Class::Storage::DBI::_dbic_connect_attributes or DBIx::Class::Storage::DBI::_driver_determined or DBIx::Class::Storage::DBI::_sql_maker or DBIx::Class::Storage::DBI::_sql_maker_opts or DBIx::Class::Storage::DBI::disable_sth_caching or DBIx::Class::Storage::DBI::on_connect_call or DBIx::Class::Storage::DBI::on_connect_do or DBIx::Class::Storage::DBI::unsafe or DBIx::Class::Storage::debug or DBIx::Class::Storage::schema or DBIx::Class::Storage::transaction_depth at line 830 of Class/Accessor/Grouped.pm, avg 72µs/call # 4 times (175µs+90µs) by Method::Generate::Accessor::_generate_xs at line 641 of Method/Generate/Accessor.pm, avg 66µs/call
sub import {
283214µs my $own_class = shift;
293240µs my ($caller_pkg) = caller();
30
31 # Support both { getters => ... } and plain getters => ...
323272µs my %opts = ref($_[0]) eq 'HASH' ? %{$_[0]} : @_;
33
343226µs $caller_pkg = $opts{class} if defined $opts{class};
35
36 # TODO: Refactor. Move more duplicated code to ::Heavy
373255µs3270µs my $read_subs = _make_hash($opts{getters} || {});
# spent 70µs making 32 calls to Class::XSAccessor::_make_hash, avg 2µs/call
383238µs3230µs my $set_subs = _make_hash($opts{setters} || {});
# spent 30µs making 32 calls to Class::XSAccessor::_make_hash, avg 931ns/call
393232µs3226µs my $acc_subs = _make_hash($opts{accessors} || {});
# spent 26µs making 32 calls to Class::XSAccessor::_make_hash, avg 825ns/call
403233µs3226µs my $lvacc_subs = _make_hash($opts{lvalue_accessors} || {});
# spent 26µs making 32 calls to Class::XSAccessor::_make_hash, avg 800ns/call
413233µs3225µs my $pred_subs = _make_hash($opts{predicates} || {});
# spent 25µs making 32 calls to Class::XSAccessor::_make_hash, avg 778ns/call
423229µs3224µs my $ex_pred_subs = _make_hash($opts{exists_predicates} || {});
# spent 24µs making 32 calls to Class::XSAccessor::_make_hash, avg 753ns/call
433230µs3226µs my $def_pred_subs = _make_hash($opts{defined_predicates} || {});
# spent 26µs making 32 calls to Class::XSAccessor::_make_hash, avg 816ns/call
443230µs3224µs my $test_subs = _make_hash($opts{__tests__} || {});
# spent 24µs making 32 calls to Class::XSAccessor::_make_hash, avg 759ns/call
453232µs my $construct_subs = $opts{constructors} || [defined($opts{constructor}) ? $opts{constructor} : ()];
463211µs my $true_subs = $opts{true} || [];
473216µs my $false_subs = $opts{false} || [];
48
4932143µs foreach my $subtype ( ["getter", $read_subs],
50 ["setter", $set_subs],
51 ["accessor", $acc_subs],
52 ["lvalue_accessor", $lvacc_subs],
53 ["test", $test_subs],
54 ["ex_predicate", $ex_pred_subs],
55 ["def_predicate", $def_pred_subs],
56 ["def_predicate", $pred_subs] )
57 {
5825649µs my $subs = $subtype->[1];
59256238µs foreach my $subname (keys %$subs) {
603212µs my $hashkey = $subs->{$subname};
613278µs32592µs _generate_method($caller_pkg, $subname, $hashkey, \%opts, $subtype->[0]);
# spent 592µs making 32 calls to Class::XSAccessor::_generate_method, avg 19µs/call
62 }
63 }
64
6532190µs foreach my $subtype ( ["constructor", $construct_subs],
66 ["true", $true_subs],
67 ["false", $false_subs] )
68 {
699652µs foreach my $subname (@{$subtype->[1]}) {
70 _generate_method($caller_pkg, $subname, "", \%opts, $subtype->[0]);
71 }
72 }
73}
74
75
# spent 592µs (297+295) within Class::XSAccessor::_generate_method which was called 32 times, avg 19µs/call: # 32 times (297µs+295µs) by Class::XSAccessor::import at line 61, avg 19µs/call
sub _generate_method {
763222µs my ($caller_pkg, $subname, $hashkey, $opts, $type) = @_;
77
78328µs croak("Cannot use undef as a hash key for generating an XS $type accessor. (Sub: $subname)")
79 if not defined $hashkey;
80
8132130µs3238µs $subname = "${caller_pkg}::$subname" if $subname !~ /::/;
# spent 38µs making 32 calls to Class::XSAccessor::CORE:match, avg 1µs/call
82
833213µs Class::XSAccessor::Heavy::check_sub_existence($subname) if not $opts->{replace};
842200µs231µs
# spent 20µs (9+11) within Class::XSAccessor::BEGIN@84 which was called: # once (9µs+11µs) by Module::Runtime::require_module at line 84
no warnings 'redefine'; # don't warn about an explicitly requested redefine
# spent 20µs making 1 call to Class::XSAccessor::BEGIN@84 # spent 11µs making 1 call to warnings::unimport
85
8632124µs422µs if ($type eq 'getter') {
# spent 22µs making 4 calls to Class::XSAccessor::newxs_getter, avg 6µs/call
87 newxs_getter($subname, $hashkey);
88 }
89 elsif ($type eq 'lvalue_accessor') {
90 newxs_lvalue_accessor($subname, $hashkey);
91 }
92 elsif ($type eq 'setter') {
93 newxs_setter($subname, $hashkey, $opts->{chained}||0);
94 }
95 elsif ($type eq 'def_predicate') {
96 newxs_defined_predicate($subname, $hashkey);
97 }
98 elsif ($type eq 'ex_predicate') {
99 newxs_exists_predicate($subname, $hashkey);
100 }
101 elsif ($type eq 'constructor') {
102 newxs_constructor($subname);
103 }
104 elsif ($type eq 'true') {
105 newxs_boolean($subname, 1);
106 }
107 elsif ($type eq 'false') {
108 newxs_boolean($subname, 0);
109 }
110 elsif ($type eq 'test') {
111 newxs_test($subname, $hashkey);
112 }
113 else {
11428307µs28235µs newxs_accessor($subname, $hashkey, $opts->{chained}||0);
# spent 235µs making 28 calls to Class::XSAccessor::newxs_accessor, avg 8µs/call
115 }
116}
117
11814µs1;
119
120__END__
 
# spent 38µs within Class::XSAccessor::CORE:match which was called 32 times, avg 1µs/call: # 32 times (38µs+0s) by Class::XSAccessor::_generate_method at line 81, avg 1µs/call
sub Class::XSAccessor::CORE:match; # opcode
# spent 235µs within Class::XSAccessor::newxs_accessor which was called 28 times, avg 8µs/call: # 28 times (235µs+0s) by Class::XSAccessor::_generate_method at line 114, avg 8µs/call
sub Class::XSAccessor::newxs_accessor; # xsub
# spent 22µs within Class::XSAccessor::newxs_getter which was called 4 times, avg 6µs/call: # 4 times (22µs+0s) by Class::XSAccessor::_generate_method at line 86, avg 6µs/call
sub Class::XSAccessor::newxs_getter; # xsub