X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=util%2Fmklink.pl;h=eacc32788264f5c3fcbfe7cfa9935ba6df363c02;hb=d73ed541db07ca273335341ba3cc8aad86f91d15;hp=d7b997ada72371edeac5009405c0d652b0038840;hpb=9ef876f2697d2a01fcce5cda6f0b0f80493b2bdd;p=oweals%2Fopenssl.git diff --git a/util/mklink.pl b/util/mklink.pl index d7b997ada7..eacc327882 100755 --- a/util/mklink.pl +++ b/util/mklink.pl @@ -15,13 +15,23 @@ # Apart from this, this script should be able to handle even the most # pathological cases. +my $pwd; +eval 'use Cwd;'; +if ($@) + { + $pwd = `pwd`; + } +else + { + $pwd = getcwd(); + } + 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); +chomp($pwd); +my @pwd_path = split(/[\\\/]/, $pwd); my @to_path = (); @@ -48,8 +58,23 @@ foreach $dirname (@from_path) { my $to = join('/', @to_path); my $file; +$symlink_exists=eval {symlink("",""); 1}; foreach $file (@files) { my $err = ""; - symlink("$to/$file", "$from/$file") or $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"; }