Mercurial > hg > config
comparison python/git_merge_master.py @ 639:3be3b16aeda0
stub for merging from master
author | Jeff Hammel <k0scist@gmail.com> |
---|---|
date | Tue, 04 Mar 2014 11:19:19 -0800 |
parents | |
children | 3059ee249888 |
comparison
equal
deleted
inserted
replaced
638:6dedad97c4eb | 639:3be3b16aeda0 |
---|---|
1 #!/usr/bin/env python | |
2 # -*- coding: utf-8 -*- | |
3 | |
4 """ | |
5 merge master to branch | |
6 """ | |
7 # TODO: combine with k0s.org/hg/gut | |
8 | |
9 import argparse | |
10 import os | |
11 import subprocess | |
12 import sys | |
13 import tempfile | |
14 from which import which | |
15 | |
16 class Git(object): | |
17 def branch(self): | |
18 """returns branch you are on""" | |
19 return self.branches()[0] | |
20 def branches(self): | |
21 """return all branches, active first""" | |
22 output = subprocess.check_output(['git', 'branch']).strip() | |
23 lines = sorted(output.splitlines(), key=lambda line: line.startswith('*'), reverse=True) | |
24 return [line.strip('*').strip() for line in lines] | |
25 | |
26 def diff(self): | |
27 """returns diff between active branch and master""" | |
28 branch = self.branch() | |
29 if branch == 'master': | |
30 raise AssertionError("Cannot be on the master branch") | |
31 merge_base = subprocess.check_output(['git', 'merge-base', 'HEAD', 'master']).strip() | |
32 return subprocess.check_output(['git', 'diff', merge_base]) | |
33 | |
34 def merge(self): | |
35 pass | |
36 | |
37 def main(args=sys.argv[1:]): | |
38 | |
39 parser = argparse.ArgumentParser(description=__doc__) | |
40 options = parser.parse_args(args) | |
41 | |
42 # find branch | |
43 git = Git() | |
44 print (git.diff()) | |
45 | |
46 | |
47 if __name__ == '__main__': | |
48 main() |