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