Hello, > On 9 Mar 2022, at 22:56, Robin Roevens wrote: > > - Revamped 'pakfire update' more in the style of 'pakfire > install' for a more consistent look and feel. > - Add core update details to output > - Add new dependencies to install to output > - First collect all upgrade info, then perform core update > together with available package updates and after user > confirmation (without -y). I am sorry to disappoint Tom, but this is quite likely a no-can-do. The problem is that we are repeatedly tight on disk space which makes downloading everything first a bit of a problem. We do not have any mechanism that checks whether enough space for either the downloads or for extracting the update is available, which is why the old way was more of a step-by-step system. I don’t like the old system at all, but I would propose to add a function that checks if enough disk space is available before it asks the user whether they want to continue. That should consider: * The download size of the updates * The download size of all add-ons * The extracted size (for simplicity probably assuming that the core update is only adding new files) * The extracted size of all add-ons Then, we can even drop some last checks in the update scripts that aborted the update process if disk space was running low. How does that sound? -Michael > > Signed-off-by: Robin Roevens > --- > src/pakfire/pakfire | 79 +++++++++++++++++++++++++++++---------------- > 1 file changed, 51 insertions(+), 28 deletions(-) > > diff --git a/src/pakfire/pakfire b/src/pakfire/pakfire > index 9935481a5..0a144c517 100644 > --- a/src/pakfire/pakfire > +++ b/src/pakfire/pakfire > @@ -258,51 +258,76 @@ > &Pakfire::getcoredb("$force"); > > } elsif ("$ARGV[0]" eq "upgrade") { > - my $use_color = ""; > - my $reset_color = ""; > - > - if ("$Pakfire::enable_colors" eq "1") { > - $reset_color = "$Pakfire::color{'normal'}"; > - $use_color = "$Pakfire::color{'lightpurple'}"; > - } > - > &Pakfire::message("CORE INFO: Checking for Core updates..."); > - > ### Make sure that the core db is not outdated. > &Pakfire::getcoredb("noforce"); > - my %coredb = &Pakfire::coredbinfo(); > > - if (defined $coredb{'AvailableRelease'}) { > - &Pakfire::upgradecore(); > - } else { > - &Pakfire::message("CORE WARN: No new Core upgrades available. You are on release ".$coredb{'Release'}); > - } > + my %coredb = &Pakfire::coredbinfo(); > + &Pakfire::message("CORE WARN: No new Core upgrades available. You are on release ".$coredb{'Release'}) unless (defined $coredb{'AvailableRelease'}); > > &Pakfire::message("PAKFIRE INFO: Checking for package updates..."); > ### Make sure that the package list is not outdated. > &Pakfire::dbgetlist("noforce"); > > my @deps = (); > - if (my %upgradepaks = &Pakfire::dblist("upgrade")) { > - # Resolve the dependencies of the to be upgraded packages > - @deps = &Pakfire::resolvedeps_recursive(keys %upgradepaks); > + my %upgradepaks = &Pakfire::dblist("upgrade"); > > - foreach $pak (sort keys %upgradepaks) { > - print "${use_color}Update: $pak\nVersion: $upgradepaks{$pak}{'ProgVersion'} -> $upgradepaks{$pak}{'AvailableProgVersion'}\n"; > - print "Release: $upgradepaks{$pak}{'Release'} -> $upgradepaks{$pak}{'AvailableRelease'}${reset_color}\n"; > - } > + # Resolve the dependencies of the to be upgraded packages > + @deps = &Pakfire::resolvedeps_recursive(keys %upgradepaks) if (%upgradepaks); > + &Pakfire::message("PAKFIRE WARN: No new package upgrades available.") unless (@deps); > + > + if (defined $coredb{'AvailableRelease'} || %upgradepaks) { > + &Pakfire::message(""); > &Pakfire::message(""); > - &Pakfire::message("PAKFIRE UPGR: We are going to install all packages listed above."); > + &Pakfire::message("PAKFIRE INFO: Upgrade summary:"); > + &Pakfire::message(""); > + > + if (defined $coredb{'AvailableRelease'}) { > + &Pakfire::message("CORE INFO: Core-Update $coredb{'CoreVersion'} to install:"); > + &Pakfire::message("CORE UPGR: Release: $coredb{'Release'} -> $coredb{'AvailableRelease'}"); > + &Pakfire::message(""); > + } > + > + if (@deps) { > + &Pakfire::message("PAKFIRE INFO: New dependencies to install:"); > + my $totalsize = 0; > + foreach $pak (@deps) { > + unless (defined $upgradepaks{$pak} || &Pakfire::isinstalled($pak) == 0) { > + my $size = &Pakfire::getsize("$pak"); > + $totalsize += $size; > + $size = &Pakfire::beautifysize($size); > + &Pakfire::message("PAKFIRE INFO: $pak \t - $size"); > + } > + } > + $totalsize = &Pakfire::beautifysize($totalsize); > + &Pakfire::message(""); > + &Pakfire::message("PAKFIRE INFO: Total size: \t ~ $totalsize"); > + &Pakfire::message(""); > + } > + > + if (%upgradepaks) { > + &Pakfire::message("PAKFIRE INFO: Packages to upgrade:"); > + foreach $pak (sort keys %upgradepaks) { > + &Pakfire::message("PAKFIRE UPGR: $pak\t$upgradepaks{$pak}{'ProgVersion'}-$upgradepaks{$pak}{'Release'} -> $upgradepaks{$pak}{'AvailableProgVersion'}-$upgradepaks{$pak}{'AvailableRelease'}"); > + } > + &Pakfire::message(""); > + } > + > if ($interactive) { > - &Pakfire::message("PAKFIRE INFO: Is this okay? [y/N]"); > + &Pakfire::message("PAKFIRE INFO: Is this okay? [y/N]"); > my $ret = ; > chomp($ret); > &Pakfire::logger("PAKFIRE INFO: Answer: $ret"); > if ( $ret ne "y" ) { > - &Pakfire::message("PAKFIRE ERROR: Installation aborted."); > - exit 1; > + &Pakfire::message("PAKFIRE ERROR: Installation aborted."); > + exit 1; > } > } > + > + # Perform core update > + if (defined $coredb{'AvailableRelease'}) { > + &Pakfire::upgradecore(); > + } > > # Download packages > foreach $pak (sort keys %upgradepaks) { > @@ -323,8 +348,6 @@ > foreach $pak (sort keys %upgradepaks) { > &Pakfire::upgradepak("$pak"); > } > - } else { > - &Pakfire::message("PAKFIRE WARN: No new package upgrades available."); > } > > } elsif ("$ARGV[0]" eq "list") { > -- > 2.34.1 > > > -- > Dit bericht is gescanned op virussen en andere gevaarlijke > inhoud door MailScanner en lijkt schoon te zijn. >