summaryrefslogtreecommitdiff
path: root/usr.sbin
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/pkg_add/OpenBSD/PackageRepository.pm25
1 files changed, 23 insertions, 2 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm b/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm
index d8fdcff5e21..ee9345b84e0 100644
--- a/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm
+++ b/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: PackageRepository.pm,v 1.60 2008/10/25 22:28:42 bernd Exp $
+# $OpenBSD: PackageRepository.pm,v 1.61 2008/12/11 15:43:19 espie Exp $
#
# Copyright (c) 2003-2007 Marc Espie <espie@openbsd.org>
#
@@ -280,11 +280,32 @@ sub parse_fullurl
return $class->parse_local_url($r);
}
+# wrapper around copy, that sometimes does not copy
+sub may_copy
+{
+ my ($self, $object, $destdir) = @_;
+ my $src = $self->relative_url($object->{name});
+ require File::Spec;
+ my (undef, undef, $base) = File::Spec->splitpath($src);
+ my $dest = File::Spec->catfile($destdir, $base);
+ if (File::Spec->canonpath($dest) eq File::Spec->canonpath($src)) {
+ return;
+ }
+ if (-f $dest) {
+ my ($ddev, $dino) = (stat $dest)[0,1];
+ my ($sdev, $sino) = (stat $src)[0, 1];
+ if ($ddev == $sdev and $sino == $dino) {
+ return;
+ }
+ }
+ Copy($src, $destdir);
+}
+
sub open_pipe
{
my ($self, $object) = @_;
if (defined $ENV{'PKG_CACHE'}) {
- Copy($self->relative_url($object->{name}), $ENV{'PKG_CACHE'});
+ $self->may_copy($object, $ENV{'PKG_CACHE'});
}
my $pid = open(my $fh, "-|");
if (!defined $pid) {