X-Git-Url: https://git.openssl.org/gitweb/?p=openssl.git;a=blobdiff_plain;f=util%2Fmklink.pl;h=61db12c68f3156475f4f44e2dde2e01d8be001ee;hp=9f4892559ea181eaa3ec8bf7b3ff795b0e00166b;hb=5219d3dd350cc74498dd49daef5e6ee8c34d9857;hpb=065e106f25b670586c9fb955beba87f4b456c940 diff --git a/util/mklink.pl b/util/mklink.pl index 9f4892559e..61db12c68f 100755 --- a/util/mklink.pl +++ b/util/mklink.pl @@ -1,30 +1,34 @@ #!/usr/local/bin/perl -# mklink.pl -- a faster substitute for mklink.sh. +# mklink.pl # The first command line argument is a non-empty relative path # specifying the "from" directory. -# Each other argument is a file name not containing / and names -# a file in the current directory. +# Each other argument is a file name not containing / and +# names a file in the current directory. # # For each of these files, we create in the "from" directory a link # of the same name pointing to the local file. # -# We assume that the directory structure is a tree, i.e. that does not -# contain symbolic links and that the parent of / is never referenced. +# We assume that the directory structure is a tree, i.e. that it does +# not contain symbolic links and that the parent of / is never referenced. # Apart from this, this script should be able to handle even the most # pathological cases. +use Cwd; + my $from = shift; my @files = @ARGV; -my @from_path = split(/\//, $from); -my $pwd = `pwd`; -chop($pwd); -my @pwd_path = split(/\//, $pwd); +my @from_path = split(/[\\\/]/, $from); +my $pwd = getcwd(); +chomp($pwd); +my @pwd_path = split(/[\\\/]/, $pwd); my @to_path = (); -foreach my $dirname (@from_path) { + +my $dirname; +foreach $dirname (@from_path) { # In this loop, @to_path always is a relative path from # @pwd_path (interpreted is an absolute path) to the original pwd. @@ -45,8 +49,25 @@ foreach my $dirname (@from_path) { my $to = join('/', @to_path); -foreach my $file (@files) { -# print "ln -s $to/$file $from/$file\n"; - symlink("$to/$file", "$from/$file"); - print $file . " => $from/$file\n"; +my $file; +$symlink_exists=eval {symlink("",""); 1}; +if ($^O eq "msys") { $symlink_exists=0 }; +foreach $file (@files) { + my $err = ""; + if ($symlink_exists) { + unlink "$from/$file"; + symlink("$to/$file", "$from/$file") or $err = " [$!]"; + } else { + unlink "$from/$file"; + open (OLD, "<$file") or die "Can't open $file: $!"; + open (NEW, ">$from/$file") or die "Can't open $from/$file: $!"; + binmode(OLD); + binmode(NEW); + while () { + print NEW $_; + } + close (OLD) or die "Can't close $file: $!"; + close (NEW) or die "Can't close $from/$file: $!"; + } + print $file . " => $from/$file$err\n"; }