Kaydet (Commit) 50f7d7e2 authored tarafından Hirokazu Yamamoto's avatar Hirokazu Yamamoto

Issue #5117: Fixed root directory related issue on posixpath.relpath() and

ntpath.relpath().
üst 04910475
...@@ -488,8 +488,8 @@ def relpath(path, start=curdir): ...@@ -488,8 +488,8 @@ def relpath(path, start=curdir):
if not path: if not path:
raise ValueError("no path specified") raise ValueError("no path specified")
start_list = abspath(start).split(sep) start_list = [x for x in abspath(start).split(sep) if x]
path_list = abspath(path).split(sep) path_list = [x for x in abspath(path).split(sep) if x]
if start_list[0].lower() != path_list[0].lower(): if start_list[0].lower() != path_list[0].lower():
unc_path, rest = splitunc(path) unc_path, rest = splitunc(path)
unc_start, rest = splitunc(start) unc_start, rest = splitunc(start)
......
...@@ -403,8 +403,8 @@ def relpath(path, start=curdir): ...@@ -403,8 +403,8 @@ def relpath(path, start=curdir):
if not path: if not path:
raise ValueError("no path specified") raise ValueError("no path specified")
start_list = abspath(start).split(sep) start_list = [x for x in abspath(start).split(sep) if x]
path_list = abspath(path).split(sep) path_list = [x for x in abspath(path).split(sep) if x]
# Work out how much of the filepath is shared by start and path. # Work out how much of the filepath is shared by start and path.
i = len(commonprefix([start_list, path_list])) i = len(commonprefix([start_list, path_list]))
......
...@@ -178,6 +178,16 @@ class TestNtpath(unittest.TestCase): ...@@ -178,6 +178,16 @@ class TestNtpath(unittest.TestCase):
tester('ntpath.relpath("a", "b/c")', '..\\..\\a') tester('ntpath.relpath("a", "b/c")', '..\\..\\a')
tester('ntpath.relpath("//conky/mountpoint/a", "//conky/mountpoint/b/c")', '..\\..\\a') tester('ntpath.relpath("//conky/mountpoint/a", "//conky/mountpoint/b/c")', '..\\..\\a')
tester('ntpath.relpath("a", "a")', '.') tester('ntpath.relpath("a", "a")', '.')
tester('ntpath.relpath("/foo/bar/bat", "/x/y/z")', '..\\..\\..\\foo\\bar\\bat')
tester('ntpath.relpath("/foo/bar/bat", "/foo/bar")', 'bat')
tester('ntpath.relpath("/foo/bar/bat", "/")', 'foo\\bar\\bat')
tester('ntpath.relpath("/", "/foo/bar/bat")', '..\\..\\..')
tester('ntpath.relpath("/foo/bar/bat", "/x")', '..\\foo\\bar\\bat')
tester('ntpath.relpath("/x", "/foo/bar/bat")', '..\\..\\..\\x')
tester('ntpath.relpath("/", "/")', '.')
tester('ntpath.relpath("/a", "/a")', '.')
tester('ntpath.relpath("/a/b", "/a/b")', '.')
tester('ntpath.relpath("c:/foo", "C:/FOO")', '.')
class NtCommonTest(test_genericpath.CommonTest): class NtCommonTest(test_genericpath.CommonTest):
......
...@@ -322,6 +322,15 @@ class PosixPathTest(unittest.TestCase): ...@@ -322,6 +322,15 @@ class PosixPathTest(unittest.TestCase):
self.assertEqual(posixpath.relpath("a/b", "../c"), "../"+curdir+"/a/b") self.assertEqual(posixpath.relpath("a/b", "../c"), "../"+curdir+"/a/b")
self.assertEqual(posixpath.relpath("a", "b/c"), "../../a") self.assertEqual(posixpath.relpath("a", "b/c"), "../../a")
self.assertEqual(posixpath.relpath("a", "a"), ".") self.assertEqual(posixpath.relpath("a", "a"), ".")
self.assertEqual(posixpath.relpath("/foo/bar/bat", "/x/y/z"), '../../../foo/bar/bat')
self.assertEqual(posixpath.relpath("/foo/bar/bat", "/foo/bar"), 'bat')
self.assertEqual(posixpath.relpath("/foo/bar/bat", "/"), 'foo/bar/bat')
self.assertEqual(posixpath.relpath("/", "/foo/bar/bat"), '../../..')
self.assertEqual(posixpath.relpath("/foo/bar/bat", "/x"), '../foo/bar/bat')
self.assertEqual(posixpath.relpath("/x", "/foo/bar/bat"), '../../../x')
self.assertEqual(posixpath.relpath("/", "/"), '.')
self.assertEqual(posixpath.relpath("/a", "/a"), '.')
self.assertEqual(posixpath.relpath("/a/b", "/a/b"), '.')
finally: finally:
os.getcwd = real_getcwd os.getcwd = real_getcwd
......
...@@ -60,6 +60,9 @@ Core and Builtins ...@@ -60,6 +60,9 @@ Core and Builtins
Library Library
------- -------
- Issue #5117: Fixed root directory related issue on posixpath.relpath() and
ntpath.relpath().
- Issue 9409: Fix the regex to match all kind of filenames, for interactive - Issue 9409: Fix the regex to match all kind of filenames, for interactive
debugging in doctests. debugging in doctests.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment