Mercurial > dotfiles
view unixSoft/bin/hgimp @ 504:1b863525992d
icargo: hacky tool to auto-run cargo for me
author | Augie Fackler <raf@durin42.com> |
---|---|
date | Sat, 24 Oct 2020 23:59:13 -0400 |
parents | 957632211aa3 |
children | 6cc5a0550281 |
line wrap: on
line source
#!/usr/bin/env python import argparse import os import subprocess import sys _MAP = { 'hg': '~/Programming/hg/crew', 'hglib': '~/Programming/hg/python-hglib', 'hgsubversion': '~/Programming/hg/hgsubversion', 'hg-git': '~/Programming/hg/hg-git', 'topics': '~/Programming/hg/topic', } def main(argv): p = argparse.ArgumentParser('import patches') p.add_argument('repo', type=str, nargs=1, help='repo name to apply patches to') p.add_argument('--partial', action='store_true', help='Commit partially-applied patches.') args = p.parse_args(argv[1:]) name, = args.repo if name in _MAP: repo = _MAP[name] else: c = [] for n in _MAP: if n.startswith(name): c.append(n) if not c: print 'abort: no repo named %s' % name sys.exit(1) elif len(c) != 1: print 'abort: ambiguous repo name %s matches %s' % ( name, ', '.join(c)) sys.exit(1) repo = _MAP[c[0]] importargs = ['hg', '-R', repo, 'import', '--obsolete'] if args.partial: importargs.append('--partial') importargs.append('-') hg = subprocess.Popen(importargs, stdin=subprocess.PIPE) hg.stdin.write(sys.stdin.read()) hg.stdin.close() hg.wait() sys.exit(hg.returncode) if __name__ == '__main__': main(argv=sys.argv)