Filename | /usr/share/koha/lib/C4/XSLT.pm |
Statements | Executed 5870 statements in 37.6ms |
Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
---|---|---|---|---|---|
25 | 1 | 1 | 11.5ms | 1.40s | transformMARCXML4XSLT | C4::XSLT::
25 | 1 | 1 | 7.70ms | 3.36s | XSLTParse4Display | C4::XSLT::
25 | 1 | 1 | 7.68ms | 1.72s | buildKohaItemsNamespace | C4::XSLT::
1 | 1 | 1 | 3.35ms | 5.32ms | BEGIN@35 | C4::XSLT::
100 | 4 | 1 | 1.60ms | 1.60ms | CORE:subst (opcode) | C4::XSLT::
25 | 1 | 1 | 888µs | 888µs | CORE:ftfile (opcode) | C4::XSLT::
25 | 1 | 1 | 843µs | 7.98ms | getAuthorisedValues4MARCSubfields | C4::XSLT::
25 | 1 | 1 | 724µs | 1.61ms | _get_best_default_xslt_filename | C4::XSLT::
51 | 3 | 1 | 229µs | 229µs | CORE:match (opcode) | C4::XSLT::
1 | 1 | 1 | 49µs | 201µs | BEGIN@27 | C4::XSLT::
1 | 1 | 1 | 23µs | 96µs | BEGIN@235 | C4::XSLT::
1 | 1 | 1 | 23µs | 385µs | BEGIN@32 | C4::XSLT::
1 | 1 | 1 | 23µs | 298µs | BEGIN@34 | C4::XSLT::
1 | 1 | 1 | 22µs | 422µs | BEGIN@31 | C4::XSLT::
1 | 1 | 1 | 20µs | 300µs | BEGIN@28 | C4::XSLT::
1 | 1 | 1 | 19µs | 582µs | BEGIN@36 | C4::XSLT::
1 | 1 | 1 | 19µs | 19µs | BEGIN@40 | C4::XSLT::
1 | 1 | 1 | 18µs | 103µs | BEGIN@33 | C4::XSLT::
1 | 1 | 1 | 18µs | 598µs | BEGIN@30 | C4::XSLT::
1 | 1 | 1 | 18µs | 22µs | BEGIN@23 | C4::XSLT::
1 | 1 | 1 | 15µs | 498µs | BEGIN@29 | C4::XSLT::
1 | 1 | 1 | 14µs | 38µs | BEGIN@24 | C4::XSLT::
1 | 1 | 1 | 13µs | 18µs | BEGIN@26 | C4::XSLT::
1 | 1 | 1 | 11µs | 64µs | BEGIN@38 | C4::XSLT::
0 | 0 | 0 | 0s | 0s | GetURI | C4::XSLT::
Line | State ments |
Time on line |
Calls | Time in subs |
Code |
---|---|---|---|---|---|
1 | package C4::XSLT; | ||||
2 | # Copyright (C) 2006 LibLime | ||||
3 | # <jmf at liblime dot com> | ||||
4 | # Parts Copyright Katrin Fischer 2011 | ||||
5 | # Parts Copyright ByWater Solutions 2011 | ||||
6 | # Parts Copyright Biblibre 2012 | ||||
7 | # | ||||
8 | # This file is part of Koha. | ||||
9 | # | ||||
10 | # Koha is free software; you can redistribute it and/or modify it under the | ||||
11 | # terms of the GNU General Public License as published by the Free Software | ||||
12 | # Foundation; either version 2 of the License, or (at your option) any later | ||||
13 | # version. | ||||
14 | # | ||||
15 | # Koha is distributed in the hope that it will be useful, but WITHOUT ANY | ||||
16 | # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR | ||||
17 | # A PARTICULAR PURPOSE. See the GNU General Public License for more details. | ||||
18 | # | ||||
19 | # You should have received a copy of the GNU General Public License along | ||||
20 | # with Koha; if not, write to the Free Software Foundation, Inc., | ||||
21 | # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||||
22 | |||||
23 | 3 | 28µs | 2 | 26µs | # spent 22µs (18+4) within C4::XSLT::BEGIN@23 which was called:
# once (18µs+4µs) by C4::Search::BEGIN@29 at line 23 # spent 22µs making 1 call to C4::XSLT::BEGIN@23
# spent 4µs making 1 call to strict::import |
24 | 3 | 30µs | 2 | 62µs | # spent 38µs (14+24) within C4::XSLT::BEGIN@24 which was called:
# once (14µs+24µs) by C4::Search::BEGIN@29 at line 24 # spent 38µs making 1 call to C4::XSLT::BEGIN@24
# spent 24µs making 1 call to warnings::import |
25 | |||||
26 | 3 | 28µs | 2 | 24µs | # spent 18µs (13+5) within C4::XSLT::BEGIN@26 which was called:
# once (13µs+5µs) by C4::Search::BEGIN@29 at line 26 # spent 18µs making 1 call to C4::XSLT::BEGIN@26
# spent 5µs making 1 call to C4::Context::import |
27 | 3 | 40µs | 2 | 353µs | # spent 201µs (49+152) within C4::XSLT::BEGIN@27 which was called:
# once (49µs+152µs) by C4::Search::BEGIN@29 at line 27 # spent 201µs making 1 call to C4::XSLT::BEGIN@27
# spent 152µs making 1 call to Exporter::import |
28 | 3 | 40µs | 2 | 581µs | # spent 300µs (20+281) within C4::XSLT::BEGIN@28 which was called:
# once (20µs+281µs) by C4::Search::BEGIN@29 at line 28 # spent 300µs making 1 call to C4::XSLT::BEGIN@28
# spent 281µs making 1 call to Exporter::import |
29 | 3 | 37µs | 2 | 981µs | # spent 498µs (15+483) within C4::XSLT::BEGIN@29 which was called:
# once (15µs+483µs) by C4::Search::BEGIN@29 at line 29 # spent 498µs making 1 call to C4::XSLT::BEGIN@29
# spent 483µs making 1 call to Exporter::import |
30 | 3 | 40µs | 2 | 1.18ms | # spent 598µs (18+580) within C4::XSLT::BEGIN@30 which was called:
# once (18µs+580µs) by C4::Search::BEGIN@29 at line 30 # spent 598µs making 1 call to C4::XSLT::BEGIN@30
# spent 580µs making 1 call to Exporter::import |
31 | 3 | 59µs | 2 | 822µs | # spent 422µs (22+400) within C4::XSLT::BEGIN@31 which was called:
# once (22µs+400µs) by C4::Search::BEGIN@29 at line 31 # spent 422µs making 1 call to C4::XSLT::BEGIN@31
# spent 400µs making 1 call to Exporter::import |
32 | 3 | 43µs | 2 | 747µs | # spent 385µs (23+362) within C4::XSLT::BEGIN@32 which was called:
# once (23µs+362µs) by C4::Search::BEGIN@29 at line 32 # spent 385µs making 1 call to C4::XSLT::BEGIN@32
# spent 362µs making 1 call to Exporter::import |
33 | 3 | 51µs | 2 | 188µs | # spent 103µs (18+85) within C4::XSLT::BEGIN@33 which was called:
# once (18µs+85µs) by C4::Search::BEGIN@29 at line 33 # spent 103µs making 1 call to C4::XSLT::BEGIN@33
# spent 85µs making 1 call to Exporter::import |
34 | 3 | 48µs | 2 | 572µs | # spent 298µs (23+275) within C4::XSLT::BEGIN@34 which was called:
# once (23µs+275µs) by C4::Search::BEGIN@29 at line 34 # spent 298µs making 1 call to C4::XSLT::BEGIN@34
# spent 275µs making 1 call to XML::LibXML::import |
35 | 3 | 182µs | 1 | 5.32ms | # spent 5.32ms (3.35+1.96) within C4::XSLT::BEGIN@35 which was called:
# once (3.35ms+1.96ms) by C4::Search::BEGIN@29 at line 35 # spent 5.32ms making 1 call to C4::XSLT::BEGIN@35 |
36 | 3 | 49µs | 2 | 1.15ms | # spent 582µs (19+563) within C4::XSLT::BEGIN@36 which was called:
# once (19µs+563µs) by C4::Search::BEGIN@29 at line 36 # spent 582µs making 1 call to C4::XSLT::BEGIN@36
# spent 563µs making 1 call to LWP::Simple::import |
37 | |||||
38 | 3 | 61µs | 2 | 118µs | # spent 64µs (11+53) within C4::XSLT::BEGIN@38 which was called:
# once (11µs+53µs) by C4::Search::BEGIN@29 at line 38 # spent 64µs making 1 call to C4::XSLT::BEGIN@38
# spent 53µs making 1 call to vars::import |
39 | |||||
40 | # spent 19µs within C4::XSLT::BEGIN@40 which was called:
# once (19µs+0s) by C4::Search::BEGIN@29 at line 48 | ||||
41 | 1 | 800ns | require Exporter; | ||
42 | 1 | 1µs | $VERSION = 3.07.00.049; | ||
43 | 1 | 10µs | @ISA = qw(Exporter); | ||
44 | 1 | 6µs | @EXPORT = qw( | ||
45 | &XSLTParse4Display | ||||
46 | &GetURI | ||||
47 | ); | ||||
48 | 1 | 1.02ms | 1 | 19µs | } # spent 19µs making 1 call to C4::XSLT::BEGIN@40 |
49 | |||||
50 | =head1 NAME | ||||
51 | |||||
- - | |||||
62 | sub GetURI { | ||||
63 | my ($uri) = @_; | ||||
64 | my $string; | ||||
65 | $string = get $uri ; | ||||
66 | return $string; | ||||
67 | } | ||||
68 | |||||
69 | =head2 transformMARCXML4XSLT | ||||
70 | |||||
- - | |||||
75 | # spent 1.40s (11.5ms+1.39) within C4::XSLT::transformMARCXML4XSLT which was called 25 times, avg 55.9ms/call:
# 25 times (11.5ms+1.39s) by C4::XSLT::XSLTParse4Display at line 197, avg 55.9ms/call | ||||
76 | 25 | 56µs | my ($biblionumber, $record) = @_; | ||
77 | 25 | 230µs | 100 | 58.4ms | my $frameworkcode = GetFrameworkCode($biblionumber) || ''; # spent 57.9ms making 25 calls to C4::Biblio::GetFrameworkCode, avg 2.31ms/call
# spent 407µs making 50 calls to DBI::common::DESTROY, avg 8µs/call
# spent 94µs making 25 calls to DBD::_mem::common::DESTROY, avg 4µs/call |
78 | 25 | 183µs | 34 | 501ms | my $tagslib = &GetMarcStructure(1,$frameworkcode); # spent 501ms making 25 calls to C4::Biblio::GetMarcStructure, avg 20.0ms/call
# spent 99µs making 6 calls to DBI::common::DESTROY, avg 16µs/call
# spent 18µs making 3 calls to DBD::_mem::common::DESTROY, avg 6µs/call |
79 | 25 | 19µs | my @fields; | ||
80 | # FIXME: wish there was a better way to handle exceptions | ||||
81 | 25 | 142µs | eval { | ||
82 | 25 | 421µs | 25 | 509µs | @fields = $record->fields(); # spent 509µs making 25 calls to MARC::Record::fields, avg 20µs/call |
83 | }; | ||||
84 | 25 | 17µs | if ($@) { warn "PROBLEM WITH RECORD"; next; } | ||
85 | 25 | 195µs | 25 | 7.98ms | my $av = getAuthorisedValues4MARCSubfields($frameworkcode); # spent 7.98ms making 25 calls to C4::XSLT::getAuthorisedValues4MARCSubfields, avg 319µs/call |
86 | 25 | 177µs | foreach my $tag ( keys %$av ) { | ||
87 | 50 | 527µs | 50 | 17.3ms | foreach my $field ( $record->field( $tag ) ) { # spent 17.3ms making 50 calls to MARC::Record::field, avg 346µs/call |
88 | 57 | 435µs | if ( $av->{ $tag } ) { | ||
89 | 57 | 64µs | my @new_subfields = (); | ||
90 | 57 | 1.11ms | 57 | 3.50ms | for my $subfield ( $field->subfields() ) { # spent 3.50ms making 57 calls to MARC::Field::subfields, avg 61µs/call |
91 | 636 | 1.05ms | my ( $letter, $value ) = @$subfield; | ||
92 | 636 | 3.03ms | 817 | 792ms | $value = GetAuthorisedValueDesc( $tag, $letter, $value, '', $tagslib ) # spent 790ms making 295 calls to C4::Biblio::GetAuthorisedValueDesc, avg 2.68ms/call
# spent 1.87ms making 348 calls to DBI::common::DESTROY, avg 5µs/call
# spent 485µs making 174 calls to DBD::_mem::common::DESTROY, avg 3µs/call |
93 | if $av->{ $tag }->{ $letter }; | ||||
94 | 636 | 1.82ms | push( @new_subfields, $letter, $value ); | ||
95 | } | ||||
96 | 57 | 1.33ms | 228 | 8.78ms | $field ->replace_with( MARC::Field->new( # spent 5.00ms making 57 calls to MARC::Field::new, avg 88µs/call
# spent 1.99ms making 114 calls to MARC::Field::indicator, avg 17µs/call
# spent 1.79ms making 57 calls to MARC::Field::replace_with, avg 31µs/call |
97 | $tag, | ||||
98 | $field->indicator(1), | ||||
99 | $field->indicator(2), | ||||
100 | @new_subfields | ||||
101 | ) ); | ||||
102 | } | ||||
103 | } | ||||
104 | } | ||||
105 | 25 | 251µs | return $record; | ||
106 | } | ||||
107 | |||||
108 | =head2 getAuthorisedValues4MARCSubfields | ||||
109 | |||||
- - | |||||
114 | # Cache for tagfield-tagsubfield to decode per framework. | ||||
115 | # Should be preferably be placed in Koha-core... | ||||
116 | 1 | 300ns | my %authval_per_framework; | ||
117 | |||||
118 | # spent 7.98ms (843µs+7.14) within C4::XSLT::getAuthorisedValues4MARCSubfields which was called 25 times, avg 319µs/call:
# 25 times (843µs+7.14ms) by C4::XSLT::transformMARCXML4XSLT at line 85, avg 319µs/call | ||||
119 | 25 | 45µs | my ($frameworkcode) = @_; | ||
120 | 25 | 52µs | 9 | 77µs | unless ( $authval_per_framework{ $frameworkcode } ) { # spent 65µs making 6 calls to DBI::common::DESTROY, avg 11µs/call
# spent 12µs making 3 calls to DBD::_mem::common::DESTROY, avg 4µs/call |
121 | 3 | 29µs | 3 | 3.36ms | my $dbh = C4::Context->dbh; # spent 3.36ms making 3 calls to C4::Context::dbh, avg 1.12ms/call |
122 | 3 | 75µs | 6 | 658µs | my $sth = $dbh->prepare("SELECT DISTINCT tagfield, tagsubfield # spent 356µs making 3 calls to DBI::db::prepare, avg 119µs/call
# spent 302µs making 3 calls to DBD::mysql::db::prepare, avg 101µs/call |
123 | FROM marc_subfield_structure | ||||
124 | WHERE authorised_value IS NOT NULL | ||||
125 | AND authorised_value!='' | ||||
126 | AND frameworkcode=?"); | ||||
127 | 3 | 3.01ms | 3 | 2.95ms | $sth->execute( $frameworkcode ); # spent 2.95ms making 3 calls to DBI::st::execute, avg 985µs/call |
128 | 3 | 8µs | my $av = { }; | ||
129 | 3 | 721µs | 44 | 393µs | while ( my ( $tag, $letter ) = $sth->fetchrow() ) { # spent 393µs making 44 calls to DBI::st::fetchrow, avg 9µs/call |
130 | $av->{ $tag }->{ $letter } = 1; | ||||
131 | } | ||||
132 | 3 | 182µs | $authval_per_framework{ $frameworkcode } = $av; | ||
133 | } | ||||
134 | 25 | 152µs | return $authval_per_framework{ $frameworkcode }; | ||
135 | } | ||||
136 | |||||
137 | 1 | 200ns | my $stylesheet; | ||
138 | |||||
139 | # spent 1.61ms (724µs+888µs) within C4::XSLT::_get_best_default_xslt_filename which was called 25 times, avg 64µs/call:
# 25 times (724µs+888µs) by C4::XSLT::XSLTParse4Display at line 188, avg 64µs/call | ||||
140 | 25 | 50µs | my ($htdocs, $theme, $lang, $base_xslfile) = @_; | ||
141 | |||||
142 | 25 | 285µs | my @candidates = ( | ||
143 | "$htdocs/$theme/$lang/xslt/${base_xslfile}", # exact match | ||||
144 | "$htdocs/$theme/en/xslt/${base_xslfile}", # if not, preferred theme in English | ||||
145 | "$htdocs/prog/$lang/xslt/${base_xslfile}", # if not, 'prog' theme in preferred language | ||||
146 | "$htdocs/prog/en/xslt/${base_xslfile}", # otherwise, prog theme in English; should always | ||||
147 | # exist | ||||
148 | ); | ||||
149 | 25 | 10µs | my $xslfilename; | ||
150 | 25 | 35µs | foreach my $filename (@candidates) { | ||
151 | 25 | 14µs | $xslfilename = $filename; | ||
152 | 25 | 1.03ms | 25 | 888µs | if (-f $filename) { # spent 888µs making 25 calls to C4::XSLT::CORE:ftfile, avg 36µs/call |
153 | 25 | 59µs | last; # we have a winner! | ||
154 | } | ||||
155 | } | ||||
156 | 25 | 149µs | return $xslfilename; | ||
157 | } | ||||
158 | |||||
159 | # spent 3.36s (7.70ms+3.35) within C4::XSLT::XSLTParse4Display which was called 25 times, avg 134ms/call:
# 25 times (7.70ms+3.35s) by C4::Search::searchResults at line 2014 of /usr/share/koha/lib/C4/Search.pm, avg 134ms/call | ||||
160 | 25 | 56µs | my ( $biblionumber, $orig_record, $xslsyspref, $fixamps, $hidden_items ) = @_; | ||
161 | 25 | 85µs | 25 | 76µs | my $xslfilename = C4::Context->preference($xslsyspref); # spent 76µs making 25 calls to C4::Context::preference, avg 3µs/call |
162 | 25 | 291µs | 25 | 153µs | if ( $xslfilename =~ /^\s*"?default"?\s*$/i ) { # spent 153µs making 25 calls to C4::XSLT::CORE:match, avg 6µs/call |
163 | 25 | 12µs | my $htdocs; | ||
164 | 25 | 9µs | my $theme; | ||
165 | 25 | 160µs | 25 | 162µs | my $lang = C4::Templates::_current_language(); # spent 162µs making 25 calls to C4::Templates::_current_language, avg 6µs/call |
166 | 25 | 9µs | my $xslfile; | ||
167 | 25 | 96µs | if ($xslsyspref eq "XSLTDetailsDisplay") { | ||
168 | $htdocs = C4::Context->config('intrahtdocs'); | ||||
169 | $theme = C4::Context->preference("template"); | ||||
170 | $xslfile = C4::Context->preference('marcflavour') . | ||||
171 | "slim2intranetDetail.xsl"; | ||||
172 | } elsif ($xslsyspref eq "XSLTResultsDisplay") { | ||||
173 | $htdocs = C4::Context->config('intrahtdocs'); | ||||
174 | $theme = C4::Context->preference("template"); | ||||
175 | $xslfile = C4::Context->preference('marcflavour') . | ||||
176 | "slim2intranetResults.xsl"; | ||||
177 | } elsif ($xslsyspref eq "OPACXSLTDetailsDisplay") { | ||||
178 | $htdocs = C4::Context->config('opachtdocs'); | ||||
179 | $theme = C4::Context->preference("opacthemes"); | ||||
180 | $xslfile = C4::Context->preference('marcflavour') . | ||||
181 | "slim2OPACDetail.xsl"; | ||||
182 | } elsif ($xslsyspref eq "OPACXSLTResultsDisplay") { | ||||
183 | 25 | 155µs | 25 | 705µs | $htdocs = C4::Context->config('opachtdocs'); # spent 705µs making 25 calls to C4::Context::config, avg 28µs/call |
184 | 25 | 131µs | 25 | 135µs | $theme = C4::Context->preference("opacthemes"); # spent 135µs making 25 calls to C4::Context::preference, avg 5µs/call |
185 | 25 | 78µs | 25 | 128µs | $xslfile = C4::Context->preference('marcflavour') . # spent 128µs making 25 calls to C4::Context::preference, avg 5µs/call |
186 | "slim2OPACResults.xsl"; | ||||
187 | } | ||||
188 | 25 | 101µs | 25 | 1.61ms | $xslfilename = _get_best_default_xslt_filename($htdocs, $theme, $lang, $xslfile); # spent 1.61ms making 25 calls to C4::XSLT::_get_best_default_xslt_filename, avg 64µs/call |
189 | } | ||||
190 | |||||
191 | 25 | 141µs | 25 | 73µs | if ( $xslfilename =~ m/\{langcode\}/ ) { # spent 73µs making 25 calls to C4::XSLT::CORE:match, avg 3µs/call |
192 | my $lang = C4::Templates::_current_language(); | ||||
193 | $xslfilename =~ s/\{langcode\}/$lang/; | ||||
194 | } | ||||
195 | |||||
196 | # grab the XML, run it through our stylesheet, push it out to the browser | ||||
197 | 25 | 164µs | 25 | 1.40s | my $record = transformMARCXML4XSLT($biblionumber, $orig_record); # spent 1.40s making 25 calls to C4::XSLT::transformMARCXML4XSLT, avg 55.9ms/call |
198 | #return $record->as_formatted(); | ||||
199 | 25 | 194µs | 25 | 1.72s | my $itemsxml = buildKohaItemsNamespace($biblionumber, $hidden_items); # spent 1.72s making 25 calls to C4::XSLT::buildKohaItemsNamespace, avg 68.8ms/call |
200 | 25 | 458µs | 50 | 105ms | my $xmlrecord = $record->as_xml(C4::Context->preference('marcflavour')); # spent 104ms making 25 calls to MARC::Record::as_xml, avg 4.17ms/call
# spent 343µs making 25 calls to C4::Context::preference, avg 14µs/call |
201 | 25 | 29µs | my $sysxml = "<sysprefs>\n"; | ||
202 | 25 | 113µs | foreach my $syspref ( qw/ hidelostitems OPACURLOpenInNewWindow | ||
203 | DisplayOPACiconsXSLT URLLinkText viewISBD | ||||
204 | OPACBaseURL TraceCompleteSubfields UseICU | ||||
205 | UseAuthoritiesForTracings TraceSubjectSubdivisions | ||||
206 | Display856uAsImage OPACDisplay856uAsImage | ||||
207 | UseControlNumber IntranetBiblioDefaultView BiblioDefaultView | ||||
208 | singleBranchMode OPACItemLocation DisplayIconsXSLT | ||||
209 | AlternateHoldingsField AlternateHoldingsSeparator | ||||
210 | TrackClicks OpacResultsItemtypeImage/ ) | ||||
211 | { | ||||
212 | 550 | 1.50ms | 550 | 41.9ms | my $sp = C4::Context->preference( $syspref ); # spent 41.9ms making 550 calls to C4::Context::preference, avg 76µs/call |
213 | 550 | 186µs | next unless defined($sp); | ||
214 | 525 | 829µs | $sysxml .= "<syspref name=\"$syspref\">$sp</syspref>\n"; | ||
215 | } | ||||
216 | 25 | 22µs | $sysxml .= "</sysprefs>\n"; | ||
217 | 25 | 789µs | 25 | 634µs | $xmlrecord =~ s/\<\/record\>/$itemsxml$sysxml\<\/record\>/; # spent 634µs making 25 calls to C4::XSLT::CORE:subst, avg 25µs/call |
218 | 25 | 32µs | if ($fixamps) { # We need to correct the ampersand entities that Zebra outputs | ||
219 | 25 | 345µs | 25 | 257µs | $xmlrecord =~ s/\&amp;/\&/g; # spent 257µs making 25 calls to C4::XSLT::CORE:subst, avg 10µs/call |
220 | } | ||||
221 | 25 | 463µs | 25 | 398µs | $xmlrecord =~ s/\& /\&\; /; # spent 398µs making 25 calls to C4::XSLT::CORE:subst, avg 16µs/call |
222 | 25 | 383µs | 25 | 313µs | $xmlrecord =~ s/\&\;amp\; /\&\; /; # spent 313µs making 25 calls to C4::XSLT::CORE:subst, avg 13µs/call |
223 | |||||
224 | 25 | 216µs | 25 | 687µs | my $parser = XML::LibXML->new(); # spent 687µs making 25 calls to XML::LibXML::new, avg 27µs/call |
225 | # don't die when you find &, >, etc | ||||
226 | 25 | 153µs | 25 | 1.05ms | $parser->recover_silently(0); # spent 1.05ms making 25 calls to XML::LibXML::recover_silently, avg 42µs/call |
227 | 25 | 162µs | 25 | 13.7ms | my $source = $parser->parse_string($xmlrecord); # spent 13.7ms making 25 calls to XML::LibXML::parse_string, avg 547µs/call |
228 | 25 | 90µs | 2 | 555µs | unless ( $stylesheet->{$xslfilename} ) { # spent 290µs making 1 call to XML::LibXML::Node::DESTROY
# spent 265µs making 1 call to AutoLoader::AUTOLOAD |
229 | 1 | 9µs | 1 | 20µs | my $xslt = XML::LibXSLT->new(); # spent 20µs making 1 call to XML::LibXSLT::new |
230 | 1 | 400ns | my $style_doc; | ||
231 | 1 | 9µs | 1 | 3µs | if ( $xslfilename =~ /^https?:\/\// ) { # spent 3µs making 1 call to C4::XSLT::CORE:match |
232 | my $xsltstring = GetURI($xslfilename); | ||||
233 | $style_doc = $parser->parse_string($xsltstring); | ||||
234 | } else { | ||||
235 | 3 | 542µs | 2 | 168µs | # spent 96µs (23+73) within C4::XSLT::BEGIN@235 which was called:
# once (23µs+73µs) by C4::Search::BEGIN@29 at line 235 # spent 96µs making 1 call to C4::XSLT::BEGIN@235
# spent 73µs making 1 call to Exporter::import |
236 | 1 | 4µs | 1 | 1.53ms | $style_doc = $parser->parse_file($xslfilename); # spent 1.53ms making 1 call to XML::LibXML::parse_file |
237 | } | ||||
238 | 1 | 334µs | 1 | 15.0ms | $stylesheet->{$xslfilename} = $xslt->parse_stylesheet($style_doc); # spent 15.0ms making 1 call to XML::LibXSLT::parse_stylesheet |
239 | } | ||||
240 | 25 | 195µs | 25 | 50.4ms | my $results = $stylesheet->{$xslfilename}->transform($source); # spent 50.4ms making 25 calls to XML::LibXSLT::StylesheetWrapper::transform, avg 2.02ms/call |
241 | 25 | 180µs | 25 | 1.72ms | my $newxmlrecord = $stylesheet->{$xslfilename}->output_string($results); # spent 1.72ms making 25 calls to XML::LibXSLT::StylesheetWrapper::output_string, avg 69µs/call |
242 | 25 | 2.17ms | return $newxmlrecord; | ||
243 | } | ||||
244 | |||||
245 | # spent 1.72s (7.68ms+1.71) within C4::XSLT::buildKohaItemsNamespace which was called 25 times, avg 68.8ms/call:
# 25 times (7.68ms+1.71s) by C4::XSLT::XSLTParse4Display at line 199, avg 68.8ms/call | ||||
246 | 25 | 48µs | my ($biblionumber, $hidden_items) = @_; | ||
247 | |||||
248 | 25 | 335µs | 250 | 833ms | my @items = C4::Items::GetItemsInfo($biblionumber); # spent 832ms making 25 calls to C4::Items::GetItemsInfo, avg 33.3ms/call
# spent 1.19ms making 150 calls to DBI::common::DESTROY, avg 8µs/call
# spent 358µs making 75 calls to DBD::_mem::common::DESTROY, avg 5µs/call |
249 | 25 | 61µs | if ($hidden_items && @$hidden_items) { | ||
250 | my %hi = map {$_ => 1} @$hidden_items; | ||||
251 | @items = grep { !$hi{$_->{itemnumber}} } @items; | ||||
252 | } | ||||
253 | |||||
254 | 25 | 430µs | 200 | 171ms | my $shelflocations = GetKohaAuthorisedValues('items.location',GetFrameworkCode($biblionumber), 'opac'); # spent 115ms making 25 calls to C4::Koha::GetKohaAuthorisedValues, avg 4.60ms/call
# spent 55.7ms making 25 calls to C4::Biblio::GetFrameworkCode, avg 2.23ms/call
# spent 638µs making 100 calls to DBI::common::DESTROY, avg 6µs/call
# spent 173µs making 50 calls to DBD::_mem::common::DESTROY, avg 3µs/call |
255 | 25 | 351µs | 200 | 158ms | my $ccodes = GetKohaAuthorisedValues('items.ccode',GetFrameworkCode($biblionumber), 'opac'); # spent 107ms making 25 calls to C4::Koha::GetKohaAuthorisedValues, avg 4.27ms/call
# spent 50.6ms making 25 calls to C4::Biblio::GetFrameworkCode, avg 2.03ms/call
# spent 625µs making 100 calls to DBI::common::DESTROY, avg 6µs/call
# spent 149µs making 50 calls to DBD::_mem::common::DESTROY, avg 3µs/call |
256 | |||||
257 | 25 | 268µs | 175 | 336ms | my $branches = GetBranches(); # spent 335ms making 25 calls to C4::Branch::GetBranches, avg 13.4ms/call
# spent 668µs making 100 calls to DBI::common::DESTROY, avg 7µs/call
# spent 246µs making 50 calls to DBD::_mem::common::DESTROY, avg 5µs/call |
258 | 25 | 213µs | 100 | 78.1ms | my $itemtypes = GetItemTypes(); # spent 77.7ms making 25 calls to C4::Koha::GetItemTypes, avg 3.11ms/call
# spent 257µs making 50 calls to DBI::common::DESTROY, avg 5µs/call
# spent 88µs making 25 calls to DBD::_mem::common::DESTROY, avg 4µs/call |
259 | 25 | 36µs | my $location = ""; | ||
260 | 25 | 28µs | my $ccode = ""; | ||
261 | 25 | 20µs | my $xml = ''; | ||
262 | 25 | 96µs | for my $item (@items) { | ||
263 | 32 | 13µs | my $status; | ||
264 | |||||
265 | 32 | 348µs | 128 | 69.8ms | my ( $transfertwhen, $transfertfrom, $transfertto ) = C4::Circulation::GetTransfers($item->{itemnumber}); # spent 69.5ms making 32 calls to C4::Circulation::GetTransfers, avg 2.17ms/call
# spent 276µs making 64 calls to DBI::common::DESTROY, avg 4µs/call
# spent 84µs making 32 calls to DBD::_mem::common::DESTROY, avg 3µs/call |
266 | |||||
267 | 32 | 475µs | 128 | 68.5ms | my $reservestatus = C4::Reserves::GetReserveStatus( $item->{itemnumber} ); # spent 68.1ms making 32 calls to C4::Reserves::GetReserveStatus, avg 2.13ms/call
# spent 329µs making 64 calls to DBI::common::DESTROY, avg 5µs/call
# spent 97µs making 32 calls to DBD::_mem::common::DESTROY, avg 3µs/call |
268 | |||||
269 | 32 | 444µs | if ( $itemtypes->{ $item->{itype} }->{notforloan} || $item->{notforloan} || $item->{onloan} || $item->{wthdrawn} || $item->{itemlost} || $item->{damaged} || | ||
270 | (defined $transfertwhen && $transfertwhen ne '') || $item->{itemnotforloan} || (defined $reservestatus && $reservestatus eq "Waiting") ){ | ||||
271 | 1 | 7µs | if ( $item->{notforloan} < 0) { | ||
272 | $status = "On order"; | ||||
273 | } | ||||
274 | 1 | 11µs | if ( $item->{itemnotforloan} > 0 || $item->{notforloan} > 0 || $itemtypes->{ $item->{itype} }->{notforloan} == 1 ) { | ||
275 | $status = "reference"; | ||||
276 | } | ||||
277 | 1 | 2µs | if ($item->{onloan}) { | ||
278 | $status = "Checked out"; | ||||
279 | } | ||||
280 | 1 | 2µs | if ( $item->{wthdrawn}) { | ||
281 | $status = "Withdrawn"; | ||||
282 | } | ||||
283 | 1 | 2µs | if ($item->{itemlost}) { | ||
284 | $status = "Lost"; | ||||
285 | } | ||||
286 | 1 | 2µs | if ($item->{damaged}) { | ||
287 | $status = "Damaged"; | ||||
288 | } | ||||
289 | 1 | 1µs | if (defined $transfertwhen && $transfertwhen ne '') { | ||
290 | $status = 'In transit'; | ||||
291 | } | ||||
292 | 1 | 3µs | if (defined $reservestatus && $reservestatus eq "Waiting") { | ||
293 | $status = 'Waiting'; | ||||
294 | } | ||||
295 | } else { | ||||
296 | 31 | 49µs | $status = "available"; | ||
297 | } | ||||
298 | 32 | 370µs | 32 | 1.08ms | my $homebranch = $item->{homebranch}? xml_escape($branches->{$item->{homebranch}}->{'branchname'}):''; # spent 1.08ms making 32 calls to C4::Koha::xml_escape, avg 34µs/call |
299 | 32 | 187µs | 32 | 526µs | my $holdingbranch = $item->{holdingbranch}? xml_escape($branches->{$item->{holdingbranch}}->{'branchname'}):''; # spent 526µs making 32 calls to C4::Koha::xml_escape, avg 16µs/call |
300 | 32 | 144µs | 17 | 266µs | $location = $item->{location}? xml_escape($shelflocations->{$item->{location}}||$item->{location}):''; # spent 266µs making 17 calls to C4::Koha::xml_escape, avg 16µs/call |
301 | 32 | 69µs | 1 | 10µs | $ccode = $item->{ccode}? xml_escape($ccodes->{$item->{ccode}}||$item->{ccode}):''; # spent 10µs making 1 call to C4::Koha::xml_escape |
302 | 32 | 159µs | 32 | 376µs | my $itemcallnumber = xml_escape($item->{itemcallnumber}); # spent 376µs making 32 calls to C4::Koha::xml_escape, avg 12µs/call |
303 | 32 | 323µs | $xml.= "<item><homebranch>$homebranch</homebranch>". | ||
304 | "<holdingbranch>$holdingbranch</holdingbranch>". | ||||
305 | "<location>$location</location>". | ||||
306 | "<ccode>$ccode</ccode>". | ||||
307 | "<status>$status</status>". | ||||
308 | "<itemcallnumber>".$itemcallnumber."</itemcallnumber>" | ||||
309 | . "</item>"; | ||||
310 | |||||
311 | } | ||||
312 | 25 | 45µs | $xml = "<items xmlns=\"http://www.koha-community.org/items\">".$xml."</items>"; | ||
313 | 25 | 3.41ms | return $xml; | ||
314 | } | ||||
315 | |||||
- - | |||||
318 | 1 | 5µs | 1; | ||
319 | __END__ | ||||
# spent 888µs within C4::XSLT::CORE:ftfile which was called 25 times, avg 36µs/call:
# 25 times (888µs+0s) by C4::XSLT::_get_best_default_xslt_filename at line 152, avg 36µs/call | |||||
sub C4::XSLT::CORE:match; # opcode | |||||
# spent 1.60ms within C4::XSLT::CORE:subst which was called 100 times, avg 16µs/call:
# 25 times (634µs+0s) by C4::XSLT::XSLTParse4Display at line 217, avg 25µs/call
# 25 times (398µs+0s) by C4::XSLT::XSLTParse4Display at line 221, avg 16µs/call
# 25 times (313µs+0s) by C4::XSLT::XSLTParse4Display at line 222, avg 13µs/call
# 25 times (257µs+0s) by C4::XSLT::XSLTParse4Display at line 219, avg 10µs/call |