1
0

Add git-branch-check script

This commit is contained in:
Noah 2014-05-30 14:24:35 -07:00
parent 6af97cb0fa
commit 4f028a5680
2 changed files with 48 additions and 0 deletions

View File

@ -106,8 +106,12 @@ autocmd BufEnter * :syntax sync fromstart
noremap <F12> <Esc>:syntax sync fromstart<CR>
inoremap <F12> <C-o>:syntax sync fromstart<CR>
" Markdown syntax
autocmd BufRead,BufNewFile *.md set ft=markdown
" Show tab characters
set list listchars=tab:\|\
""""""""""""""
""" Perl stuff
""""""""""""""

44
home/bin/git-branch-check Executable file
View File

@ -0,0 +1,44 @@
#!/usr/bin/env python
# git-branch-check: Compare your local git branches with the remote.
#
# Usage: git-branch-check [remote]
#
# Default remote name is "origin", provide [remote] to change that.
#
# --Kirsle
# https://www.kirsle.net/
import sys
import subprocess
remote = "origin"
if len(sys.argv) >= 2:
remote = sys.argv[1]
local_branch = set()
remote_branch = set()
data = subprocess.check_output(["git", "branch", "-a"])
for line in data.split("\n"):
# Remove the currently active branch indicator and extra spaces.
line = line.strip("*").strip()
if not len(line): continue
# Remote branch?
if line.startswith("remotes/{}/".format(remote)):
line = line.replace("remotes/{}/".format(remote), "")
remote_branch.add(line)
elif line.startswith("remotes/"):
# A different remote?
pass
else:
local_branch.add(line)
# Show comparisons.
print "Local branches that are not on the remote:"
for branch in sorted(local_branch):
if not branch in remote_branch:
print "*", branch
# vim:expandtab