die "$0: auto-update not possible: need write permissions in @{[cwd]}\n"
if not -w '.';
+ # Get information about our remote and calculate the chance for a
+ # successfull auto-updat. Based on:
# http://stackoverflow.com/questions/3258243/check-if-pull-needed-in-git
system("git fetch $remote") == 0 or die $? >> 8;
my ($upstream, $local, $base) = qx'git rev-parse ...@{upstream}'; die $? >> 8 if $?;
$base =~ s/^\^//;
if ($upstream ne $local) {
- die "$0: the merge base is not local anymore. Refusing to `git pull`\n"
- if $base ne $local;
- say "Doing git pull ..." if $verbose;
-
- # if we're the merge base, the ff-only should workkkkkk
- system 'git pull --ff-only' == 0 or die $? >> 8;
- say "$0: re-execute after update";
- chdir $CALLED{cwd} or die "$0: Can't chdir to $CALLED{cwd}: $!\n";
- exec $CALLED{argv0}, @{$CALLED{argv}};
- die "Can't re-exec\n";
+ if ($base ne $local) {
+ warn "$0: the merge base is not local anymore. Refusing to `git pull`\n"
+ }
+ else {
+ # if we're the merge base, the ff-only should work
+ system('git pull --ff-only') == 0 or die $? >> 8;
+ say "$0: re-execute after update";
+ chdir $CALLED{cwd} or die "$0: Can't chdir to $CALLED{cwd}: $!\n";
+ exec $CALLED{argv0}, @{$CALLED{argv}};
+ die "Can't re-exec\n";
+ }
}
}