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 |