--- trunk/run.pl 2007/05/24 10:53:48 834 +++ trunk/run.pl 2007/05/27 16:00:26 856 @@ -68,6 +68,14 @@ turn on extra validation of imput records, see L +You can use special variables C<$database> and $C<$input> in this parametar +like C<--validate 'conf/validate/$database-$input'> to construct filename + +=item --validate-delimiters path/to/validate_delimiters_file + +this option is used with C<--validate> to turn on extra validation of +delimiters. If file is non existant, it will be created on first run. + =item --marc-generate Generate MARC file. This will automatically be on if file contains C directives. @@ -108,6 +116,7 @@ my $only_filter; my $stats = 0; my $validate_path; +my $validate_delimiters_path; my $marc_generate = 1; my $marc_lint = 1; my $marc_dump = 0; @@ -128,6 +137,7 @@ "debug+" => \$debug, "stats" => \$stats, "validate=s" => \$validate_path, + "validate-delimiters=s" => \$validate_delimiters_path, "marc-generate!" => \$marc_generate, "marc-lint!" => \$marc_lint, "marc-dump!" => \$marc_dump, @@ -137,6 +147,8 @@ "help" => \$help, ); +$marc_generate = 0 if ( $validate_delimiters_path ); + pod2usage(-verbose => 2) if ($help); my $config = new WebPAC::Config( path => $config_path ); @@ -163,13 +175,12 @@ $log->info("created merge batch file $estcmd_path"); } - my $validate; $validate = new WebPAC::Validate( path => $validate_path, delimiters => $config->webpac('delimiters'), -) if ($validate_path); - + delimiters_path => $validate_delimiters_path, +) if ($validate_path || $validate_delimiters_path); my $use_indexer = $config->use_indexer; $stats ||= $validate; @@ -562,7 +573,10 @@ print $report_fh "$errors\n" if ($report_fh); } - print $report_fh "\nAll possible subfields/delimiter templates:\n", $validate->delimiters_templates( report => 1 ), "\n\n"; + print $report_fh "\nAll possible subfields/delimiter templates:\n", $validate->delimiters_templates( report => 1, current_input => 1 ), "\n\n"; + + # must be last thing that touches $validate for this input + $validate->reset; } if ($stats) { @@ -575,8 +589,7 @@ $marc->finish if ($marc); # close report - close($report_fh) if ($report_fh) - + close($report_fh) if ($report_fh); } eval { $indexer->finish } if ($indexer && $indexer->can('finish')); @@ -603,6 +616,9 @@ $log->info("all parallel processes finished"); } +# save new delimiters if needed +$validate->save_delimiters_templates if ( $validate ); + # # handle links or merge after indexing #