/[webpac2]/trunk/lib/WebPAC/Input.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /trunk/lib/WebPAC/Input.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 818 by dpavlin, Thu Apr 5 21:53:52 2007 UTC revision 910 by dpavlin, Tue Oct 30 01:51:20 2007 UTC
# Line 16  WebPAC::Input - read different file form Line 16  WebPAC::Input - read different file form
16    
17  =head1 VERSION  =head1 VERSION
18    
19  Version 0.17  Version 0.18
20    
21  =cut  =cut
22    
23  our $VERSION = '0.17';  our $VERSION = '0.18';
24    
25  =head1 SYNOPSIS  =head1 SYNOPSIS
26    
# Line 64  Create new input database object. Line 64  Create new input database object.
64          encoding => 'ISO-8859-2',          encoding => 'ISO-8859-2',
65          recode => 'char pairs',          recode => 'char pairs',
66          no_progress_bar => 1,          no_progress_bar => 1,
67            input_config => {
68                    mapping => [ 'foo', 'bar', 'baz' ],
69            },
70    );    );
71    
72  C<module> is low-level file format module. See L<WebPAC::Input::ISIS> and  C<module> is low-level file format module. See L<WebPAC::Input::ISIS> and
# Line 233  sub open { Line 236  sub open {
236    
237          my $ll_db = $class->new(          my $ll_db = $class->new(
238                  path => $arg->{path},                  path => $arg->{path},
239                    input_config => $arg->{input_config} || $self->{input_config},
240  #               filter => sub {  #               filter => sub {
241  #                       my ($l,$f_nr) = @_;  #                       my ($l,$f_nr) = @_;
242  #                       return unless defined($l);  #                       return unless defined($l);
# Line 519  sub stats { Line 523  sub stats {
523    
524          my $out = join("\n",          my $out = join("\n",
525                  map {                  map {
526                          my $f = $_ || die "no field";                          my $f = $_;
527                            die "no field in ", dump( $s->{fld} ) unless defined( $f );
528                          my $v = $s->{fld}->{$f} || die "no s->{fld}->{$f}";                          my $v = $s->{fld}->{$f} || die "no s->{fld}->{$f}";
529                          $max_fld = $v if ($v > $max_fld);                          $max_fld = $v if ($v > $max_fld);
530    
531                          my $o = sprintf("%4s %d ~", $f, $v);                          my $o = sprintf("%4s %d ~", $f, $v);
532    
533                          if (defined($s->{sf}->{$f})) {                          if (defined($s->{sf}->{$f})) {
534                                    my @subfields = keys %{ $s->{sf}->{$f} };
535                                  map {                                  map {
536                                          $o .= sprintf(" %s:%d%s", $_,                                          $o .= sprintf(" %s:%d%s", $_,
537                                                  $s->{sf}->{$f}->{$_}->{count},                                                  $s->{sf}->{$f}->{$_}->{count},
538                                                  $s->{sf}->{$f}->{$_}->{repeatable} ? '*' : '',                                                  $s->{sf}->{$f}->{$_}->{repeatable} ? '*' : '',
539                                          );                                          );
540                                  } sort keys %{ $s->{sf}->{$f} };                                  } (
541                                            # first indicators and other special subfields
542                                            sort( grep { length($_)  > 1 } @subfields ),
543                                            # then subfileds (single char)
544                                            sort( grep { length($_) == 1 } @subfields ),
545                                    );
546                          }                          }
547    
548                          if (my $v_r = $s->{repeatable}->{$f}) {                          if (my $v_r = $s->{repeatable}->{$f}) {
# Line 539  sub stats { Line 550  sub stats {
550                          }                          }
551    
552                          $o;                          $o;
553                  } sort { $a cmp $b } keys %{ $s->{fld} }                  } sort { $a <=> $b } keys %{ $s->{fld} }
554          );          );
555    
556          $log->debug( sub { dump($s) } );          $log->debug( sub { dump($s) } );
# Line 558  sub dump_ascii { Line 569  sub dump_ascii {
569    
570          return unless $self->{ll_db};          return unless $self->{ll_db};
571    
572          if ($self->{ll_db}->can('dump_rec')) {          if ($self->{ll_db}->can('dump_ascii')) {
573                  return $self->{ll_db}->dump_ascii( $self->{pos} );                  return $self->{ll_db}->dump_ascii( $self->{pos} );
574          } else {          } else {
575                  return dump( $self->{ll_db}->fetch_rec( $self->{pos} ) );                  return dump( $self->{ll_db}->fetch_rec( $self->{pos} ) );
576          }          }
577  }  }
578    
579  =head2 modify_record_regexps  =head2 _get_regex
580    
581  Generate hash with regexpes to be applied using L<filter>.  Helper function called which create regexps to be execute on code.
582    
583    my $regexpes = $input->modify_record_regexps(    _get_regex( 900, 'regex:[0-9]+' ,'numbers' );
584                  900 => { '^a' => { ' : ' => '^b' } },    _get_regex( 900, '^b', ' : ^b' );
585                  901 => { '*' => { '^b' => ' ; ' } },  
586    );  It supports perl regexps with C<regex:> prefix to from value and has
587    additional logic to skip empty subfields.
588    
589  =cut  =cut
590    
# Line 589  sub _get_regex { Line 601  sub _get_regex {
601                  $from = '\Q' . $from . '\E';                  $from = '\Q' . $from . '\E';
602          }          }
603          if ($sf =~ /^\^/) {          if ($sf =~ /^\^/) {
604                    my $need_subfield_data = '*';   # no
605                    # if from is also subfield, require some data in between
606                    # to correctly skip empty subfields
607                    $need_subfield_data = '+' if ($from =~ m/^\\Q\^/);
608                  return                  return
609                          's/\Q'. $sf .'\E([^\^]*?)'. $from .'([^\^]*?)/'. $sf .'$1'. $to .'$2/';                          's/\Q'. $sf .'\E([^\^]' . $need_subfield_data . '?)'. $from .'([^\^]*?)/'. $sf .'$1'. $to .'$2/';
610          } else {          } else {
611                  return                  return
612                          's/'. $from .'/'. $to .'/g';                          's/'. $from .'/'. $to .'/g';
613          }          }
614  }  }
615    
616    
617    =head2 modify_record_regexps
618    
619    Generate hash with regexpes to be applied using L<filter>.
620    
621      my $regexpes = $input->modify_record_regexps(
622                    900 => { '^a' => { ' : ' => '^b' } },
623                    901 => { '*' => { '^b' => ' ; ' } },
624      );
625    
626    =cut
627    
628  sub modify_record_regexps {  sub modify_record_regexps {
629          my $self = shift;          my $self = shift;
630          my $modify_record = {@_};          my $modify_record = {@_};

Legend:
Removed from v.818  
changed lines
  Added in v.910

  ViewVC Help
Powered by ViewVC 1.1.26