]> git.vpit.fr Git - perl/modules/rgit.git/commitdiff
Add an open shell option in interactive mode
authorVincent Pit <vince@profvince.com>
Mon, 20 Oct 2008 22:11:10 +0000 (00:11 +0200)
committerVincent Pit <vince@profvince.com>
Mon, 20 Oct 2008 22:11:10 +0000 (00:11 +0200)
bin/rgit

index 6b747898dcaf3218756c92c346a1c47b1432aab8..326d56edf3f4872485549e7702adc1bfc6ee5446 100755 (executable)
--- a/bin/rgit
+++ b/bin/rgit
@@ -29,40 +29,26 @@ BEGIN {
  $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};
@@ -90,6 +76,52 @@ exit App::Rgit->new(
  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