diff options
| author | Daniel Dunbar <daniel@zuster.org> | 2010-02-25 18:07:07 +0000 |
|---|---|---|
| committer | Daniel Dunbar <daniel@zuster.org> | 2010-02-25 18:07:07 +0000 |
| commit | ce33de5b98f71b4a7f6503eea9498996f781603f (patch) | |
| tree | 34db37550f60130078f1a9570bef1d1261e4b124 | |
| parent | 74cca5a989c551559510721253697d6c9681aa35 (diff) | |
| download | bcm5719-llvm-ce33de5b98f71b4a7f6503eea9498996f781603f.tar.gz bcm5719-llvm-ce33de5b98f71b4a7f6503eea9498996f781603f.zip | |
Add simple script for finding most-recent-rev-before-N in a git-svn repo; useful
when bisecting multiple repos in sync.
llvm-svn: 97150
| -rwxr-xr-x | llvm/utils/git/find-rev | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/llvm/utils/git/find-rev b/llvm/utils/git/find-rev new file mode 100755 index 00000000000..a6161db1898 --- /dev/null +++ b/llvm/utils/git/find-rev @@ -0,0 +1,50 @@ +#!/usr/bin/python + +import os, sys, subprocess + +def main(): + from optparse import OptionParser, OptionGroup + parser = OptionParser("usage: %prog [options] <repo> <revision>") + parser.add_option("", "--dump-section-data", dest="dumpSectionData", + help="Dump the contents of sections", + action="store_true", default=False) + (opts, args) = parser.parse_args() + + if len(args) != 2: + parser.error("invalid number of arguments") + + repo,rev = args + + try: + rev = int(rev) + except: + parser.error("invalid revision argument (not an integer)") + + os.chdir(repo) + p = subprocess.Popen(['git', 'rev-list', 'git-svn', '--pretty'], + stdout=subprocess.PIPE) + + bestRev = bestCommit = None + lastCommit = None + for ln in p.stdout: + if ln.startswith('commit '): + lastCommit = ln.split(' ',2)[1] + elif ln.startswith(' git-svn-id: '): + _,repo,_ = ln.strip().split(' ') + _,lrev = repo.rsplit('@',1) + lrev = int(lrev) + if lrev<=rev: + if bestRev is None or lrev>bestRev: + assert lastCommit + bestCommit = lastCommit + bestRev = lrev + if lrev == rev: + break + + if bestCommit is not None: + print bestCommit + sys.exit(0) + sys.exit(1) + +if __name__=='__main__': + main() |

