← Index
NYTProf Performance Profile   « line view »
For svc/members/upsert
  Run on Tue Jan 13 11:50:22 2015
Reported on Tue Jan 13 12:09:49 2015

Filename/mnt/catalyst/koha/C4/ClassSortRoutine.pm
StatementsExecuted 31 statements in 701µs
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
111484µs496µsC4::ClassSortRoutine::::BEGIN@20C4::ClassSortRoutine::BEGIN@20
1119µs15µsC4::ClassSortRoutine::::BEGIN@24C4::ClassSortRoutine::BEGIN@24
1117µs13µsC4::ClassSortRoutine::::BEGIN@21C4::ClassSortRoutine::BEGIN@21
1117µs9µsC4::ClassSortRoutine::::BEGIN@25C4::ClassSortRoutine::BEGIN@25
1116µs55µsC4::ClassSortRoutine::::BEGIN@27C4::ClassSortRoutine::BEGIN@27
1116µs6.66msC4::ClassSortRoutine::::GetSortRoutineNamesC4::ClassSortRoutine::GetSortRoutineNames
0000s0sC4::ClassSortRoutine::::GetClassSortKeyC4::ClassSortRoutine::GetClassSortKey
0000s0sC4::ClassSortRoutine::::_get_class_sort_keyC4::ClassSortRoutine::_get_class_sort_key
Call graph for these subroutines as a Graphviz dot language file.
Line State
ments
Time
on line
Calls Time
in subs
Code
1package C4::ClassSortRoutine;
2
3# Copyright (C) 2007 LibLime
4#
5# This file is part of Koha.
6#
7# Koha is free software; you can redistribute it and/or modify it under the
8# terms of the GNU General Public License as published by the Free Software
9# Foundation; either version 2 of the License, or (at your option) any later
10# version.
11#
12# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
15#
16# You should have received a copy of the GNU General Public License along
17# with Koha; if not, write to the Free Software Foundation, Inc.,
18# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
19
20228µs2509µs
# spent 496µs (484+13) within C4::ClassSortRoutine::BEGIN@20 which was called: # once (484µs+13µs) by C4::ClassSource::BEGIN@25 at line 20
use strict;
# spent 496µs making 1 call to C4::ClassSortRoutine::BEGIN@20 # spent 13µs making 1 call to strict::import
21225µs219µs
# spent 13µs (7+6) within C4::ClassSortRoutine::BEGIN@21 which was called: # once (7µs+6µs) by C4::ClassSource::BEGIN@25 at line 21
use warnings;
# spent 13µs making 1 call to C4::ClassSortRoutine::BEGIN@21 # spent 6µs making 1 call to warnings::import
22
231900nsrequire Exporter;
24222µs220µs
# spent 15µs (9+6) within C4::ClassSortRoutine::BEGIN@24 which was called: # once (9µs+6µs) by C4::ClassSource::BEGIN@25 at line 24
use Class::Factory::Util;
# spent 15µs making 1 call to C4::ClassSortRoutine::BEGIN@24 # spent 6µs making 1 call to Class::Factory::Util::import
25231µs211µs
# spent 9µs (7+2) within C4::ClassSortRoutine::BEGIN@25 which was called: # once (7µs+2µs) by C4::ClassSource::BEGIN@25 at line 25
use C4::Context;
# spent 9µs making 1 call to C4::ClassSortRoutine::BEGIN@25 # spent 2µs making 1 call to C4::Context::import
26
272372µs2104µs
# spent 55µs (6+49) within C4::ClassSortRoutine::BEGIN@27 which was called: # once (6µs+49µs) by C4::ClassSource::BEGIN@25 at line 27
use vars qw($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
# spent 55µs making 1 call to C4::ClassSortRoutine::BEGIN@27 # spent 49µs making 1 call to vars::import
28
29# set the version for version checking
3011µs$VERSION = 3.07.00.049;
31
32=head1 NAME
33
34C4::ClassSortRoutine - base object for creation of classification sorting
35 key generation routines
36
37=head1 SYNOPSIS
38
39use C4::ClassSortRoutine;
40
41=head1 FUNCTIONS
42
43=cut
44
4516µs@ISA = qw(Exporter);
461500ns@EXPORT = qw(
47 &GetSortRoutineNames
48 &GetClassSortKey
49);
50
51# intialization code
521400nsmy %loaded_routines = ();
5312µs16.66msmy @sort_routines = GetSortRoutineNames();
# spent 6.66ms making 1 call to C4::ClassSortRoutine::GetSortRoutineNames
541700nsforeach my $sort_routine (@sort_routines) {
55363µs if (eval "require C4::ClassSortRoutine::$sort_routine") {
# spent 3.08ms executing statements in string eval # spent 2.97ms executing statements in string eval # spent 2.55ms executing statements in string eval
563500ns my $ref;
57380µs eval "\$ref = \\\&C4::ClassSortRoutine::${sort_routine}::get_class_sort_key";
# spent 2µs executing statements in string eval # spent 2µs executing statements in string eval # spent 2µs executing statements in string eval
58353µs if (eval "\$ref->(\"a\", \"b\")") {
# spent 10µs executing statements in 3 string evals (merged)
59 $loaded_routines{$sort_routine} = $ref;
60 } else {
61 $loaded_routines{$sort_routine} = \&_get_class_sort_key;
62 }
63 } else {
64 $loaded_routines{$sort_routine} = \&_get_class_sort_key;
65 }
66}
67
68=head2 GetSortRoutineNames
69
70 my @routines = GetSortRoutineNames();
71
72Get names of all modules under C4::ClassSortRoutine::*. Adding
73a new classification sorting routine can therefore be done
74simply by writing a new submodule under C4::ClassSortRoutine and
75placing it in the C4/ClassSortRoutine directory.
76
77=cut
78
79
# spent 6.66ms (6µs+6.65) within C4::ClassSortRoutine::GetSortRoutineNames which was called: # once (6µs+6.65ms) by C4::ClassSource::BEGIN@25 at line 53
sub GetSortRoutineNames {
8015µs16.65ms return C4::ClassSortRoutine->subclasses();
# spent 6.65ms making 1 call to Class::Factory::Util::_subclasses
81}
82
83=head2 GetClassSortKey
84
85 my $cn_sort = GetClassSortKey($sort_routine, $cn_class, $cn_item);
86
87Generates classification sorting key. If $sort_routine does not point
88to a valid submodule in C4::ClassSortRoutine, default to a basic
89normalization routine.
90
91=cut
92
93sub GetClassSortKey {
94 my ($sort_routine, $cn_class, $cn_item) = @_;
95 unless (exists $loaded_routines{$sort_routine}) {
96 warn "attempting to use non-existent class sorting routine $sort_routine\n";
97 $loaded_routines{$sort_routine} = \&_get_class_sort_key;
98 }
99 my $key = $loaded_routines{$sort_routine}->($cn_class, $cn_item);
100 # FIXME -- hardcoded length for cn_sort
101 # should replace with some way of getting column widths from
102 # the DB schema -- since doing this should ideally be
103 # independent of the DBMS, deferring for the moment.
104 return substr($key, 0, 30);
105}
106
107=head2 _get_class_sort_key
108
109Basic sorting function. Concatenates classification part
110and item, converts to uppercase, changes each run of
111whitespace to '_', and removes any non-digit, non-latin
112letter characters.
113
114=cut
115
116sub _get_class_sort_key {
117 my ($cn_class, $cn_item) = @_;
118 my $key = uc "$cn_class $cn_item";
119 $key =~ s/\s+/_/;
120 $key =~ s/[^A-Z_0-9]//g;
121 return $key;
122}
123
124110µs1;
125
126=head1 AUTHOR
127
128Koha Development Team <http://koha-community.org/>
129
130=cut
131