| OLD | NEW |
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 # Copyright 2014 The Chromium Authors. All rights reserved. | 2 # Copyright 2014 The Chromium Authors. All rights reserved. |
| 3 # Use of this source code is governed by a BSD-style license that can be | 3 # Use of this source code is governed by a BSD-style license that can be |
| 4 # found in the LICENSE file. | 4 # found in the LICENSE file. |
| 5 | 5 |
| 6 import argparse | 6 import argparse |
| 7 import sys | 7 import sys |
| 8 | 8 |
| 9 import subprocess2 | 9 import subprocess2 |
| 10 | 10 |
| 11 from git_common import run, root, set_config, get_or_create_merge_base, tags | 11 from git_common import run, root, set_config, get_or_create_merge_base, tags |
| 12 from git_common import hash_one | 12 from git_common import hash_one |
| 13 | 13 |
| 14 | 14 |
| 15 def main(args): | 15 def main(args): |
| 16 parser = argparse.ArgumentParser( | 16 parser = argparse.ArgumentParser( |
| 17 formatter_class=argparse.ArgumentDefaultsHelpFormatter | 17 formatter_class=argparse.ArgumentDefaultsHelpFormatter |
| 18 ) | 18 ) |
| 19 parser.add_argument('branch_name') | 19 parser.add_argument('branch_name') |
| 20 g = parser.add_mutually_exclusive_group() | 20 g = parser.add_mutually_exclusive_group() |
| 21 g.add_argument('--upstream_current', action='store_true', | 21 g.add_argument('--upstream-current', '--upstream_current', |
| 22 action='store_true', |
| 22 help='set upstream branch to current branch.') | 23 help='set upstream branch to current branch.') |
| 23 g.add_argument('--upstream', metavar='REF', default=root(), | 24 g.add_argument('--upstream', metavar='REF', default=root(), |
| 24 help='upstream branch (or tag) to track.') | 25 help='upstream branch (or tag) to track.') |
| 25 g.add_argument('--lkgr', action='store_const', const='lkgr', dest='upstream', | 26 g.add_argument('--lkgr', action='store_const', const='lkgr', dest='upstream', |
| 26 help='set basis ref for new branch to lkgr.') | 27 help='set basis ref for new branch to lkgr.') |
| 27 | 28 |
| 28 opts = parser.parse_args(args) | 29 opts = parser.parse_args(args) |
| 29 | 30 |
| 30 try: | 31 try: |
| 31 if opts.upstream_current: | 32 if opts.upstream_current: |
| (...skipping 12 matching lines...) Expand all Loading... |
| 44 get_or_create_merge_base(opts.branch_name) | 45 get_or_create_merge_base(opts.branch_name) |
| 45 except subprocess2.CalledProcessError as cpe: | 46 except subprocess2.CalledProcessError as cpe: |
| 46 sys.stdout.write(cpe.stdout) | 47 sys.stdout.write(cpe.stdout) |
| 47 sys.stderr.write(cpe.stderr) | 48 sys.stderr.write(cpe.stderr) |
| 48 return 1 | 49 return 1 |
| 49 sys.stderr.write('Switched to branch %s.\n' % opts.branch_name) | 50 sys.stderr.write('Switched to branch %s.\n' % opts.branch_name) |
| 50 | 51 |
| 51 | 52 |
| 52 if __name__ == '__main__': # pragma: no cover | 53 if __name__ == '__main__': # pragma: no cover |
| 53 sys.exit(main(sys.argv[1:])) | 54 sys.exit(main(sys.argv[1:])) |
| OLD | NEW |