summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Lynagh <ian@well-typed.com>2013-02-15 15:38:55 +0000
committerIan Lynagh <ian@well-typed.com>2013-02-15 15:38:55 +0000
commitd8ab46d2258fbf765dc39e5868e18606624dc36c (patch)
tree66f0a6c67ee04baea8e0fdeefc9aaa7cc125d183
parent192789a4c4a4388e39d1652a62c09a3715637ead (diff)
downloadhaskell-d8ab46d2258fbf765dc39e5868e18606624dc36c.tar.gz
Check sub-modules are OK before pushing
-rwxr-xr-xsync-all40
1 files changed, 40 insertions, 0 deletions
diff --git a/sync-all b/sync-all
index 898ce66d06..607f7f9f67 100755
--- a/sync-all
+++ b/sync-all
@@ -371,6 +371,42 @@ sub scmall {
$ignore_failure = 1;
scm ($localpath, $scm, "commit", @args);
}
+ elsif ($command eq "check_submodules") {
+ # If we have a submodule then check whether it is up-to-date
+ if ($remotepath eq "-") {
+ my %remote_heads;
+
+ message "== Checking sub-module $localpath";
+
+ chdir($localpath);
+
+ open my $lsremote, '-|', 'git', 'ls-remote', '--heads', '-q'
+ or die "Executing ls-remote failed: $!";
+ while (<$lsremote>) {
+ if (/^([0-9a-f]{40})\s*refs\/heads\//) {
+ $remote_heads{$1} = 1;
+ }
+ else {
+ die "Bad output from ls-remote: $_";
+ }
+ }
+ close($lsremote);
+
+ open my $revparse, '-|', 'git', 'rev-parse', '--verify', 'HEAD'
+ or die "Executing rev-parse failed: $!";
+ my $myhead;
+ $myhead = <$revparse>;
+ # or die "Failed to read from rev-parse: $!";
+ chomp $myhead;
+ close($revparse);
+
+ if (not defined($remote_heads{$myhead})) {
+ die "Sub module $localpath needs to be pushed; see http://hackage.haskell.org/trac/ghc/wiki/Repositories/Upstream";
+ }
+
+ chdir($initial_working_directory);
+ }
+ }
elsif ($command eq "push") {
# We don't automatically push to the submodules. If you want
# to push to them then you need to use a special command, as
@@ -783,6 +819,10 @@ sub main {
$command = "status";
}
+ if ($command eq "push") {
+ scmall ("check_submodules", @_);
+ }
+
scmall ($command, @_);
my @submodule_args = grep(/^-q/,@_);