clean up preflight checks
[p5sagit/Distar.git] / helpers / preflight
CommitLineData
be032607 1#!/usr/bin/env perl
2use strict;
3use warnings FATAL => 'all';
4use Config;
5use File::Spec;
6use File::Find;
190976f8 7use Getopt::Long qw(:config gnu_getopt);
be032607 8
190976f8 9GetOptions(
10 "branch=s" => \(my $branch = 'master'),
9b920c5c 11 "changelog=s" => \(my $changelog = 'Changes'),
190976f8 12) or die("Error in command line arguments\n");
13
14my $version = shift or die "version required!";
be032607 15
16my $make = $Config{make};
17my $null = File::Spec->devnull;
18
19system("git fetch");
20if (system("git rev-parse --quiet --verify v$version >$null") == 0) {
21 die "Tag v$version already exists!";
22}
23
0d483d8e 24chomp(my $head = `git symbolic-ref -q HEAD`);
25(my $current_branch = $head) =~ s{^refs/heads/}{};
26$head eq "refs/heads/$branch"
27 or die "Current branch is $current_branch, not $branch. EEEK!\n";
28chomp(my $upstream = `git for-each-ref --format="%(upstream)" $head`);
29length $upstream
30 or die "No upstream branch configured for $branch!\n";
31system qw(git merge-base --is-ancestor), $upstream, $head
32 and die "Not synced with upstream!\n";
be032607 33
34for (scalar `git diff`) {
0d483d8e 35 length && die "Outstanding changes!\n";
be032607 36}
37my $ymd = sprintf(
38 "%i-%02i-%02i", (gmtime)[5]+1900, (gmtime)[4]+1, (gmtime)[3]
39);
40my $changes_line = "$version - $ymd\n";
0d483d8e 41my @cached = grep /^\+/, `git diff --cached -U0 --no-prefix`;
42@cached > 0 or die "Please add:\n\n$changes_line\nto $changelog and stage $changelog (git add $changelog)\n";
43@cached == 2 or die "All '$changelog' changes must be committed aside from version heading\n";
44$cached[0] =~ /^\+\+\+ \Q$changelog\E\n/ or die "$changelog not changed\n";
45$cached[1] eq "+$changes_line" or die "$changelog new line should be: \n\n$changes_line\n";