util/scripts/gerrit-rebase: allow skipping old history

This might provide a minor speedup but more importantly it allows
skipping commits without Reviewed-on line (which we have a couple of
due to mistakes with git push).

To use, add a line starting with "Gerrit-Rebase-Ignore-CLs-Before:"
pointing out a match string (ie "something that comes after Reviewed-on")
prior to which no changes are considered on the originating branch. The
target branch is still fully considered to avoid issues with changes
that were retargetted out of order around the new cut and would then
make a reappearance (or be skipped).

Change-Id: I9f2679891e93f6d28a781315aebd2aa60a1e3b23
Signed-off-by: Patrick Georgi <pgeorgi@google.com>
Reviewed-on: https://review.coreboot.org/20185
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Martin Roth <martinroth@google.com>
This commit is contained in:
Patrick Georgi 2017-06-13 15:14:09 +02:00
parent 09634d0328
commit 8f8668d87f
1 changed files with 32 additions and 4 deletions

View File

@ -27,7 +27,22 @@ to=$2
# so go for Reviewed-on instead. It's also unique because it # so go for Reviewed-on instead. It's also unique because it
# contains the gerrit instance's host name and the change's number # contains the gerrit instance's host name and the change's number
# on that system. # on that system.
match_string='^ [-A-Za-z]*[Rr]eviewed-on: ' match_string='[-A-Za-z]*[Rr]eviewed-on:'
# Custom root: allow a certain CL (identified by matching either side's
# match_string) to be the new root, instead of using git's common history only.
# This allows cutting down on commits that are re-evaluated on every run.
#
# Use:
# To the commit message of a commit on the "to" side, add
# $custom_root: match_string (the part coming after $match_string)
#
# For a $match_string of ~ "Reviewed-on: " this might
# be "$custom_root: https://example.com/12345"
#
# On traversal, the commit with "$match_string: https://example.com/12345"
# is then considered a base commit.
custom_root='^Gerrit-Rebase-Ignore-CLs-Before:'
# fetch common ancestor # fetch common ancestor
common_base=$(git merge-base ${from} ${to} 2>/dev/null) common_base=$(git merge-base ${from} ${to} 2>/dev/null)
@ -37,9 +52,22 @@ if [ -z "${common_base}" ]; then
exit 1 exit 1
fi fi
from_base=$common_base
# fetch custom root ID
croot_marker=$(git log --pretty=%b -1 --grep "${custom_root}" \
${common_base}..${to} | \
grep "${custom_root}" | cut -d: -f2-)
if [ -n "${croot_marker}" ]; then
from_base=$( ( \
git log --pretty=%H -1 \
--grep "^${match_string}${croot_marker}" \
${from_base}..${from}; echo ${from_base} )| head -1)
fi
# collect matches that are present on the target side # collect matches that are present on the target side
to_matches="$(git log ${common_base}..${to} | \ to_matches="$(git log ${common_base}..${to} | \
grep "${match_string}" | \ grep "^ ${match_string}" | \
cut -d: -f2-)" cut -d: -f2-)"
# start rebase process, but fail immediately by enforcing an invalid todo # start rebase process, but fail immediately by enforcing an invalid todo
@ -49,8 +77,8 @@ GIT_SEQUENCE_EDITOR="echo foo >" \
# write new rebase todo # write new rebase todo
# the appended "commit" line triggers handling of the last log entry # the appended "commit" line triggers handling of the last log entry
commit="" commit=""
(git log --reverse ${common_base}..${from} | \ (git log --reverse ${from_base}..${from} | \
grep -E "(^commit [0-9a-f]{40}\$|${match_string})"; \ grep -E "(^commit [0-9a-f]{40}\$|^ ${match_string})"; \
echo "commit") | \ echo "commit") | \
while read key value; do while read key value; do
if [ "${key}" = "commit" ]; then if [ "${key}" = "commit" ]; then