summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/pkg_add/OpenBSD/Add.pm4
-rw-r--r--usr.sbin/pkg_add/OpenBSD/AddDelete.pm76
-rw-r--r--usr.sbin/pkg_add/OpenBSD/Delete.pm4
-rw-r--r--usr.sbin/pkg_add/OpenBSD/PackingElement.pm22
-rw-r--r--usr.sbin/pkg_add/OpenBSD/SharedLibs.pm49
5 files changed, 84 insertions, 71 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/Add.pm b/usr.sbin/pkg_add/OpenBSD/Add.pm
index 1cc4f6e7a9b..9f0275086f2 100644
--- a/usr.sbin/pkg_add/OpenBSD/Add.pm
+++ b/usr.sbin/pkg_add/OpenBSD/Add.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: Add.pm,v 1.117 2010/12/24 09:04:14 espie Exp $
+# $OpenBSD: Add.pm,v 1.118 2010/12/24 09:09:54 espie Exp $
#
# Copyright (c) 2003-2007 Marc Espie <espie@openbsd.org>
#
@@ -649,7 +649,7 @@ sub install
my ($self, $state) = @_;
$self->SUPER::install($state);
return if $state->{do_faked};
- $self->mark_ldconfig_directory($state->{destdir});
+ $self->mark_ldconfig_directory($state);
}
package OpenBSD::PackingElement::SpecialFile;
diff --git a/usr.sbin/pkg_add/OpenBSD/AddDelete.pm b/usr.sbin/pkg_add/OpenBSD/AddDelete.pm
index 3bf8d67c262..0d73727fcf9 100644
--- a/usr.sbin/pkg_add/OpenBSD/AddDelete.pm
+++ b/usr.sbin/pkg_add/OpenBSD/AddDelete.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: AddDelete.pm,v 1.42 2010/12/24 09:04:14 espie Exp $
+# $OpenBSD: AddDelete.pm,v 1.43 2010/12/24 09:09:54 espie Exp $
#
# Copyright (c) 2007-2010 Marc Espie <espie@openbsd.org>
#
@@ -64,7 +64,7 @@ sub framework
my $dielater = $self->do_the_main_work($state);
# cleanup various things
$state->{recorder}->cleanup($state);
- OpenBSD::PackingElement::Lib::ensure_ldconfig($state);
+ $state->ldconfig->ensure;
OpenBSD::PackingElement::Fontdir::finish_fontdirs($state);
$state->progress->clear;
$state->log->dump;
@@ -328,6 +328,78 @@ sub check_dir
}
}
+OpenBSD::Auto::cache(ldconfig,
+ sub {
+ my $self = shift;
+ return OpenBSD::LdConfig->new($self);
+ });
+
+# this is responsible for running ldconfig when needed
+package OpenBSD::LdConfig;
+
+sub new
+{
+ my ($class, $state) = @_;
+ bless { state => $state, todo => 0 }, $class;
+}
+
+# called once to figure out which directories are actually used
+sub init
+{
+ my $self = shift;
+ my $state = $self->{state};
+ my $destdir = $state->{destdir};
+
+ $self->{ldconfig} = [OpenBSD::Paths->ldconfig];
+
+ $self->{path} = {};
+ if ($destdir ne '') {
+ unshift @{$self->{ldconfig}}, OpenBSD::Paths->chroot, '--',
+ $destdir;
+ }
+ open my $fh, "-|", @{$self->{ldconfig}}, "-r";
+ if (defined $fh) {
+ my $_;
+ while (<$fh>) {
+ if (m/^\s*search directories:\s*(.*?)\s*$/o) {
+ for my $d (split(/\:/o, $1)) {
+ $self->{path}{$d} = 1;
+ }
+ last;
+ }
+ }
+ close($fh);
+ } else {
+ $state->errsay("Can't find ldconfig");
+ }
+}
+
+# called from libs to figure out whether ldconfig should be rerun
+sub mark_directory
+{
+ my ($self, $name) = @_;
+ if (!defined $self->{path}) {
+ $self->init;
+ }
+ require File::Basename;
+ my $d = File::Basename::dirname($name);
+ if ($self->{path}{$d}) {
+ $self->{todo} = 1;
+ }
+}
+
+# call before running any command (or at end) to run ldconfig just in time
+sub ensure
+{
+ my $self = shift;
+ if ($self->{todo}) {
+ my $state = $self->{state};
+ $state->vsystem(@{$self->{ldconfig}}, "-R")
+ unless $state->{not};
+ $self->{todo} = 0;
+ }
+}
+
# the object that gets displayed during status updates
package OpenBSD::Status;
diff --git a/usr.sbin/pkg_add/OpenBSD/Delete.pm b/usr.sbin/pkg_add/OpenBSD/Delete.pm
index 345c7127cbe..ad1087ab532 100644
--- a/usr.sbin/pkg_add/OpenBSD/Delete.pm
+++ b/usr.sbin/pkg_add/OpenBSD/Delete.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: Delete.pm,v 1.111 2010/12/24 09:04:14 espie Exp $
+# $OpenBSD: Delete.pm,v 1.112 2010/12/24 09:09:54 espie Exp $
#
# Copyright (c) 2003-2007 Marc Espie <espie@openbsd.org>
#
@@ -655,7 +655,7 @@ sub delete
{
my ($self, $state) = @_;
$self->SUPER::delete($state);
- $self->mark_ldconfig_directory($state->{destdir});
+ $self->mark_ldconfig_directory($state);
}
package OpenBSD::PackingElement::FDEINSTALL;
diff --git a/usr.sbin/pkg_add/OpenBSD/PackingElement.pm b/usr.sbin/pkg_add/OpenBSD/PackingElement.pm
index eb3657b8846..1325a57705b 100644
--- a/usr.sbin/pkg_add/OpenBSD/PackingElement.pm
+++ b/usr.sbin/pkg_add/OpenBSD/PackingElement.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: PackingElement.pm,v 1.189 2010/12/24 09:04:14 espie Exp $
+# $OpenBSD: PackingElement.pm,v 1.190 2010/12/24 09:09:54 espie Exp $
#
# Copyright (c) 2003-2010 Marc Espie <espie@openbsd.org>
#
@@ -584,20 +584,8 @@ __PACKAGE__->register_with_factory;
sub mark_ldconfig_directory
{
- require OpenBSD::SharedLibs;
-
- my ($self, $destdir) = @_;
- OpenBSD::SharedLibs::mark_ldconfig_directory($self->fullname,
- $destdir);
-}
-
-sub ensure_ldconfig
-{
- if ($todo) {
- require OpenBSD::SharedLibs;
-
- &OpenBSD::SharedLibs::ensure_ldconfig;
- }
+ my ($self, $state) = @_;
+ $state->ldconfig->mark_directory($self->fullname);
}
sub parse
@@ -1291,7 +1279,7 @@ sub run
{
my ($self, $state) = @_;
- OpenBSD::PackingElement::Lib::ensure_ldconfig($state);
+ $state->ldconfig->ensure;
$state->say("#1 #2", $self->keyword, $self->{expanded})
if $state->verbose >= 2;
$state->log->system(OpenBSD::Paths->sh, '-c', $self->{expanded})
@@ -1603,7 +1591,7 @@ sub run
return if $state->{dont_run_scripts};
- OpenBSD::PackingElement::Lib::ensure_ldconfig($state);
+ $state->ldconfig->ensure;
$state->say("#1 script: #2 #3 #4", $self->beautify, $name, $pkgname,
join(' ', @args)) if $state->verbose >= 2;
return if $state->{not};
diff --git a/usr.sbin/pkg_add/OpenBSD/SharedLibs.pm b/usr.sbin/pkg_add/OpenBSD/SharedLibs.pm
index c35ab517e91..dfb646ab3e8 100644
--- a/usr.sbin/pkg_add/OpenBSD/SharedLibs.pm
+++ b/usr.sbin/pkg_add/OpenBSD/SharedLibs.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: SharedLibs.pm,v 1.55 2010/12/24 09:04:14 espie Exp $
+# $OpenBSD: SharedLibs.pm,v 1.56 2010/12/24 09:09:54 espie Exp $
#
# Copyright (c) 2003-2010 Marc Espie <espie@openbsd.org>
#
@@ -40,53 +40,6 @@ package OpenBSD::SharedLibs;
use File::Basename;
use OpenBSD::Error;
-my $path;
-my @ldconfig = (OpenBSD::Paths->ldconfig);
-
-
-sub init_path($)
-{
- my $destdir = shift;
- $path={};
- if ($destdir ne '') {
- unshift @ldconfig, OpenBSD::Paths->chroot, '--', $destdir;
- }
- open my $fh, "-|", @ldconfig, "-r";
- if (defined $fh) {
- my $_;
- while (<$fh>) {
- if (m/^\s*search directories:\s*(.*?)\s*$/o) {
- for my $d (split(/\:/o, $1)) {
- $path->{$d} = 1;
- }
- last;
- }
- }
- close($fh);
- } else {
- print STDERR "Can't find ldconfig\n";
- }
-}
-
-sub mark_ldconfig_directory
-{
- my ($name, $destdir) = @_;
- if (!defined $path) {
- init_path($destdir);
- }
- my $d = dirname($name);
- if ($path->{$d}) {
- $OpenBSD::PackingElement::Lib::todo = 1;
- }
-}
-
-sub ensure_ldconfig
-{
- my $state = shift;
- $state->vsystem(@ldconfig, "-R") unless $state->{not};
- $OpenBSD::PackingElement::Lib::todo = 0;
-}
-
our $repo = OpenBSD::LibRepo->new;
sub register_library