diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2008-07-04 10:47:14 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2008-07-04 10:47:14 +0000 |
commit | b3753a2ee5b621168a705031b4255daedf3be6f3 (patch) | |
tree | 0b72b5fa588cc831c604681eb55abad461aa4c12 /usr.sbin/pkg_add/OpenBSD/PackageRepository.pm | |
parent | f77f243a8feb8c249af9b216cdd159a45d30cd27 (diff) |
clean up parser a bit, separating local/distant parts in a more reusable way,
and simplify file: parsing scheme (trying it with file:, then without is
a bit stupid once we have the pieces to put it back together directly).
Drop the restriction on urls from the man page, no need to finish stuff with /.
Diffstat (limited to 'usr.sbin/pkg_add/OpenBSD/PackageRepository.pm')
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/PackageRepository.pm | 116 |
1 files changed, 73 insertions, 43 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm b/usr.sbin/pkg_add/OpenBSD/PackageRepository.pm index 819c41e8849..e4ef299c719 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.57 2008/07/03 18:45:51 sturm Exp $ +# $OpenBSD: PackageRepository.pm,v 1.58 2008/07/04 10:47:13 espie Exp $ # # Copyright (c) 2003-2007 Marc Espie <espie@openbsd.org> # @@ -41,11 +41,7 @@ sub baseurl { my $self = shift; - if (defined $self->{host}) { - return "//$self->{host}/$self->{path}"; - } else { - return $self->{path}; - } + return $self->{path}; } sub new @@ -55,37 +51,46 @@ sub new return $o; } -sub _parse +sub strip_urlscheme { my ($class, $r) = @_; if ($$r =~ m/^(.*?)\:(.*)$/) { my $scheme = lc($1); - if ($scheme ne $class->urlscheme) { - return undef; + if ($scheme eq $class->urlscheme) { + $$r = $2; + return 1; } + } + return 0; +} + +sub parse_local_url +{ + my ($class, $r, @args) = @_; + + my $o; + + if ($$r =~ m/^(.*?)\:(.*)/) { + $o = $class->_new($1, @args); $$r = $2; - my $o; - # use similar heuristics as ftp - if ($$r =~ m/^\/\/(.*?)(\/.*)$/) { - my $host = $1; - $$r = $2; - if ($$r =~ m/^(.*?)\:(.*)$/) { - $o = $class->_new($1, $host); - $$r = $2; - } else { - $o = $class->_new($$r, $host); - $$r = ''; - } - } elsif ($$r =~ m/^(.*?)\:(.*)/) { # no /, split on : - $o = $class->_new($1); - $$r = $2; - } else { - $o = $class->_new($$r); - $$r = ''; - } - return $o; + } else { + $o = $class->_new($$r, @args); + $$r = ''; } - return undef; + return $o; +} + +sub parse_url +{ + &parse_local_url; +} + +sub parse_fullurl +{ + my ($class, $r) = @_; + + $class->strip_urlscheme($r) or return undef; + return $class->parse_url($r); } sub parse @@ -95,25 +100,25 @@ sub parse return undef if $_ eq ''; if (m/^ftp\:/io) { - return OpenBSD::PackageRepository::FTP->_parse($ref); + return OpenBSD::PackageRepository::FTP->parse_fullurl($ref); } elsif (m/^http\:/io) { - return OpenBSD::PackageRepository::HTTP->_parse($ref); + return OpenBSD::PackageRepository::HTTP->parse_fullurl($ref); } elsif (m/^https\:/io) { - return OpenBSD::PackageRepository::HTTPS->_parse($ref); + return OpenBSD::PackageRepository::HTTPS->parse_fullurl($ref); } elsif (m/^scp\:/io) { require OpenBSD::PackageRepository::SCP; - return OpenBSD::PackageRepository::SCP->_parse($ref); + return OpenBSD::PackageRepository::SCP->parse_fullurl($ref); } elsif (m/^src\:/io) { require OpenBSD::PackageRepository::Source; - return OpenBSD::PackageRepository::Source->_parse($ref); + return OpenBSD::PackageRepository::Source->parse_fullurl($ref); } elsif (m/^file\:/io) { - return OpenBSD::PackageRepository::Local->_parse($ref); + return OpenBSD::PackageRepository::Local->parse_fullurl($ref); } elsif (m/^inst\:$/io) { - return OpenBSD::PackageRepository::Installed->_parse($ref); + return OpenBSD::PackageRepository::Installed->parse_fullurl($ref); } else { - return OpenBSD::PackageRepository::Local->_parse($ref); + return OpenBSD::PackageRepository::Local->parse_fullurl($ref); } } @@ -266,13 +271,12 @@ sub urlscheme return 'file'; } -sub _parse +sub parse_fullurl { my ($class, $r) = @_; - my $o = $class->SUPER::_parse($r); - return $o if defined $o; - $$r = "file:$$r"; - return $class->SUPER::_parse($r); + + $class->strip_urlscheme($r); + return $class->parse_local_url($r); } sub open_pipe @@ -361,6 +365,32 @@ sub open_pipe package OpenBSD::PackageRepository::Distant; our @ISA=qw(OpenBSD::PackageRepository); +sub baseurl +{ + my $self = shift; + + return "//$self->{host}/$self->{path}"; +} + +sub parse_url +{ + &parse_distant_url; +} + +sub parse_distant_url +{ + my ($class, $r) = @_; + # same heuristics as ftp(1): + # find host part, rest is parsed as a local url + if ($$r =~ m/^\/\/(.*?)(\/.*)$/) { + my $host = $1; + $$r = $2; + return $class->parse_local_url($r, $host); + } else { + return undef; + } +} + my $buffsize = 2 * 1024 * 1024; sub pkg_copy |