diff options
-rw-r--r-- | usr.sbin/pkg_add/OpenBSD/PackingElement.pm | 63 | ||||
-rw-r--r-- | usr.sbin/pkg_add/pkg_add | 12 | ||||
-rw-r--r-- | usr.sbin/pkg_add/pkg_delete | 64 |
3 files changed, 117 insertions, 22 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/PackingElement.pm b/usr.sbin/pkg_add/OpenBSD/PackingElement.pm index cf11c2d181a..7360affc6ac 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.20 2004/08/07 17:27:26 espie Exp $ +# $OpenBSD: PackingElement.pm,v 1.21 2004/08/10 11:53:27 espie Exp $ # # Copyright (c) 2003-2004 Marc Espie <espie@openbsd.org> # @@ -67,7 +67,7 @@ sub category() { 'items' } sub new { my ($class, $args) = @_; - if ($args =~ m|/$| and defined $class->dirclass()) { + if ($args =~ m|/+$| and defined $class->dirclass()) { bless { name => $` }, $class->dirclass(); } else { bless { name => $args }, $class; @@ -110,10 +110,12 @@ sub needs_keyword() { 1 } sub write { my ($self, $fh) = @_; + my $s = $self->stringize(); if ($self->needs_keyword()) { - print $fh "\@", $self->keyword(), " ", $self->stringize(), "\n"; + $s = " $s" unless $s eq ''; + print $fh "\@", $self->keyword(), "$s\n"; } else { - print $fh $self->stringize(), "\n"; + print $fh "$s\n"; } } @@ -121,10 +123,12 @@ sub write sub fullstring { my ($self, $fh) = @_; + my $s = $self->stringize(); if ($self->needs_keyword()) { - return "\@".$self->keyword()." ".$self->stringize(); + $s = " $s" unless $s eq ''; + return "\@".$self->keyword().$s; } else { - return $self->stringize(); + return $s; } } @@ -768,7 +772,8 @@ sub NoDuplicateNames() { 1 } package OpenBSD::PackingElement::DirBase; sub stringize($) { - return $_[0]->{name}."/"; + my $self = $_[0]; + return $self->{name}."/"; } sub NoDuplicateNames() { 1 } @@ -797,12 +802,56 @@ our @ISA=qw(OpenBSD::PackingElement::Dir); __PACKAGE__->setKeyword('fontdir'); sub keyword() { "fontdir" } sub needs_keyword { 1 } +sub dirclass() { "OpenBSD::PackingElement::Fontdir" } + +our %fonts_todo = (); + +sub install +{ + my ($self, $archive, $destdir, $verbose, $not) = @_; + $self->SUPER::install($archive, $destdir, $verbose, $not); + $fonts_todo{$destdir.$self->fullname()} = 1; +} + +sub reload +{ + my ($self, $state) = @_; + $fonts_todo{$state->{destdir}.$self->fullname()} = 1; +} + +sub update_fontalias +{ + my $dirname = shift; + my @aliases; + + for my $alias (glob "$dirname/fonts.alias-*") { + open my $f ,'<', $alias or next; + push(@aliases, <$f>); + close $f; + } + open my $f, '>', "$dirname/fonts.alias"; + print $f @aliases; + close $f; +} + +sub finish_fontdirs +{ + my @l = keys %fonts_todo; + if (@l != 0) { + map { update_fontalias($_) } @l; + print "You may wish to update your font path for ", join(' ', @l), "\n"; + eval { system("/usr/X11R6/bin/mkfontdir", @l); }; + eval { system("/usr/X11R6/bin/fc-cache", @l); }; + } +} + package OpenBSD::PackingElement::Mandir; our @ISA=qw(OpenBSD::PackingElement::Dir); __PACKAGE__->setKeyword('mandir'); sub keyword() { "mandir" } sub needs_keyword { 1 } +sub dirclass() { "OpenBSD::PackingElement::Mandir" } package OpenBSD::PackingElement::Extra; our @ISA=qw(OpenBSD::PackingElement); diff --git a/usr.sbin/pkg_add/pkg_add b/usr.sbin/pkg_add/pkg_add index fc3aa0e3855..590a0dcd070 100644 --- a/usr.sbin/pkg_add/pkg_add +++ b/usr.sbin/pkg_add/pkg_add @@ -1,7 +1,7 @@ #! /usr/bin/perl # ex:ts=8 sw=4: -# $OpenBSD: pkg_add,v 1.47 2004/08/07 17:27:26 espie Exp $ +# $OpenBSD: pkg_add,v 1.48 2004/08/10 11:53:27 espie Exp $ # # Copyright (c) 2003-2004 Marc Espie <espie@openbsd.org> # @@ -132,6 +132,15 @@ sub install &OpenBSD::PackingElement::Dir::install; } +package OpenBSD::PackingElement::Mandir; + +sub install +{ + my ($self, $archive, $destdir, $verbose, $not) = @_; + $self->SUPER::install->($archive, $destdir, $verbose, $not); + print "You may wish to add ", $self->fullname(), " to /etc/man.conf\n"; +} + package OpenBSD::PackingElement::InfoFile; use File::Basename; @@ -713,6 +722,7 @@ while (my $pkg = shift @todo) { $conflict_list->{$plist->pkgname()} = $handle->{conflicts}; } +OpenBSD::PackingElement::Fontdir::finish_fontdirs(); ensure_ldconfig($opt_v) unless $opt_n; if ($opt_n or $opt_v) { diff --git a/usr.sbin/pkg_add/pkg_delete b/usr.sbin/pkg_add/pkg_delete index 7ef582f91df..2df41528e9f 100644 --- a/usr.sbin/pkg_add/pkg_delete +++ b/usr.sbin/pkg_add/pkg_delete @@ -1,6 +1,6 @@ #!/usr/bin/perl # ex:ts=8 sw=4: -# $OpenBSD: pkg_delete,v 1.38 2004/08/09 01:40:57 espie Exp $ +# $OpenBSD: pkg_delete,v 1.39 2004/08/10 11:53:27 espie Exp $ # # Copyright (c) 2003-2004 Marc Espie <espie@openbsd.org> # @@ -39,14 +39,14 @@ sub ensure_ldconfig undef $OpenBSD::PackingElement::Lib::todo; } -sub find_alldirrms +sub erase_alldirrms { my $db = {}; my @list = installed_packages(); for my $e (@list) { my $plist = OpenBSD::PackingList->fromfile(installed_info($e).CONTENTS, \&OpenBSD::PackingList::DirrmOnly) or next; for my $item (@{$plist->{items}}) { - $item->record_dirrm($e, $db); + $item->erase_dir($e, $db); } } return $db; @@ -59,13 +59,21 @@ sub remove_dirs my $h = $state->{dirs_to_rm}; return unless defined $h; - my $remaining = find_alldirrms(); + my $remaining = erase_alldirrms(); for my $d (sort {$b cmp $a} keys %$h) { - next if defined $remaining->{$d}; my $realname = $state->{destdir}.$d; - if (!rmdir $realname) { - print "Error deleting directory $realname: $!\n"; + if ($remaining->{$realname}) { + for my $i (@{$h->{$d}}) { + $i->reload($state); + } + } else { + for my $i (@{$h->{$d}}) { + $i->cleanup($state); + } + if (!rmdir $realname) { + print "Error deleting directory $realname: $!\n"; + } } } } @@ -76,7 +84,15 @@ sub delete { } -sub record_dirrm +sub erase_dir +{ +} + +sub cleanup +{ +} + +sub reload { } @@ -92,12 +108,11 @@ sub log_pkgname package OpenBSD::PackingElement::DirBase; -sub record_dirrm +sub erase_dir { my ($self, $pkgname, $db) = @_; my $k = $self->fullname(); - $db->{$k} = [] unless defined $db->{$k}; - push(@{$db->{$k}}, $pkgname); + $db->{$k} = 1; } sub delete @@ -114,13 +129,13 @@ sub delete my $h = $state->{dirs_to_rm}; $h->{$name} = [] unless defined $h->{$name}; - push(@{$h->{$name}}, $state->{pkgname}); + push(@{$h->{$name}}, $self->clone()); } package OpenBSD::PackingElement::DirRm; -sub record_dirrm +sub erase_dir { - &OpenBSD::PackingElement::DirBase::record_dirrm; + &OpenBSD::PackingElement::DirBase::erase_dir; } sub delete @@ -279,6 +294,26 @@ sub delete $self->SUPER::delete($state); } +package OpenBSD::PackingElement::Mandir; +sub cleanup +{ + my ($self, $state) = @_; + my $fullname = $state->{destdir}.self->fullname(); + print "You may wish to remove ", $fullname, " from man.conf\n"; + unlink("$fullname/whatis.db"); +} + +package OpenBSD::PackingElement::Fontdir; +sub cleanup +{ + my ($self, $state) = @_; + my $fullname = $state->{destdir}.$self->fullname(); + print "You may wish to remove ", $fullname, " from your font path\n"; + unlink("$fullname/fonts.alias"); + unlink("$fullname/fonts.dir"); + unlink("$fullname/fonts.cache-1"); +} + package OpenBSD::PackingElement::ExtraUnexec; sub delete { @@ -567,6 +602,7 @@ if ($opt_B eq '') { ensure_ldconfig($opt_v) unless $opt_n; # delayed directory removal remove_dirs($state); +OpenBSD::PackingElement::Fontdir::finish_fontdirs(); my $logname = OpenBSD::Logger::logname(); if (defined $logname) { |