7 |
|
|
8 |
use WebPAC::Common; |
use WebPAC::Common; |
9 |
use base qw/WebPAC::Common/; |
use base qw/WebPAC::Common/; |
10 |
use Data::Dumper; |
use Data::Dump qw/dump/; |
11 |
use Encode qw/from_to/; |
use Encode qw/from_to/; |
12 |
|
|
13 |
=head1 NAME |
=head1 NAME |
16 |
|
|
17 |
=head1 VERSION |
=head1 VERSION |
18 |
|
|
19 |
Version 0.14 |
Version 0.15 |
20 |
|
|
21 |
=cut |
=cut |
22 |
|
|
23 |
our $VERSION = '0.14'; |
our $VERSION = '0.15'; |
24 |
|
|
25 |
=head1 SYNOPSIS |
=head1 SYNOPSIS |
26 |
|
|
102 |
|
|
103 |
require $module_path; |
require $module_path; |
104 |
|
|
|
# check if required subclasses are implemented |
|
|
foreach my $subclass (qw/open_db fetch_rec init dump_rec/) { |
|
|
# FIXME |
|
|
} |
|
|
|
|
105 |
$self->{'encoding'} ||= 'ISO-8859-2'; |
$self->{'encoding'} ||= 'ISO-8859-2'; |
106 |
|
|
107 |
$self ? return $self : return undef; |
$self ? return $self : return undef; |
224 |
$log->debug("using modify_file $p"); |
$log->debug("using modify_file $p"); |
225 |
$rec_regex = $self->modify_file_regexps( $p ); |
$rec_regex = $self->modify_file_regexps( $p ); |
226 |
} elsif (my $h = $arg->{modify_records}) { |
} elsif (my $h = $arg->{modify_records}) { |
227 |
$log->debug("using modify_records ", Dumper( $h )); |
$log->debug("using modify_records ", sub { dump( $h ) }); |
228 |
$rec_regex = $self->modify_record_regexps(%{ $h }); |
$rec_regex = $self->modify_record_regexps(%{ $h }); |
229 |
} |
} |
230 |
$log->debug("rec_regex: ", Dumper($rec_regex)) if ($rec_regex); |
$log->debug("rec_regex: ", sub { dump($rec_regex) }) if ($rec_regex); |
231 |
|
|
232 |
my $class = $self->{module} || $log->logconfess("can't get low-level module name!"); |
my $class = $self->{module} || $log->logconfess("can't get low-level module name!"); |
233 |
|
|
310 |
return $l; |
return $l; |
311 |
}); |
}); |
312 |
|
|
313 |
$log->debug(sub { Dumper($rec) }); |
$log->debug(sub { dump($rec) }); |
314 |
|
|
315 |
if (! $rec) { |
if (! $rec) { |
316 |
$log->warn("record $pos empty? skipping..."); |
$log->warn("record $pos empty? skipping..."); |
530 |
} sort { $a cmp $b } keys %{ $s->{fld} } |
} sort { $a cmp $b } keys %{ $s->{fld} } |
531 |
); |
); |
532 |
|
|
533 |
$log->debug( sub { Dumper($s) } ); |
$log->debug( sub { dump($s) } ); |
534 |
|
|
535 |
return $out; |
return $out; |
536 |
} |
} |
544 |
sub dump { |
sub dump { |
545 |
my $self = shift; |
my $self = shift; |
546 |
|
|
547 |
return $self->{ll_db}->dump_rec( $self->{pos} ); |
return unless $self->{ll_db}; |
548 |
|
|
549 |
|
if ($self->{ll_db}->can('dump_rec')) { |
550 |
|
return $self->{ll_db}->dump_rec( $self->{pos} ); |
551 |
|
} else { |
552 |
|
return dump( $self->{ll_db}->fetch_rec( $self->{pos} ) ); |
553 |
|
} |
554 |
} |
} |
555 |
|
|
556 |
=head2 modify_record_regexps |
=head2 modify_record_regexps |