# HG changeset patch # User Martin Geisler # Date 1300288026 -3600 # Node ID a73f38d8bbdbab6c8d30b3149daf79546c2d33ef # Parent 0e200e1801f4741f52ce8525ca874369a96b6e5a# Parent 6cc306093b996d88e023d7c9424cb657148aa0b6 merge with stable diff -r 0e200e1801f4 -r a73f38d8bbdb hgext/relink.py --- a/hgext/relink.py Wed Mar 16 13:51:47 2011 +0100 +++ b/hgext/relink.py Wed Mar 16 16:07:06 2011 +0100 @@ -42,8 +42,12 @@ hg.remoteui(repo, opts), ui.expandpath(origin or 'default-relink', origin or 'default')) if not src.local(): - raise util.Abort('must specify local origin repository') + raise util.Abort(_('must specify local origin repository')) ui.status(_('relinking %s to %s\n') % (src.store.path, repo.store.path)) + if repo.root == src.root: + ui.status(_('there is nothing to relink\n')) + return + locallock = repo.lock() try: remotelock = src.lock() diff -r 0e200e1801f4 -r a73f38d8bbdb tests/test-relink.t --- a/tests/test-relink.t Wed Mar 16 13:51:47 2011 +0100 +++ b/tests/test-relink.t Wed Mar 16 16:07:06 2011 +0100 @@ -36,6 +36,13 @@ $ cat $TESTDIR/binfile.bin >> b $ hg ci -m anotherchange +don't sit forever trying to double-lock the source repo + + $ hg relink . + relinking $TESTTMP/repo/.hg/store to $TESTTMP/repo/.hg/store + there is nothing to relink + + Test files are read in binary mode $ python -c "file('.hg/store/data/dummy.i', 'wb').write('a\r\nb\n')"