# HG changeset patch # User Matt Harbison # Date 1509669331 14400 # Node ID f445b10dc7fb3495d24d1c22b0996148864c77f7 # Parent 95f54cec00258ffa4caa8df38e4ecb265aa7a0a3 pathutil: use util.pathto() to calculate relative cwd in canonpath() os.path.relpath() exploded if the 'root' and 'cwd' directories had different drive letters. I noticed this in TortoiseHg when typing a fileset into the filter, and it kept complaining until the closing '()' was typed. This was reproducible on the command line with: $ cd /d $ hg -R /c/Users/Matt/Projects/hg files 'set:e' Traceback (most recent call last): ... File "mercurial\pathutil.pyc", line 182, in canonpath File "ntpath.pyc", line 529, in relpath ValueError: path is on drive c:, start on drive d: diff -r 95f54cec0025 -r f445b10dc7fb mercurial/pathutil.py --- a/mercurial/pathutil.py Wed Nov 01 16:54:39 2017 -0500 +++ b/mercurial/pathutil.py Thu Nov 02 20:35:31 2017 -0400 @@ -184,8 +184,10 @@ try: if cwd != root: canonpath(root, root, myname, auditor) - hint = (_("consider using '--cwd %s'") - % os.path.relpath(root, cwd)) + relpath = util.pathto(root, cwd, '') + if relpath[-1] == pycompat.ossep: + relpath = relpath[:-1] + hint = (_("consider using '--cwd %s'") % relpath) except error.Abort: pass