-
Enable Rerere
git config --global rerere.enabled 1
-
If one branch failes with a note about
merge.renamelimit
, try it again with the recommended value.- Set with
git config merge.renameLimit <NUMBER>
- Unset afterwards with
it config --unset merge.renameLimit
- Set with
-
Lookout for something like:
Recorded preimage for 'odoo/addons/base/res/res_partner_view.xml'
in case of a conflict. It indicates that rerere is working.
Last active
August 12, 2018 21:26
-
-
Save blaggacao/bf82a69536035f1e4a84243e447e050d to your computer and use it in GitHub Desktop.
Backport patches from master
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/bash | |
folders=("vendor/odoo/cc/.git" "vendor/odoo/ee/.git") | |
devbranch="master" | |
branches=("11.0") | |
owndev="dev" | |
prefix="remotes/" | |
candidate_branches="remotes/${owndev}/${devbranch}-" | |
RED='\033[0;31m' | |
GREEN='\033[0;32m' | |
NC='\033[0m' # No Color | |
cherry_pick_alert() { | |
echo -e "\n${RED}The cherry pick failed (see logs).${NC}" | |
echo -e "${RED}Please open another terminal and handle the issue.${NC}" | |
read -p "Do you want to continue this script? (Y/n)" -n 1 -r | |
echo -e "" | |
if ! [[ $REPLY =~ ^[Yy]$ ]]; then | |
eval "${gitcmd} cherry-pick --abort" | |
eval "${gitcmd} checkout ${HEAD}" | |
eval "${gitcmd} branch -D ${newbranch}" | |
exit 1 | |
fi | |
cherry_pick_continue | |
} | |
cherry_pick_continue () { | |
if ! eval "${gitcmd} cherry-pick --continue"; then | |
cherry_pick_alert | |
fi | |
} | |
for folder in "${folders[@]}"; do | |
echo -e "\nBackporting patches in ${folder}\n" | |
gitcmd="git --git-dir ${folder}" | |
HEAD=$(eval "${gitcmd} rev-parse --abbrev-ref HEAD") | |
# Use command arguments instead of all detectable branches, if present | |
if ! [[ $# -eq 0 ]] ;then | |
candidates=() | |
detected=($(eval "$gitcmd branch -a | grep '${candidate_branches}'")) | |
for arg in "${@}"; do | |
if [[ $arg != "${owndev}/${devbranch}-"* ]]; then | |
echo -e "${RED}A valid candidate branch would have prefix: '${owndev}/${devbranch}-'. \nGot: '${arg}'.${NC}" | |
exit 1 | |
fi | |
for d in "${detected[@]}";do | |
if [[ "${d}" == "${arg}" ]]; then | |
canidates+="${arg}" | |
fi | |
done | |
done | |
candidates=(${@}) | |
else | |
candidates=($(eval "$gitcmd branch -a | grep '${candidate_branches}'")) | |
fi | |
for branch in "${branches[@]}"; do | |
for candidate in "${candidates[@]}"; do | |
candidate=${candidate#"$prefix"} | |
echo -e "\n${GREEN}Backporting ${candidate} to ${branch}${NC}\n" | |
eval "${gitcmd} checkout ${branch}" | |
# Create appropriate name for target branch | |
newbranch=${branch}${candidate#"$owndev/$devbranch"} | |
eval "${gitcmd} checkout -b ${newbranch}" | |
commits=($(eval "${gitcmd} cherry ${owndev}/${devbranch} ${candidate}" | sed 's/^+ //')) | |
if ! eval "${gitcmd} cherry-pick" "${commits[@]}"; then | |
cherry_pick_alert | |
fi | |
echo -e "\nPushing ${newbranch} to ${owndev}" | |
eval "${gitcmd} push -f ${owndev}" | |
eval "${gitcmd} checkout ${branch}" | |
eval "${gitcmd} branch -D ${newbranch}" | |
done | |
done | |
eval "${gitcmd} checkout ${HEAD}" | |
done |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment