2 #===-- merge-git.sh - Merge commit to the stable branch --------------------===#
4 # The LLVM Compiler Infrastructure
6 # This file is distributed under the University of Illinois Open Source
9 #===------------------------------------------------------------------------===#
11 # This script will merge an svn revision to a git repo using git-svn while
12 # preserving the svn commit message.
14 # NOTE: This script has only been tested with the per-project git repositories
15 # and not with the monorepo.
17 # In order to use this script, you must:
18 # 1) Checkout the stable branch you would like to merge the revision into.
19 # 2) Correctly configure the branch as an svn-remote by adding the following to
20 # your .git/config file for your git repo (replace xy with the major/minor
21 # version of the release branch. e.g. release_50 or release_60):
23 #[svn-remote "release_xy"]
24 #url = https://llvm.org/svn/llvm-project/llvm/branches/release_xy
25 #fetch = :refs/remotes/origin/release_xy
27 # Once the script completes successfully, you can push your changes with
30 #===------------------------------------------------------------------------===#
34 echo "usage: `basename $0` [OPTIONS]"
35 echo " -rev NUM The revision to merge into the project"
38 while [ $# -gt 0 ]; do
48 echo "unknown option: $1"
57 if [ -z "$rev" ]; then
58 echo "error: need to specify a revision"
64 # Rebuild revision map
65 git svn find-rev r
$rev origin
/master
&>/dev
/null
67 git_hash
=`git svn find-rev r$rev origin/master`
69 if [ -z "$git_hash" ]; then
70 echo "error: could not determine git commit for r$rev"
74 commit_msg
=`svn log -r $rev https://llvm.org/svn/llvm-project/`
77 git cherry-pick
$git_hash
80 echo "** cherry-pick failed enter 'e' to exit or 'c' when you have finished resolving the conflicts:"
92 git commit
$ammend -m "Merging r$rev:" -m "$commit_msg"