BEGIN {
use Exporter ();
use vars qw ($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
- $VERSION = 0.21;
+ $VERSION = 0.22_1;
@ISA = qw (Exporter);
#Give a hoot don't pollute, do not export more than needed by default
@EXPORT = qw ();
my $hash = $isis->to_hash({
mfn => 42,
include_subfields => 1,
+ regexps => [
+ 's/something/else/g',
+ ],
});
Each option controll creation of hash:
$mfn = $arg->{mfn} || confess "need mfn in arguments";
}
+ 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 ] };
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});
+ }
+
my $val;
my $r_sf; # repeatable subfields in this record
use strict;
use blib;
-use Test::More tests => 134;
+use Test::More tests => 136;
use File::Spec;
BEGIN {
],
902 => [{ a => "a1 ; a2 ; a3 ; a4 ; a5", b => "b1 ; b2", c => "c1" }],
}, 'hash is_deeply');
+
+# split_on_delimiters
+
+$isis->{record} = {
+ 900 => [ '^a900a : 900b ; 900c' ],
+ 901 => [
+ '^a901a-1 x 901b-1 y 901c-1',
+ '^b901b-2 x 901b-2',
+ '^c901c-3 y 901c-3',
+ ],
+};
+
+my $split_on_delimiters = {
+ 900 => { a => { ' : ' => 'b', ' ; ' => 'c' } },
+ 901 => {
+ a => { ' x ' => 'b', ' y ' => 'c' },
+ b => { ' x ' => 'b' },
+ c => { ' y ' => 'c' }
+ },
+};
+
+diag "split_on_delimiters = ", Dumper($split_on_delimiters);
+
+my $regexpes;
+
+foreach my $f (keys %$split_on_delimiters) {
+warn "--- f: $f\n";
+ foreach my $sf (keys %{ $split_on_delimiters->{$f} }) {
+warn "---- sf: $sf\n";
+ foreach my $patt (keys %{ $split_on_delimiters->{$f}->{$sf} }) {
+ my $new_sf = $split_on_delimiters->{$f}->{$sf}->{$patt} || die "no field?";
+warn "----- patt: $patt -> $new_sf\n";
+
+ # fool-proof spaces in pattern
+ $patt =~ s/\s+/\\s\+/g;
+
+ push @{ $regexpes->{$f} },
+ 's/\^' . $sf . '([^\^]+)' . $patt . '([^\^]+)/^' . $sf . '$1^' . $new_sf . '$2/g';
+ }
+ }
+}
+
+diag "generated regexpes = ", Dumper( $regexpes );
+
+
+ok($hash = $isis->to_hash({ mfn => $isis->mfn, regexps => $regexpes, }), 'to_hash(mfn,regexpes)');
+diag "to_hash = ",Dumper( $hash ) if ($debug);
+is_deeply( $hash, {
+ "000" => [42],
+ 900 => [{ a => "900a", b => "900b", c => "900c" }],
+ 901 => [
+ { a => "901a-1", b => "901b-1", c => "901c-1" },
+ { b => ["901b-2", "901b-2"] },
+ { c => ["901c-3", "901c-3"] },
+ ],
+}, 'hash is_deeply');