[llvm-exegesis] Fix missing std::move.
[llvm-complete.git] / utils / release / merge-git.sh
blob81d577db9d62499de19ca7124b923a792dffba05
1 #!/bin/bash
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
7 # License.
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
28 # git-svn dcommit
30 #===------------------------------------------------------------------------===#
33 usage() {
34 echo "usage: `basename $0` [OPTIONS]"
35 echo " -rev NUM The revision to merge into the project"
38 while [ $# -gt 0 ]; do
39 case $1 in
40 -rev | --rev | -r )
41 shift
42 rev=$1
44 -h | -help | --help )
45 usage
47 * )
48 echo "unknown option: $1"
49 echo ""
50 usage
51 exit 1
53 esac
54 shift
55 done
57 if [ -z "$rev" ]; then
58 echo "error: need to specify a revision"
59 echo
60 usage
61 exit 1
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"
71 exit 1
74 commit_msg=`svn log -r $rev https://llvm.org/svn/llvm-project/`
75 ammend="--amend"
77 git cherry-pick $git_hash
78 if [ $? -ne 0 ]; then
79 echo ""
80 echo "** cherry-pick failed enter 'e' to exit or 'c' when you have finished resolving the conflicts:"
81 read option
82 case $option in
84 ammend=""
87 exit 1
89 esac
92 git commit $ammend -m "Merging r$rev:" -m "$commit_msg"