xref: /aosp_15_r20/external/openthread/tools/gerrit/git-squash-merge.sh (revision cfb92d1480a9e65faed56933e9c12405f45898b4)
1*cfb92d14SAndroid Build Coastguard Worker#!/bin/bash
2*cfb92d14SAndroid Build Coastguard Worker#
3*cfb92d14SAndroid Build Coastguard Worker#  Copyright (c) 2018, The OpenThread Authors.
4*cfb92d14SAndroid Build Coastguard Worker#  All rights reserved.
5*cfb92d14SAndroid Build Coastguard Worker#
6*cfb92d14SAndroid Build Coastguard Worker#  Redistribution and use in source and binary forms, with or without
7*cfb92d14SAndroid Build Coastguard Worker#  modification, are permitted provided that the following conditions are met:
8*cfb92d14SAndroid Build Coastguard Worker#  1. Redistributions of source code must retain the above copyright
9*cfb92d14SAndroid Build Coastguard Worker#     notice, this list of conditions and the following disclaimer.
10*cfb92d14SAndroid Build Coastguard Worker#  2. Redistributions in binary form must reproduce the above copyright
11*cfb92d14SAndroid Build Coastguard Worker#     notice, this list of conditions and the following disclaimer in the
12*cfb92d14SAndroid Build Coastguard Worker#     documentation and/or other materials provided with the distribution.
13*cfb92d14SAndroid Build Coastguard Worker#  3. Neither the name of the copyright holder nor the
14*cfb92d14SAndroid Build Coastguard Worker#     names of its contributors may be used to endorse or promote products
15*cfb92d14SAndroid Build Coastguard Worker#     derived from this software without specific prior written permission.
16*cfb92d14SAndroid Build Coastguard Worker#
17*cfb92d14SAndroid Build Coastguard Worker#  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18*cfb92d14SAndroid Build Coastguard Worker#  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19*cfb92d14SAndroid Build Coastguard Worker#  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20*cfb92d14SAndroid Build Coastguard Worker#  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
21*cfb92d14SAndroid Build Coastguard Worker#  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22*cfb92d14SAndroid Build Coastguard Worker#  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23*cfb92d14SAndroid Build Coastguard Worker#  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24*cfb92d14SAndroid Build Coastguard Worker#  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25*cfb92d14SAndroid Build Coastguard Worker#  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26*cfb92d14SAndroid Build Coastguard Worker#  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27*cfb92d14SAndroid Build Coastguard Worker#  POSSIBILITY OF SUCH DAMAGE.
28*cfb92d14SAndroid Build Coastguard Worker#
29*cfb92d14SAndroid Build Coastguard Worker
30*cfb92d14SAndroid Build Coastguard Workerdie()
31*cfb92d14SAndroid Build Coastguard Worker{
32*cfb92d14SAndroid Build Coastguard Worker    echo " *** ERROR: " "$*"
33*cfb92d14SAndroid Build Coastguard Worker    exit 1
34*cfb92d14SAndroid Build Coastguard Worker}
35*cfb92d14SAndroid Build Coastguard Worker
36*cfb92d14SAndroid Build Coastguard Workerdisplay_usage()
37*cfb92d14SAndroid Build Coastguard Worker{
38*cfb92d14SAndroid Build Coastguard Worker    echo "Squash merge a given branch into the current branch"
39*cfb92d14SAndroid Build Coastguard Worker    echo ""
40*cfb92d14SAndroid Build Coastguard Worker    echo "This command squash merges all commits from a given branch into the current branch"
41*cfb92d14SAndroid Build Coastguard Worker    echo "By default, the changes are committed with a commit message which includes the list of all squashed commits"
42*cfb92d14SAndroid Build Coastguard Worker    echo "(use --no-commit and --no-list options to change default behavior)."
43*cfb92d14SAndroid Build Coastguard Worker    echo ""
44*cfb92d14SAndroid Build Coastguard Worker    echo "Usage: $(basename "$0") [--no-list] [--no-commit] <branch> [<commit msg>]"
45*cfb92d14SAndroid Build Coastguard Worker    echo ""
46*cfb92d14SAndroid Build Coastguard Worker    echo "     <branch>       Specifies the name of branch to merge into current branch"
47*cfb92d14SAndroid Build Coastguard Worker    echo "     <commit msg>   An optional parameter specifying text to add to the commit message"
48*cfb92d14SAndroid Build Coastguard Worker    echo "Options:"
49*cfb92d14SAndroid Build Coastguard Worker    echo "     --no-list      The commit message will not include the list of squashed commits"
50*cfb92d14SAndroid Build Coastguard Worker    echo "     --no-commit    Squash and stage the changes but do not commit "
51*cfb92d14SAndroid Build Coastguard Worker    echo ""
52*cfb92d14SAndroid Build Coastguard Worker}
53*cfb92d14SAndroid Build Coastguard Worker
54*cfb92d14SAndroid Build Coastguard WorkerSHOULD_ADD_LIST=true
55*cfb92d14SAndroid Build Coastguard WorkerSHOULD_COMMIT=true
56*cfb92d14SAndroid Build Coastguard Worker
57*cfb92d14SAndroid Build Coastguard Workerwhile test $# != 0; do
58*cfb92d14SAndroid Build Coastguard Worker    case "$1" in
59*cfb92d14SAndroid Build Coastguard Worker        --help | -h | -[?])
60*cfb92d14SAndroid Build Coastguard Worker            display_usage
61*cfb92d14SAndroid Build Coastguard Worker            exit 0
62*cfb92d14SAndroid Build Coastguard Worker            ;;
63*cfb92d14SAndroid Build Coastguard Worker
64*cfb92d14SAndroid Build Coastguard Worker        --no-list)
65*cfb92d14SAndroid Build Coastguard Worker            SHOULD_ADD_LIST=false
66*cfb92d14SAndroid Build Coastguard Worker            ;;
67*cfb92d14SAndroid Build Coastguard Worker        --no-commit)
68*cfb92d14SAndroid Build Coastguard Worker            SHOULD_COMMIT=false
69*cfb92d14SAndroid Build Coastguard Worker            ;;
70*cfb92d14SAndroid Build Coastguard Worker        --debug) set -x ;;
71*cfb92d14SAndroid Build Coastguard Worker        --*) die "Unknown argument $1" ;;
72*cfb92d14SAndroid Build Coastguard Worker        -*) die "Unknown argument $1" ;;
73*cfb92d14SAndroid Build Coastguard Worker        *)
74*cfb92d14SAndroid Build Coastguard Worker            break
75*cfb92d14SAndroid Build Coastguard Worker            ;;
76*cfb92d14SAndroid Build Coastguard Worker    esac
77*cfb92d14SAndroid Build Coastguard Worker    shift
78*cfb92d14SAndroid Build Coastguard Workerdone
79*cfb92d14SAndroid Build Coastguard Worker
80*cfb92d14SAndroid Build Coastguard Workerif [ "$#" -eq 0 ]; then
81*cfb92d14SAndroid Build Coastguard Worker    display_usage
82*cfb92d14SAndroid Build Coastguard Worker    die "No branch name"
83*cfb92d14SAndroid Build Coastguard Workerfi
84*cfb92d14SAndroid Build Coastguard Worker
85*cfb92d14SAndroid Build Coastguard Workerif [ "$#" -gt 2 ]; then
86*cfb92d14SAndroid Build Coastguard Worker    display_usage
87*cfb92d14SAndroid Build Coastguard Worker    die "Extra argument"
88*cfb92d14SAndroid Build Coastguard Workerfi
89*cfb92d14SAndroid Build Coastguard Worker
90*cfb92d14SAndroid Build Coastguard WorkerNEWLINE=$'\n'
91*cfb92d14SAndroid Build Coastguard Worker
92*cfb92d14SAndroid Build Coastguard Workerbranch="$1"
93*cfb92d14SAndroid Build Coastguard Workercur_branch=$(git rev-parse --abbrev-ref HEAD)
94*cfb92d14SAndroid Build Coastguard Worker
95*cfb92d14SAndroid Build Coastguard Worker# Get the list of commits (diff between current and new branch)
96*cfb92d14SAndroid Build Coastguard Worker# Note that the list starts with older commits
97*cfb92d14SAndroid Build Coastguard Worker
98*cfb92d14SAndroid Build Coastguard Workerif ${SHOULD_ADD_LIST}; then
99*cfb92d14SAndroid Build Coastguard Worker    commit_list=$(git log HEAD.."$branch" --oneline --decorate=no --reverse)
100*cfb92d14SAndroid Build Coastguard Workerelse
101*cfb92d14SAndroid Build Coastguard Worker    commit_list=""
102*cfb92d14SAndroid Build Coastguard Workerfi
103*cfb92d14SAndroid Build Coastguard Worker
104*cfb92d14SAndroid Build Coastguard Workercommit_msg_header="Squash merge '$branch' into '$cur_branch'"
105*cfb92d14SAndroid Build Coastguard Worker
106*cfb92d14SAndroid Build Coastguard Workerif [ -z "$2" ]; then
107*cfb92d14SAndroid Build Coastguard Worker    commit_msg="${commit_msg_header}${NEWLINE}${NEWLINE}${commit_list}"
108*cfb92d14SAndroid Build Coastguard Workerelse
109*cfb92d14SAndroid Build Coastguard Worker    commit_msg="${commit_msg_header}${NEWLINE}${NEWLINE}$2${NEWLINE}${NEWLINE}${commit_list}"
110*cfb92d14SAndroid Build Coastguard Workerfi
111*cfb92d14SAndroid Build Coastguard Worker
112*cfb92d14SAndroid Build Coastguard Workergit merge --squash "$branch" 1>/dev/null 2>/dev/null || die "Failed to perform 'git merge -squash $branch'"
113*cfb92d14SAndroid Build Coastguard Worker
114*cfb92d14SAndroid Build Coastguard Worker# Check if there is anything staged
115*cfb92d14SAndroid Build Coastguard Workerif ! git diff --cached --quiet; then
116*cfb92d14SAndroid Build Coastguard Worker    echo "No changes to commit when squash merging branch '$branch' into '$cur_branch'"
117*cfb92d14SAndroid Build Coastguard Worker    exit 0
118*cfb92d14SAndroid Build Coastguard Workerfi
119*cfb92d14SAndroid Build Coastguard Worker
120*cfb92d14SAndroid Build Coastguard Workerif ${SHOULD_COMMIT}; then
121*cfb92d14SAndroid Build Coastguard Worker    # Commit the staged changes
122*cfb92d14SAndroid Build Coastguard Worker    git commit -m "$commit_msg" 1>/dev/null 2>/dev/null || die "git commit failed${NEWLINE}${NEWLINE}$(cat "$TMP")"
123*cfb92d14SAndroid Build Coastguard Worker
124*cfb92d14SAndroid Build Coastguard Worker    git log -1
125*cfb92d14SAndroid Build Coastguard Worker
126*cfb92d14SAndroid Build Coastguard Worker    echo "${NEWLINE}Successfully squash merged branch '$branch' into '$cur_branch'"
127*cfb92d14SAndroid Build Coastguard Workerelse
128*cfb92d14SAndroid Build Coastguard Worker    echo "Successfully prepared squash merge of branch '$branch' into '$cur_branch' - ready to commit"
129*cfb92d14SAndroid Build Coastguard Workerfi
130