Mercurial > hg > config
annotate python/git_merge_master.py @ 929:7c4be71a560b default tip
remove old aliases
| author | Jeff Hammel <k0scist@gmail.com> | 
|---|---|
| date | Mon, 20 Oct 2025 15:22:19 -0700 | 
| parents | 3059ee249888 | 
| children | 
| rev | line source | 
|---|---|
| 639 | 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 | |
| 640 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 34 def checkout(self, branch): | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 35 subprocess.check_output(['git', 'checkout', branch]) | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 36 | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 37 def pull(self, branch='master'): | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 38 current_branch = self.branch() | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 39 if current_branch != branch: | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 40 self.checkout(branch) | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 41 subprocess.check_output(['git', 'pull', 'origin', branch]) | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 42 if current_branch != branch: | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 43 self.checkout(current_branch) | 
| 
3059ee249888
STUB: python/git_merge_master.py
 Jeff Hammel <k0scist@gmail.com> parents: 
639diff
changeset | 44 | 
| 639 | 45 def merge(self): | 
| 46 pass | |
| 47 | |
| 48 def main(args=sys.argv[1:]): | |
| 49 | |
| 50 parser = argparse.ArgumentParser(description=__doc__) | |
| 51 options = parser.parse_args(args) | |
| 52 | |
| 53 # find branch | |
| 54 git = Git() | |
| 55 print (git.diff()) | |
| 56 | |
| 57 | |
| 58 if __name__ == '__main__': | |
| 59 main() | 
