Fix various limitations of git-backport.py.

I've just tested the script and I'm going to install the patch
to all active branches.

contrib/ChangeLog:

	* git-backport.py: The script did 'git co HEAD~' when
	there was no modified ChangeLog file in a successful
	git cherry pick.
	Run cherry-pick --continue without editor.

(cherry picked from commit 24663f1f6d709daf8913484914ed01af9f7a480a)
parent 77836300
...@@ -30,9 +30,13 @@ if __name__ == '__main__': ...@@ -30,9 +30,13 @@ if __name__ == '__main__':
r = subprocess.run('git cherry-pick -x %s' % args.revision, shell=True) r = subprocess.run('git cherry-pick -x %s' % args.revision, shell=True)
if r.returncode == 0: if r.returncode == 0:
cmd = 'git show --name-only --pretty="" -- "*ChangeLog" |' \ cmd = 'git show --name-only --pretty="" -- "*ChangeLog"'
'xargs git checkout HEAD~' changelogs = subprocess.check_output(cmd, shell=True, encoding='utf8')
subprocess.check_output(cmd, shell=True) changelogs = changelogs.strip()
if changelogs:
for changelog in changelogs.split('\n'):
subprocess.check_output('git checkout HEAD~ %s' % changelog,
shell=True)
subprocess.check_output('git commit --amend --no-edit', shell=True) subprocess.check_output('git commit --amend --no-edit', shell=True)
else: else:
# 1) remove all ChangeLog files from conflicts # 1) remove all ChangeLog files from conflicts
...@@ -55,6 +59,7 @@ if __name__ == '__main__': ...@@ -55,6 +59,7 @@ if __name__ == '__main__':
# try to continue # try to continue
if len(conflicts) == len(changelogs): if len(conflicts) == len(changelogs):
subprocess.check_output('git cherry-pick --continue', shell=True) cmd = 'git -c core.editor=true cherry-pick --continue'
subprocess.check_output(cmd, shell=True)
else: else:
print('Please resolve all remaining file conflicts.') print('Please resolve all remaining file conflicts.')
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment