From 9f45310d761c85167ff23d8cc217d513138a6ea5 Mon Sep 17 00:00:00 2001 From: Marcel de Rooy Date: Mon, 25 Nov 2013 14:24:42 +0100 Subject: [PATCH] Bug 11278: Followup for customize command line parameter The initial patch for this bug did not include a specific command line option for customization. If a module LocalChanges.pm existed, it would be used without asking. This patch adds a command line option enabling the customization option and offering the extra possibility of using another module name. If no file name is passed, we default to LocalChanges. Without the -custom option, behavior is as it was. Also some POD lines are added to document the feature. Test plan: [1] Make a LocalChanges.pm in migration_tools. Verify that it is not used, if you do not enable the -cust parameter. [2] Run the script again with -cust. Verify that it is called now. [3] Copy LocalChanges.pm to Whatever.pm. Make some change. Run with -cust Whatever and verify that the new module is used. [4] Copy Whatever.pm to another dir, make some change. Run with -cust and the full name. Verify that the latest change was used. [5] Run without any option. Check the pod documentation. Signed-off-by: Jonathan Druart Signed-off-by: Martin Renvoize Signed-off-by: Galen Charlton --- misc/migration_tools/bulkmarcimport.pl | 33 ++++++++++++++++++++++++++++----- 1 file changed, 28 insertions(+), 5 deletions(-) diff --git a/misc/migration_tools/bulkmarcimport.pl b/misc/migration_tools/bulkmarcimport.pl index 28753b315c..ff6987a629 100755 --- a/misc/migration_tools/bulkmarcimport.pl +++ b/misc/migration_tools/bulkmarcimport.pl @@ -31,11 +31,6 @@ use Getopt::Long; use IO::File; use Pod::Usage; -my $localcust= $FindBin::Bin.'/LocalChanges.pm'; -$localcust= -e $localcust? $localcust: undef; -require $localcust if $localcust; -$localcust=\&customize if $localcust; - use open qw( :std :encoding(UTF-8) ); binmode( STDOUT, ":encoding(UTF-8)" ); my ( $input_marc_file, $number, $offset) = ('',0,0); @@ -44,6 +39,7 @@ my ( $insert, $filters, $update, $all, $yamlfile, $authtypes, $append ); my $cleanisbn = 1; my ($sourcetag,$sourcesubfield,$idmapfl, $dedup_barcode); my $framework = ''; +my $localcust; $|=1; @@ -79,6 +75,7 @@ GetOptions( 'yaml:s' => \$yamlfile, 'dedupbarcode' => \$dedup_barcode, 'framework=s' => \$framework, + 'custom:s' => \$localcust, ); $biblios ||= !$authorities; $insert ||= !$update; @@ -94,6 +91,24 @@ if ($version || ($input_marc_file eq '')) { exit; } +if(defined $localcust) { #local customize module + if(!-e $localcust) { + $localcust= $localcust||'LocalChanges'; #default name + $localcust=~ s/^.*\/([^\/]+)$/$1/; #extract file name only + $localcust=~ s/\.pm$//; #remove extension + my $fqcust= $FindBin::Bin."/$localcust.pm"; #try migration_tools dir + if(-e $fqcust) { + $localcust= $fqcust; + } + else { + print "WARNING: customize module $localcust.pm not found!\n"; + exit; + } + } + require $localcust if $localcust; + $localcust=\&customize if $localcust; +} + my $dbh = C4::Context->dbh; my $heading_fields=get_heading_fields(); @@ -748,6 +763,14 @@ This is the code for the framework that the requested records will have attached to them when they are created. If not specified, then the default framework will be used. +=item B<-custom>=I + +This parameter allows you to use a local module with a customize subroutine +that is called for each MARC record. +If no filename is passed, LocalChanges.pm is assumed to be in the +migration_tools subdirectory. You may pass an absolute file name or a file name +from the migration_tools directory. + =back =cut -- 2.11.4.GIT