Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(43)

Side by Side Diff: git_mark_merge_base.py

Issue 184253003: Add git-reup and friends (Closed) Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@freeze_thaw
Patch Set: fix pylint Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « git_map_branches.py ('k') | git_nav_downstream.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 #!/usr/bin/env python
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
4 # found in the LICENSE file.
5
6 """
7 Explicitly set/remove/print the merge-base for the current branch.
8
9 This manually set merge base will be a stand-in for `git merge-base` for the
10 purposes of the chromium depot_tools git extensions. Passing no arguments will
11 just print the effective merge base for the current branch.
12 """
13
14 import argparse
15 import sys
16
17 from subprocess2 import CalledProcessError
18
19 from git_common import remove_merge_base, manual_merge_base, current_branch
20 from git_common import get_or_create_merge_base, hash_one
21
22
23 def main(argv):
24 parser = argparse.ArgumentParser(
25 description=__doc__.strip().splitlines()[0],
26 epilog=' '.join(__doc__.strip().splitlines()[1:]))
27 g = parser.add_mutually_exclusive_group()
28 g.add_argument(
29 'merge_base', nargs='?',
30 help='The new hash to use as the merge base for the current branch'
31 )
32 g.add_argument('--delete', '-d', action='store_true',
33 help='Remove the set mark.')
34 opts = parser.parse_args(argv)
35
36 cur = current_branch()
37
38 if opts.delete:
39 try:
40 remove_merge_base(cur)
41 except CalledProcessError:
42 print "No merge base currently exists for %s." % cur
43 return 0
44
45 if opts.merge_base:
46 try:
47 opts.merge_base = hash_one(opts.merge_base)
48 except CalledProcessError:
49 print >> sys.stderr, (
50 'fatal: could not resolve %s as a commit' % (opts.merge_base)
51 )
52 return 1
53
54 manual_merge_base(cur, opts.merge_base)
55
56 ret = 0
57 actual = get_or_create_merge_base(cur)
58 if opts.merge_base and opts.merge_base != actual:
59 ret = 1
60 print "Invalid merge_base %s" % opts.merge_base
61
62 print "merge_base(%s): %s" % (cur, actual)
63
64 return ret
65
66
67 if __name__ == '__main__':
68 sys.exit(main(sys.argv[1:]))
OLDNEW
« no previous file with comments | « git_map_branches.py ('k') | git_nav_downstream.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698