feat(sterni/git-only-push): allow using git cherry-pick -x

I've noticed git only-push is quite useful for creating backports for
nixpkgs stable branches which we need git cherry-pick -x for.

Change-Id: Ie20248d3d0c5fee5cdbd3b3a078439a99f597c02
Reviewed-on: https://cl.tvl.fyi/c/depot/+/12903
Reviewed-by: sterni <sternenseemann@systemli.org>
Tested-by: BuildkiteCI
Autosubmit: sterni <sternenseemann@systemli.org>
This commit is contained in:
sterni 2024-12-22 14:03:23 +01:00 committed by clbot
parent b8342a821b
commit 8459ad94fa

View file

@ -25,7 +25,7 @@ die() {
usage() { usage() {
printf '%s\n' \ printf '%s\n' \
"git only-push [-n] [-b <rev>] -r <remote> -t <refspec> [--] <commit>..." \ "git only-push [-n] [-x] [-b <rev>] -r <remote> -t <refspec> [--] <commit>..." \
>&2 >&2
} }
@ -33,7 +33,7 @@ base=refs/remotes/origin/HEAD
dry=false dry=false
# TODO(sterni): non-interactive mode, e.g. clean up also on cherry-pick failure # TODO(sterni): non-interactive mode, e.g. clean up also on cherry-pick failure
while getopts "b:r:t:nh" opt; do while getopts "b:r:t:nxh" opt; do
case $opt in case $opt in
# TODO(sterni): it is probably too close to --branch? # TODO(sterni): it is probably too close to --branch?
b) b)
@ -48,13 +48,18 @@ while getopts "b:r:t:nh" opt; do
n) n)
dry=true dry=true
;; ;;
x)
cherry_pick_x=true
;;
h|?) h|?)
usage usage
# TODO(sterni): add man page # TODO(sterni): add man page
# shellcheck disable=SC2016
[ "$opt" = "h" ] && printf ' [ "$opt" = "h" ] && printf '
\t-r <remote>\tRemote to push to. \t-r <remote>\tRemote to push to.
\t-t <refspec>\tTarget ref to push to. \t-t <refspec>\tTarget ref to push to.
\t-b <rev>\tOptional: Base revision to cherry-pick commits onto. Defaults to refs/remotes/origin/HEAD. \t-b <rev>\tOptional: Base revision to cherry-pick commits onto. Defaults to refs/remotes/origin/HEAD.
\t-x\t\tUse `git cherry-pick -x` for creating cherry-picks.
\t-n\t\tDry run. \t-n\t\tDry run.
' '
[ "$opt" = "h" ] && exit 0 || exit 100 [ "$opt" = "h" ] && exit 0 || exit 100
@ -106,7 +111,7 @@ for rev in $revs; do
printf 'Would cherry pick %s\n' "$rev" >&2 printf 'Would cherry pick %s\n' "$rev" >&2
else else
no_cherry_pick=false no_cherry_pick=false
git cherry-pick "$rev" || no_cherry_pick=true git cherry-pick ${cherry_pick_x:+-x} "$rev" || no_cherry_pick=true
if $no_cherry_pick; then if $no_cherry_pick; then
tmp="$worktree" tmp="$worktree"
# Prevent cleanup from removing the worktree # Prevent cleanup from removing the worktree