Просмотр исходного кода

build: add script to find commits suitable for cherry picking

Signed-off-by: Jo-Philipp Wich <jo@mein.io>
Jo-Philipp Wich 3 лет назад
Родитель
Сommit
48a78f01a8
1 измененных файлов с 44 добавлено и 0 удалено
  1. 44 0
      build/find-cherry-pick-candidates.pl

+ 44 - 0
build/find-cherry-pick-candidates.pl

@@ -0,0 +1,44 @@
+#!/usr/bin/env perl
+
+use strict;
+
+sub git {
+	my $res = undef;
+
+	if (open my $git, '-|', 'git', @_) {
+		{
+			local $/;
+			$res = readline $git;
+		}
+
+		chomp $res;
+		close $git;
+	}
+
+	return $res;
+}
+
+my $release_branch = git(qw(rev-parse --abbrev-ref HEAD));
+my $default_branch = system(qw(git show-ref --verify --quiet refs/heads/main)) ? 'master' : 'main';
+
+if ($release_branch eq $default_branch) {
+	printf STDERR "Please execute from a non-default branch\n";
+	exit 1;
+}
+
+open my $cherry, '-|', 'git', 'cherry', '-v', $release_branch, $default_branch;
+
+while (defined(my $line = readline $cherry)) {
+	my ($id, $subject) = $line =~ m!^\+ ([a-f0-9]+) (.*)$!;
+	next unless $id;
+
+	my $found = git('log', '-1', '-E', "--grep=(backported|cherry picked) from commit $id");
+	next if $found;
+
+	my @files = split /\n/, git('show', '--pretty=format:', '--name-only', $id);
+	next unless grep { !/\.pot?$/ } @files;
+
+	print "$id $subject\n";
+}
+
+close $cherry;