From 021f55cb3aef011cd0b9834b631930d4b3f57cd0 Mon Sep 17 00:00:00 2001 From: Marc Espie Date: Sat, 1 Feb 2014 11:18:28 +0000 Subject: handling of critical section was wrong. Interrupting an update once we're "committed" is a bad idea. Make it possible by ^C^C still, but try to get out only when the db is in a safe state. --- usr.sbin/pkg_add/OpenBSD/PkgAdd.pm | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) (limited to 'usr.sbin/pkg_add/OpenBSD/PkgAdd.pm') diff --git a/usr.sbin/pkg_add/OpenBSD/PkgAdd.pm b/usr.sbin/pkg_add/OpenBSD/PkgAdd.pm index 76dbd5635c5..f7cef725a70 100644 --- a/usr.sbin/pkg_add/OpenBSD/PkgAdd.pm +++ b/usr.sbin/pkg_add/OpenBSD/PkgAdd.pm @@ -1,7 +1,7 @@ #! /usr/bin/perl # ex:ts=8 sw=4: -# $OpenBSD: PkgAdd.pm,v 1.50 2014/02/01 11:00:57 espie Exp $ +# $OpenBSD: PkgAdd.pm,v 1.51 2014/02/01 11:18:27 espie Exp $ # # Copyright (c) 2003-2014 Marc Espie # @@ -568,10 +568,10 @@ use OpenBSD::Error; sub failed_message { - my ($base_msg, $interrupted, @l) = @_; + my ($base_msg, $received, @l) = @_; my $msg = $base_msg; - if ($interrupted) { - $msg = "Caught SIG$interrupted. $msg"; + if ($received) { + $msg = "Caught SIG$received. $msg"; } if (@l > 0) { $msg.= ", partial installation recorded as ".join(',', @l); @@ -595,7 +595,7 @@ sub save_partial_set sub partial_install { my ($base_msg, $set, $state) = @_; - return failed_message($base_msg, $state->{interrupted}, save_partial_set($set, $state)); + return failed_message($base_msg, $state->{received}, save_partial_set($set, $state)); } sub build_before @@ -726,7 +726,13 @@ sub really_add $state->{replacing} = $replacing; my $handler = sub { - $state->{interrupted} = shift; + $state->{received} = shift; + $state->errsay("Interrupted"); + if ($state->{hardkill}) { + delete $state->{hardkill}; + return; + } + $state->{interrupted}++; }; local $SIG{'INT'} = $handler; local $SIG{'QUIT'} = $handler; @@ -734,6 +740,8 @@ sub really_add local $SIG{'KILL'} = $handler; local $SIG{'TERM'} = $handler; + $state->{hardkill} = $state->{delete_first}; + if ($replacing) { require OpenBSD::OldLibs; OpenBSD::OldLibs->save($set, $state); @@ -762,6 +770,7 @@ sub really_add } } if (!$state->{delete_first}) { + $state->{hardkill} = 1; delete_old_packages($set, $state); } @@ -814,6 +823,9 @@ sub really_add } delete $state->{delete_first}; $state->syslog("Added #1", $set->print); + if ($state->{received}) { + die "interrupted"; + } } sub newer_has_errors -- cgit v1.2.3