# HG changeset patch # User Pierre-Yves David # Date 1618396184 -7200 # Node ID b5e7cdb93abc3e26d1d80934d32f26362edecde2 # Parent d689d48527ea597345ca204ad23d65e4165a0cbd relink: use `get_unique_pull_path` The code does not support multiple destination and will probably never do so. So lets use the dedicated API for this case. Differential Revision: https://phab.mercurial-scm.org/D10409 diff -r d689d48527ea -r b5e7cdb93abc hgext/relink.py --- a/hgext/relink.py Wed Apr 14 12:01:27 2021 +0200 +++ b/hgext/relink.py Wed Apr 14 12:29:44 2021 +0200 @@ -19,7 +19,10 @@ registrar, util, ) -from mercurial.utils import stringutil +from mercurial.utils import ( + stringutil, + urlutil, +) cmdtable = {} command = registrar.command(cmdtable) @@ -62,10 +65,11 @@ util, b'samedevice' ): raise error.Abort(_(b'hardlinks are not supported on this system')) - src = hg.repository( - repo.baseui, - ui.expandpath(origin or b'default-relink', origin or b'default'), - ) + + if origin is None and b'default-relink' in ui.paths: + origin = b'default-relink' + path, __ = urlutil.get_unique_pull_path(b'relink', repo, ui, origin) + src = hg.repository(repo.baseui, path) ui.status(_(b'relinking %s to %s\n') % (src.store.path, repo.store.path)) if repo.root == src.root: ui.status(_(b'there is nothing to relink\n'))