diff options
author | Jiang Xin <worldhello.net@gmail.com> | 2013-10-14 10:29:39 +0800 |
---|---|---|
committer | Jonathan Nieder <jrnieder@gmail.com> | 2013-10-14 07:00:26 -0700 |
commit | 7fbd422162f2b49bc06a29a063f519450165dc86 (patch) | |
tree | 206305e4a38d3e6858d89f7d11dfb48fb0b082c0 /t/t0060-path-utils.sh | |
parent | daf19a80fa6b7402f8a2efa8f8255b4b5d6b48a9 (diff) | |
download | git-7fbd422162f2b49bc06a29a063f519450165dc86.tar.gz git-7fbd422162f2b49bc06a29a063f519450165dc86.tar.xz |
relative_path should honor dos-drive-prefix
Tvangeste found that the "relative_path" function could not work
properly on Windows if "in" and "prefix" have DOS drive prefix
(such as "C:/windows"). ($gmane/234434)
E.g., When execute: test-path-utils relative_path "C:/a/b" "D:/x/y",
should return "C:/a/b", but returns "../../C:/a/b", which is wrong.
So make relative_path honor DOS drive prefix, and add test cases
for it in t0060.
Reported-by: Tvangeste <i.4m.l33t@yandex.ru>
Helped-by: Johannes Sixt <j6t@kdbg.org>
Signed-off-by: Jiang Xin <worldhello.net@gmail.com>
Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
Diffstat (limited to 't/t0060-path-utils.sh')
-rwxr-xr-x | t/t0060-path-utils.sh | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/t/t0060-path-utils.sh b/t/t0060-path-utils.sh index 92976e040..40dfa2df6 100755 --- a/t/t0060-path-utils.sh +++ b/t/t0060-path-utils.sh @@ -210,6 +210,10 @@ relative_path foo/a/b/ foo/a/b ./ relative_path foo/a foo/a/b ../ relative_path foo/x/y foo/a/b ../../x/y relative_path foo/a/c foo/a/b ../c +relative_path foo/a/b /foo/x/y foo/a/b +relative_path /foo/a/b foo/x/y /foo/a/b +relative_path d:/a/b D:/a/c ../b MINGW +relative_path C:/a/b D:/a/c C:/a/b MINGW relative_path foo/a/b "<empty>" foo/a/b relative_path foo/a/b "<null>" foo/a/b relative_path "<empty>" /foo/a/b ./ |