| Filename | /usr/share/perl5/MARC/Charset/Table.pm |
| Statements | Executed 32 statements in 1.52ms |
| Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
|---|---|---|---|---|---|
| 1 | 1 | 1 | 981µs | 18.9ms | MARC::Charset::Table::BEGIN@36 |
| 1 | 1 | 1 | 934µs | 7.33ms | MARC::Charset::Table::BEGIN@38 |
| 1 | 1 | 1 | 633µs | 13.0ms | MARC::Charset::Table::BEGIN@40 |
| 1 | 1 | 1 | 277µs | 602µs | MARC::Charset::Table::BEGIN@37 |
| 1 | 1 | 1 | 24µs | 109µs | MARC::Charset::Table::_init |
| 1 | 1 | 1 | 22µs | 131µs | MARC::Charset::Table::new |
| 1 | 1 | 1 | 22µs | 27µs | MARC::Charset::Table::BEGIN@34 |
| 1 | 1 | 1 | 17µs | 20µs | MARC::Charset::Table::db_path |
| 1 | 1 | 1 | 16µs | 42µs | MARC::Charset::Table::BEGIN@35 |
| 1 | 1 | 1 | 15µs | 466µs | MARC::Charset::Table::BEGIN@39 |
| 1 | 1 | 1 | 3µs | 3µs | MARC::Charset::Table::CORE:subst (opcode) |
| 0 | 0 | 0 | 0s | 0s | MARC::Charset::Table::add_code |
| 0 | 0 | 0 | 0s | 0s | MARC::Charset::Table::brand_new |
| 0 | 0 | 0 | 0s | 0s | MARC::Charset::Table::db |
| 0 | 0 | 0 | 0s | 0s | MARC::Charset::Table::get_code |
| 0 | 0 | 0 | 0s | 0s | MARC::Charset::Table::lookup_by_marc8 |
| 0 | 0 | 0 | 0s | 0s | MARC::Charset::Table::lookup_by_utf8 |
| Line | State ments |
Time on line |
Calls | Time in subs |
Code |
|---|---|---|---|---|---|
| 1 | package MARC::Charset::Table; | ||||
| 2 | |||||
| 3 | =head1 NAME | ||||
| 4 | |||||
| - - | |||||
| 34 | 3 | 38µs | 2 | 32µs | # spent 27µs (22+5) within MARC::Charset::Table::BEGIN@34 which was called:
# once (22µs+5µs) by MARC::Charset::BEGIN@13 at line 34 # spent 27µs making 1 call to MARC::Charset::Table::BEGIN@34
# spent 5µs making 1 call to strict::import |
| 35 | 3 | 39µs | 2 | 68µs | # spent 42µs (16+26) within MARC::Charset::Table::BEGIN@35 which was called:
# once (16µs+26µs) by MARC::Charset::BEGIN@13 at line 35 # spent 42µs making 1 call to MARC::Charset::Table::BEGIN@35
# spent 26µs making 1 call to warnings::import |
| 36 | 3 | 158µs | 2 | 30.5ms | # spent 18.9ms (981µs+17.9) within MARC::Charset::Table::BEGIN@36 which was called:
# once (981µs+17.9ms) by MARC::Charset::BEGIN@13 at line 36 # spent 18.9ms making 1 call to MARC::Charset::Table::BEGIN@36
# spent 11.6ms making 1 call to POSIX::import |
| 37 | 3 | 162µs | 1 | 602µs | # spent 602µs (277+325) within MARC::Charset::Table::BEGIN@37 which was called:
# once (277µs+325µs) by MARC::Charset::BEGIN@13 at line 37 # spent 602µs making 1 call to MARC::Charset::Table::BEGIN@37 |
| 38 | 3 | 158µs | 1 | 7.33ms | # spent 7.33ms (934µs+6.40) within MARC::Charset::Table::BEGIN@38 which was called:
# once (934µs+6.40ms) by MARC::Charset::BEGIN@13 at line 38 # spent 7.33ms making 1 call to MARC::Charset::Table::BEGIN@38 |
| 39 | 3 | 47µs | 2 | 917µs | # spent 466µs (15+451) within MARC::Charset::Table::BEGIN@39 which was called:
# once (15µs+451µs) by MARC::Charset::BEGIN@13 at line 39 # spent 466µs making 1 call to MARC::Charset::Table::BEGIN@39
# spent 451µs making 1 call to Exporter::import |
| 40 | 3 | 781µs | 2 | 13.2ms | # spent 13.0ms (633µs+12.4) within MARC::Charset::Table::BEGIN@40 which was called:
# once (633µs+12.4ms) by MARC::Charset::BEGIN@13 at line 40 # spent 13.0ms making 1 call to MARC::Charset::Table::BEGIN@40
# spent 164µs making 1 call to Exporter::import |
| 41 | |||||
| 42 | =head2 new() | ||||
| 43 | |||||
| - - | |||||
| 48 | sub new | ||||
| 49 | # spent 131µs (22+109) within MARC::Charset::Table::new which was called:
# once (22µs+109µs) by MARC::File::XML::BEGIN@10 at line 44 of MARC/Charset.pm | ||||
| 50 | 1 | 2µs | my $class = shift; | ||
| 51 | 1 | 9µs | my $self = bless {}, ref($class) || $class; | ||
| 52 | 1 | 4µs | 1 | 109µs | $self->_init(O_RDONLY); # spent 109µs making 1 call to MARC::Charset::Table::_init |
| 53 | 1 | 5µs | return $self; | ||
| 54 | } | ||||
| 55 | |||||
| 56 | |||||
| 57 | =head2 add_code() | ||||
| 58 | |||||
| - - | |||||
| 64 | sub add_code | ||||
| 65 | { | ||||
| 66 | my ($self, $code) = @_; | ||||
| 67 | |||||
| 68 | # the Code object is serialized | ||||
| 69 | my $frozen = freeze($code); | ||||
| 70 | |||||
| 71 | # to support lookup by marc8 and utf8 values we | ||||
| 72 | # stash away the rule in the db using two keys | ||||
| 73 | my $marc8_key = $code->marc8_hash_code(); | ||||
| 74 | my $utf8_key = $code->utf8_hash_code(); | ||||
| 75 | |||||
| 76 | # stash away the marc8 lookup key | ||||
| 77 | $self->{db}->{$marc8_key} = $frozen; | ||||
| 78 | |||||
| 79 | # stash away the utf8 lookup key (only if it's not already there!) | ||||
| 80 | # this means that the sets that appear in the xml file will have | ||||
| 81 | # precedence ascii/ansel | ||||
| 82 | $self->{db}->{$utf8_key} = $frozen unless exists $self->{db}->{$utf8_key}; | ||||
| 83 | } | ||||
| 84 | |||||
| 85 | |||||
| 86 | =head2 get_code() | ||||
| 87 | |||||
| - - | |||||
| 92 | sub get_code | ||||
| 93 | { | ||||
| 94 | my ($self, $key) = @_; | ||||
| 95 | my $db = $self->db(); | ||||
| 96 | my $frozen = $db->{$key}; | ||||
| 97 | return thaw($frozen) if $frozen; | ||||
| 98 | return undef; | ||||
| 99 | } | ||||
| 100 | |||||
| 101 | |||||
| 102 | =head2 lookup_by_marc8() | ||||
| 103 | |||||
| - - | |||||
| 112 | sub lookup_by_marc8 | ||||
| 113 | { | ||||
| 114 | my ($self, $charset, $marc8) = @_; | ||||
| 115 | $charset = BASIC_LATIN if $charset eq ASCII_DEFAULT; | ||||
| 116 | return $self->get_code(sprintf('%s:%s', $charset, $marc8)); | ||||
| 117 | } | ||||
| 118 | |||||
| 119 | |||||
| 120 | =head2 lookup_by_utf8() | ||||
| 121 | |||||
| - - | |||||
| 126 | sub lookup_by_utf8 | ||||
| 127 | { | ||||
| 128 | my ($self, $value) = @_; | ||||
| 129 | return $self->get_code(ord($value)); | ||||
| 130 | } | ||||
| 131 | |||||
| - - | |||||
| 135 | =head2 db() | ||||
| 136 | |||||
| - - | |||||
| 142 | sub db | ||||
| 143 | { | ||||
| 144 | return shift->{db}; | ||||
| 145 | } | ||||
| 146 | |||||
| 147 | |||||
| 148 | =head2 db_path() | ||||
| 149 | |||||
| - - | |||||
| 157 | sub db_path | ||||
| 158 | # spent 20µs (17+3) within MARC::Charset::Table::db_path which was called:
# once (17µs+3µs) by MARC::Charset::Table::_init at line 187 | ||||
| 159 | 1 | 2µs | my $path = $INC{'MARC/Charset/Table.pm'}; | ||
| 160 | 1 | 14µs | 1 | 3µs | $path =~ s/\.pm$//; # spent 3µs making 1 call to MARC::Charset::Table::CORE:subst |
| 161 | 1 | 7µs | return $path; | ||
| 162 | } | ||||
| 163 | |||||
| 164 | |||||
| 165 | =head2 brand_new() | ||||
| 166 | |||||
| - - | |||||
| 173 | sub brand_new | ||||
| 174 | { | ||||
| 175 | my $class = shift; | ||||
| 176 | my $self = bless {}, ref($class) || $class; | ||||
| 177 | $self->_init(O_CREAT|O_RDWR); | ||||
| 178 | return $self; | ||||
| 179 | } | ||||
| 180 | |||||
| 181 | |||||
| 182 | # helper function for initializing table internals | ||||
| 183 | |||||
| 184 | sub _init | ||||
| 185 | # spent 109µs (24+85) within MARC::Charset::Table::_init which was called:
# once (24µs+85µs) by MARC::Charset::Table::new at line 52 | ||||
| 186 | 1 | 1µs | my ($self,$opts) = @_; | ||
| 187 | 1 | 81µs | 2 | 85µs | tie my %db, 'SDBM_File', db_path(), $opts, 0644; # spent 65µs making 1 call to SDBM_File::TIEHASH
# spent 20µs making 1 call to MARC::Charset::Table::db_path |
| 188 | 1 | 7µs | $self->{db} = \%db; | ||
| 189 | } | ||||
| 190 | |||||
| - - | |||||
| 195 | 1 | 9µs | 1; | ||
# spent 3µs within MARC::Charset::Table::CORE:subst which was called:
# once (3µs+0s) by MARC::Charset::Table::db_path at line 160 |