Mercurial > dotfiles
diff unixSoft/bin/svn-hgmerge.py @ 0:c30d68fbd368
Initial import from svn.
author | Augie Fackler <durin42@gmail.com> |
---|---|
date | Wed, 26 Nov 2008 10:56:09 -0600 |
parents | |
children |
line wrap: on
line diff
new file mode 100755 --- /dev/null +++ b/unixSoft/bin/svn-hgmerge.py @@ -0,0 +1,52 @@ +#!/usr/bin/env python +# ==================================================================== +# Copyright (c) 2007 CollabNet. All rights reserved. +# +# This software is licensed as described in the file COPYING, which +# you should have received as part of this distribution. The terms +# are also available at http://subversion.tigris.org/license-1.html. +# If newer versions of this license are posted there, you may use a +# newer version instead, at your option. +# +# This software consists of voluntary contributions made by many +# individuals. For exact contribution history, see the revision +# history and logs, available at http://subversion.tigris.org/. +# ==================================================================== +HGMERGE_BINARY='hgmerge' + +'''This script allows using Mercurial's hgmerge script with Subversion. +''' + +import os +import sys +import shutil +import tempfile + +def do_hgmerge(base, repo, local, merged): + '''Runs an interactive three-way merge using Mercurial's hgmerge script. + + This function is designed to convert Subversion's four-file interactive merges + into Mercurial's three-file interactive merges so that hgmerge can be used for + interactive merging in subversion. + ''' + # We have to use a temporary directory because FileMerge on OS X fails to save + # the file if it has to write to a file in the CWD. As of now, there's no + # obvious reason for why that is, but this fixes it. + temp_dir = tempfile.mkdtemp(prefix='svn_hgmerge') + local_name = local.split('/')[-1] + temp_file = temp_dir+'/'+local_name + shutil.copyfile(local, temp_file) + args = [HGMERGE_BINARY, temp_file, base, repo] + status = os.spawnvp(os.P_WAIT, HGMERGE_BINARY, args) + print status + if status == 0: + os.unlink(merged) + shutil.copyfile(temp_file, merged) + os.unlink(temp_file) + os.rmdir(temp_dir) + return status + +if __name__ == '__main__': + status = do_hgmerge(sys.argv[1], sys.argv[2], sys.argv[3], sys.argv[4]) + sys.exit(status) +