diff options
author | Peter Hessler <phessler@cvs.openbsd.org> | 2014-01-12 20:23:30 +0000 |
---|---|---|
committer | Peter Hessler <phessler@cvs.openbsd.org> | 2014-01-12 20:23:30 +0000 |
commit | 63299cfd7b1199287f561c8b0d60da94719bb4ba (patch) | |
tree | 9c7fc2be1ce73a5f0f8bf2bac59ce99be1983331 /usr.sbin/pkg_add | |
parent | 5820e166dcb48276e7af121c677bbd43c69942ba (diff) |
revert back to 1.97
There is a memory leak when using internal GZip, so switch back to the
external gzip for now.
OK espie@
Diffstat (limited to 'usr.sbin/pkg_add')
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/PackageRepository.pm | 60 |
1 files changed, 51 insertions, 9 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm b/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm index b3b88f066d1..7f93754d5ac 100644 --- a/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm +++ b/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm @@ -1,7 +1,7 @@ # ex:ts=8 sw=4: -# $OpenBSD: PackageRepository.pm,v 1.100 2014/01/09 20:20:01 espie Exp $ +# $OpenBSD: PackageRepository.pm,v 1.101 2014/01/12 20:23:29 phessler Exp $ # -# Copyright (c) 2003-2014 Marc Espie <espie@openbsd.org> +# Copyright (c) 2003-2010 Marc Espie <espie@openbsd.org> # # Permission to use, copy, modify, and distribute this software for any # purpose with or without fee is hereby granted, provided that the above @@ -296,11 +296,17 @@ sub did_it_fork } } -sub uncompress +sub exec_gunzip { my $self = shift; - require IO::Uncompress::Gunzip; - return IO::Uncompress::Gunzip->new(@_, MultiStream => 1); + $ENV{LC_ALL} = 'C'; + exec {OpenBSD::Paths->gzip} + ("gzip", + "-d", + "-c", + "-q", + @_) + or $self->{state}->fatal("Can't run gzip: #1", $!); } package OpenBSD::PackageRepository::Local; @@ -363,7 +369,14 @@ sub open_pipe if (defined $ENV{'PKG_CACHE'}) { $self->may_copy($object, $ENV{'PKG_CACHE'}); } - return $self->uncompress($self->relative_url($object->{name})); + my $pid = open(my $fh, "-|"); + $self->did_it_fork($pid); + if ($pid) { + return $fh; + } else { + open STDERR, ">/dev/null"; + $self->exec_gunzip("-f", $self->relative_url($object->{name})); + } } sub may_exist @@ -413,7 +426,14 @@ sub new sub open_pipe { my ($self, $object) = @_; - return $self->uncompress(\*STDIN); + my $pid = open(my $fh, "-|"); + $self->did_it_fork($pid); + if ($pid) { + return $fh; + } else { + open STDERR, ">/dev/null"; + $self->exec_gunzip("-f", "-"); + } } package OpenBSD::PackageRepository::Distant; @@ -512,12 +532,32 @@ sub open_pipe $object->{cache_dir} = $ENV{'PKG_CACHE'}; $object->{parent} = $$; - my $pid2 = open(my $rdfh, "-|"); + my ($rdfh, $wrfh); + pipe($rdfh, $wrfh); + + my $pid = open(my $fh, "-|"); + $self->did_it_fork($pid); + if ($pid) { + $object->{pid} = $pid; + } else { + open(STDIN, '<&', $rdfh) or + $self->{state}->fatal("Bad dup: #1", $!); + close($rdfh); + close($wrfh); + $self->exec_gunzip("-f", "-"); + } + my $pid2 = fork(); + $self->did_it_fork($pid2); if ($pid2) { $object->{pid2} = $pid2; } else { open STDERR, '>', $object->{errors}; + open(STDOUT, '>&', $wrfh) or + $self->{state}->fatal("Bad dup: #1", $!); + close($rdfh); + close($wrfh); + close($fh); if (defined $object->{cache_dir}) { my $pid3 = open(my $in, "-|"); $self->did_it_fork($pid3); @@ -531,7 +571,9 @@ sub open_pipe } exit(0); } - return $self->uncompress($rdfh); + close($rdfh); + close($wrfh); + return $fh; } sub finish_and_close |