summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc Espie <espie@cvs.openbsd.org>2004-11-15 12:58:49 +0000
committerMarc Espie <espie@cvs.openbsd.org>2004-11-15 12:58:49 +0000
commit55d418bd6846b04822ff672762c2579cedf847b7 (patch)
treeb72f252220e079eaa24f2e36a7533f238e54efc0
parent57686d6c1643d27271aeb02faca221d96a10cdd0 (diff)
find_pkg function to iterate through pkgs, wherever they might be.
New -E filename option that looks for a filename through specified packages (or installed packages if no packages specified). Can be very, very slow, since it scans all packing-lists, but at least it works...
-rw-r--r--usr.sbin/pkg_add/pkg_info98
1 files changed, 76 insertions, 22 deletions
diff --git a/usr.sbin/pkg_add/pkg_info b/usr.sbin/pkg_add/pkg_info
index cc45e7ba19c..1216e373809 100644
--- a/usr.sbin/pkg_add/pkg_info
+++ b/usr.sbin/pkg_add/pkg_info
@@ -1,6 +1,6 @@
#! /usr/bin/perl
# ex:ts=8 sw=4:
-# $OpenBSD: pkg_info,v 1.20 2004/11/15 12:22:59 espie Exp $
+# $OpenBSD: pkg_info,v 1.21 2004/11/15 12:58:48 espie Exp $
#
# Copyright (c) 2003-2004 Marc Espie <espie@openbsd.org>
#
@@ -26,6 +26,32 @@ use OpenBSD::Error;
my $total_size = 0;
my $pkgs = 0;
+
+sub find_pkg
+{
+ my ($pkg, $code) = @_;
+ if (is_installed($pkg)) {
+ &$code($pkg, installed_info($pkg));
+ return;
+ }
+ if (OpenBSD::PackageName::is_stem($pkg)) {
+ my @l = sort (OpenBSD::PackageName::findstem($pkg, installed_packages()));
+ if (@l != 0) {
+ for my $p (@l) {
+ &$code($p, installed_info($p));
+ }
+ return;
+ }
+ }
+
+ require OpenBSD::PackageLocator;
+
+ my $true_package = OpenBSD::PackageLocator->find($pkg);
+ return unless $true_package;
+ my $dir = $true_package->info();
+ &$code($pkg, $dir);
+ $true_package->close();
+}
sub printfile
{
my $filename = shift;
@@ -56,6 +82,34 @@ sub find_by_spec
return sort(OpenBSD::PkgSpec::match($pat, installed_packages()));
}
+sub filter_files
+{
+ require OpenBSD::PackingOld;
+ require OpenBSD::PackingList;
+
+ my $search = shift;
+ my @result = ();
+ for my $arg (@_) {
+ find_pkg($arg,
+ sub {
+ my ($pkg, $dir) = @_;
+
+ my $plist = OpenBSD::PackingList->fromfile($dir.CONTENTS,
+ \&OpenBSD::PackingList::FilesOnly);
+ for my $item (@{$plist->{items}}) {
+ next unless $item->IsFile();
+ my $fname = $item->fullname();
+ if (defined $search->{"$fname"}) {
+ push(@{$search->{$fname}}, $pkg);
+ push(@result, $pkg);
+ }
+ }
+ $plist->forget();
+ });
+ }
+ return @result;
+}
+
my $all_plists;
sub find_by_path
@@ -87,6 +141,7 @@ our ($opt_c, $opt_D, $opt_d, $opt_f, $opt_I, $opt_i, $opt_k, $opt_K, $opt_L,
$opt_a, $opt_M, $opt_U, $opt_A);
my $terse = 0;
my $exit_code = 0;
+my @sought_files;
sub print_info
{
@@ -189,7 +244,7 @@ sub print_info
}
}
-getopts('cDdfIikKLmpqRrsvhe:MU:l:aA',
+getopts('cDdfIikKLmpqRrsvhe:E:MU:l:aA',
{'e' =>
sub {
my $pat = shift;
@@ -204,6 +259,13 @@ getopts('cDdfIikKLmpqRrsvhe:MU:l:aA',
}
push(@ARGV, @list);
$terse = 1;
+ },
+ 'E' =>
+ sub {
+ require File::Spec;
+
+ push(@sought_files, File::Spec->rel2abs(shift));
+
}
});
@@ -245,29 +307,21 @@ if (@ARGV == 0) {
@ARGV = sort(installed_packages(defined $opt_A ? 0 : 1));
}
-for my $pkg (@ARGV) {
- if (is_installed($pkg)) {
- print_info($pkg, installed_info($pkg));
- next;
- }
- if (OpenBSD::PackageName::is_stem($pkg)) {
- my @l = sort (OpenBSD::PackageName::findstem($pkg, installed_packages()));
- if (@l != 0) {
- for my $p (@l) {
- print_info($p, installed_info($p));
- }
- next;
+if (@sought_files) {
+ my %hash = map { ($_, []) } @sought_files;
+ @ARGV = filter_files(\%hash, @ARGV);
+ for my $f (@sought_files) {
+ my $l = $hash{$f};
+ if (@$l) {
+ print "$f: ", join(',', @$l), "\n" unless $opt_q;
+ } else {
+ $exit_code = 1;
}
}
-
- require OpenBSD::PackageLocator;
-
- my $true_package = OpenBSD::PackageLocator->find($pkg);
- next unless $true_package;
- my $dir = $true_package->info();
- $true_package->close();
+}
- print_info($pkg, $dir);
+for my $pkg (@ARGV) {
+ find_pkg($pkg, \&print_info);
}
if ($pkgs > 1) {
print "Total size: $total_size\n";