From ab7fd8391ba5ba3210a76e69b3f038546b059b68 Mon Sep 17 00:00:00 2001 From: Thierry Vignaud Date: Thu, 20 Aug 2009 14:06:38 +0000 Subject: (_get_current_kernel_package,_all_unrequested_orphans) do not offer to remove current kernel --- urpm/orphans.pm | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'urpm/orphans.pm') diff --git a/urpm/orphans.pm b/urpm/orphans.pm index aa7a2a19..a7f722f9 100644 --- a/urpm/orphans.pm +++ b/urpm/orphans.pm @@ -290,6 +290,13 @@ sub _will_prop_still_be_needed { }); } +# so that we can filter out current running kernel: +sub _get_current_kernel_package() { + my $release = (POSIX::uname())[2]; + `rpm -qf --qf '%{name}' /boot/vmlinuz-$release`; +} + + #- returns the list of "unrequested" orphans. #- #- side-effects: none @@ -302,6 +309,8 @@ sub _all_unrequested_orphans { push @{$provides{$_}}, $pkg foreach $pkg->provides_nosense; } + my $current_kernel = _get_current_kernel_package(); + while (my $pkg = shift @$req) { foreach my $prop ($pkg->requires, $pkg->suggests) { my $n = URPM::property2name($prop); @@ -314,6 +323,8 @@ sub _all_unrequested_orphans { } } + # do not offer to remove current kernel: + delete $l{$current_kernel}; [ values %l ]; } -- cgit v1.2.1