--- trunk/lib/Biblio/Isis.pm 2006/07/09 21:36:33 61 +++ trunk/lib/Biblio/Isis.pm 2006/08/25 10:20:58 66 @@ -7,7 +7,7 @@ BEGIN { use Exporter (); use vars qw ($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS); - $VERSION = 0.22_1; + $VERSION = 0.23; @ISA = qw (Exporter); #Give a hoot don't pollute, do not export more than needed by default @EXPORT = qw (); @@ -84,7 +84,7 @@ read_fdt => 1, include_deleted => 1, hash_filter => sub { - my $v = shift; + my ($v,$field_number) = @_; $v =~ s#foo#bar#g; }, debug => 1, @@ -114,7 +114,9 @@ =item hash_filter -Filter code ref which will be used before data is converted to hash. +Filter code ref which will be used before data is converted to hash. It will +receive two arguments, whole line from current field (in C<< $_[0] >>) and +field number (in C<< $_[1] >>). =item debug @@ -519,9 +521,6 @@ my $hash = $isis->to_hash({ mfn => 42, include_subfields => 1, - regexps => [ - 's/something/else/g', - ], }); Each option controll creation of hash: @@ -549,6 +548,10 @@ Define delimiter which will be used to join repeatable subfields. You can specify option here instead in L if you want to have per-record control. +=item hash_filter + +You can override C defined in L using this option. + =back =cut @@ -560,13 +563,14 @@ my $mfn = shift || confess "need mfn!"; my $arg; + my $hash_filter = $self->{hash_filter}; + if (ref($mfn) eq 'HASH') { $arg = $mfn; $mfn = $arg->{mfn} || confess "need mfn in arguments"; + $hash_filter = $arg->{hash_filter} if ($arg->{hash_filter}); } - confess "regexps must be HASH" if ($arg->{regexps} && ref($arg->{regexps}) ne 'HASH'); - # init record to include MFN as field 000 my $rec = { '000' => [ $mfn ] }; @@ -580,20 +584,8 @@ foreach my $l (@{$row->{$f_nr}}) { # filter output - if ($self->{'hash_filter'}) { - $l = $self->{'hash_filter'}->($l); - next unless defined($l); - } - - # apply regexps - if ($arg->{regexps} && defined($arg->{regexps}->{$f_nr})) { - confess "regexps->{$f_nr} must be ARRAY" if (ref($arg->{regexps}->{$f_nr}) ne 'ARRAY'); - my $c = 0; - foreach my $r (@{ $arg->{regexps}->{$f_nr} }) { - while ( eval '$l =~ ' . $r ) { $c++ }; - } - warn "## field $f_nr triggered $c regexpes\n" if ($c && $self->{debug}); - } + $l = $hash_filter->($l, $f_nr) if ($hash_filter); + next unless defined($l); my $val; my $r_sf; # repeatable subfields in this record @@ -759,13 +751,21 @@ As this is young module, new features are added in subsequent version. It's a good idea to specify version when using this module like this: - use Biblio::Isis 0.21 + use Biblio::Isis 0.23 Below is list of changes in specific version of module (so you can target older versions if you really have to): =over 8 +=item 0.23 + +Added C to L + +=item 0.22 + +Added field number when calling C + =item 0.21 Added C to L and L.