$cmd = ' ' unless defined $cmd;
}
+my $shell;
+
BEGIN {
if (-t && $opts{I}) {
if (eval "require Term::ReadKey; 1") {
Term::ReadKey->import;
- *policy = sub {
- my ($cmd, $conf, $repo, $status, $signal) = @_;
- return NEXT unless $status;
- print STDERR 'The command failed for ' . $repo->work . "\n";
- print STDERR "[a]bort, [i]gnore, [I]gnore all, [r]etry ?";
- ReadMode(4);
- my $key = ReadKey(0);
- ReadMode(1);
- print STDERR "\n";
- my %codes = (
- 'a' => LAST,
- 'i' => NEXT,
- 'I' => NEXT | SAVE,
- 'r' => REDO,
- );
- $key = 'a' unless defined $key;
- my $code = $codes{$key};
- $code = $codes{a} unless defined $code;
- return $code;
- };
+ *policy = \&policy_interactive;
+ for (grep defined, $ENV{SHELL}, '/bin/sh') {
+ if (-x $_) {
+ $shell = $_;
+ last;
+ }
+ }
} else {
warn "You have to install Term::ReadKey to use the interactive mode.\n";
}
}
- *policy = sub { NEXT } if $opts{K} and not defined *policy{CODE};
- *policy = sub {
- my ($cmd, $conf, $repo, $status, $signal) = @_;
- return NEXT unless $status;
- return LAST;
- } unless defined *policy{CODE};
+ *policy = $opts{K} ? \&policy_keep
+ : \&policy_default
+ unless defined *policy{CODE};
}
setpgrp 0, 0 if $Config{d_setpgrp};
policy => \&policy,
)->run;
+sub policy_default {
+ my ($cmd, $conf, $repo, $status, $signal) = @_;
+ return NEXT unless $status;
+ return LAST;
+}
+
+sub policy_keep { NEXT }
+
+sub policy_interactive {
+ my ($cmd, $conf, $repo, $status, $signal) = @_;
+ return NEXT unless $status;
+ my %codes = (
+ 'a' => [ LAST, 'aborting' ],
+ 'i' => [ NEXT, 'ignoring' ],
+ 'I' => [ NEXT | SAVE, 'ignoring all' ],
+ 'r' => [ REDO, 'retrying' ],
+ );
+ my $int = { GetControlChars() }->{INTERRUPT};
+ while (1) {
+ print STDERR "[a]bort, [i]gnore, [I]gnore all, [r]etry, open [s]hell ?";
+ ReadMode(4);
+ my $key = ReadKey(0);
+ ReadMode(1);
+ print STDERR "\n";
+ next unless defined $key;
+ if ($key eq $int) {
+ print STDERR "Interrupted, aborting\n";
+ return LAST;
+ } elsif ($key eq 's') {
+ if (defined $shell) {
+ print STDERR 'Opening shell in ', $repo->work, "\n";
+ my $cwd = cwd;
+ $repo->chdir;
+ system { $shell } $shell;
+ chroot $cwd;
+ } else {
+ print STDERR "Couldn't find any shell\n";
+ }
+ } elsif (exists $codes{$key}) {
+ my $code = $codes{$key};
+ print STDERR 'Okay, ', $code->[1], "\n";
+ return $code->[0];
+ }
+ }
+}
+
__END__
=head1 NAME