Win32 support: Adding a script to modify shebang lines per installation platfom.
[wip/koha-chris_n.git] / fix-perl-path.PL
1 #!c:\strawberry-perl\perl\bin\perl
2 # This file is part of Koha.
3 #
4 # Koha is free software; you can redistribute it and/or modify it under the
5 # terms of the GNU General Public License as published by the Free Software
6 # Foundation; either version 2 of the License, or (at your option) any later
7 # version.
8 #
9 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
10 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
11 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
12 #
13 # You should have received a copy of the GNU General Public License along with
14 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
15 # Suite 330, Boston, MA  02111-1307 USA
16 #
17
18 use strict;
19 use ExtUtils::MakeMaker::Config;
20 use Tie::File;
21
22 my $basedir = (shift);
23 my $DEBUG = 1;
24
25 $DEBUG = 1 if $basedir eq 'test';
26
27 my $bindir = $Config{installbin};
28 $bindir =~ s!\\!/!g;    # make all directory separators uniform...
29 my $shebang = "#!$bindir\/perl -w";
30
31 warn "Perl binary located in $bindir on this system.\n" if $DEBUG;
32 warn "The shebang line for this sytems should be $shebang\n\n" if $DEBUG;
33
34 die if $basedir eq 'test';
35
36 =head1 NAME
37
38 fix-perl-path.PL - A script to correct the shebang line to match the current platform
39
40 =head1 SYNOPSIS
41
42 =head2 BASIC USAGE
43
44     perl fix-perl-path.PL /absolute/path/to/foo
45
46 =head1 DESCRIPTION
47
48 This script should be run from the base of the directory
49 structure which contains the file(s) that need the
50 shebang line corrected. It will recurse through all
51 directories below the one called from and modify all
52 .pl files.
53
54 =head2 fixshebang
55
56 This sub will recurse through a given directory and its subdirectories checking for the existence of a shebang
57 line in .pl files and replacing it with the correct line for the current OS if needed. It should be called
58 in a manner similar to 'fixshebang (foodir)' but may be supplied with any directory.
59
60 =cut
61
62 sub fixshebang{
63         # NOTE: this might be dressed up a bit with File::Spec since we're using it here already.
64         my $dir = shift;
65     opendir my $dh, $dir or die $!;
66         warn "Reading $dir contents.\n" if $DEBUG;
67     while( my $file = readdir($dh) ) {
68                 # this may be used to exclude any desired files from the scan
69                 if ( $file =~ /shebang|wixgen/ ) { next; }
70                 # handle files... other extensions could be substituted/added if needed
71                 if ( $file =~ /\.pl$/ ) {
72             my @filearray;
73                         my $pathfile =$dir . '/' . $file;
74                         warn "Found a perl script named $pathfile\n" if $DEBUG;
75             tie @filearray, 'Tie::File', $pathfile or die $!;
76             print "First line of $file is $filearray[0]\n\n";
77                         if ( ( $filearray[0] =~ /#!.*perl/ ) && ( $filearray[0] !~ /$shebang/ ) ) {
78                                 warn "\n\tRe-writing shebang line for $pathfile\n" if $DEBUG;
79                 warn "\tOriginal shebang line: $filearray[0]\n" if $DEBUG;
80                 $filearray[0] = $shebang;
81                 warn "\tNew shebang line is: $filearray[0]\n\n" if $DEBUG;
82                 untie @filearray;
83                 next;
84                         }
85             elsif ( $filearray[0] =~ /$shebang/ ) {
86                 warn "\n\tShebang line is correct.\n\n" if $DEBUG;
87                 untie @filearray;
88                 next;
89             }
90                         else {
91                 warn "\n\tNo shebang line found in $pathfile\n\n" if $DEBUG;
92                 untie @filearray;
93                                 next;
94                         }
95                 }
96                 # handle directories
97                 elsif ( -d ($dir . '/' . $file) && $file !~ /^\.{1,2}/ ) {
98                         my $dirpath = $dir . '/' . $file;
99                         warn "Found a subdir named $dirpath\n" if $DEBUG;
100                         fixshebang ($dirpath);
101 #                       closedir $dh;   # I'm not really sure if this is necessary
102                 }
103         }
104         closedir $dh;
105 }
106
107 fixshebang ($basedir);
108
109