mirror of
https://github.com/golang/go
synced 2024-11-22 09:54:40 -07:00
path/filepath: do not remove prefix "." when following path contains ":".
Fixes #52476 Change-Id: I9eb72ac7dbccd6322d060291f31831dc389eb9bb Reviewed-on: https://go-review.googlesource.com/c/go/+/401595 Auto-Submit: Ian Lance Taylor <iant@google.com> Reviewed-by: Alex Brainman <alex.brainman@gmail.com> Run-TryBot: Ian Lance Taylor <iant@google.com> Reviewed-by: Ian Lance Taylor <iant@google.com> Reviewed-by: Damien Neil <dneil@google.com> TryBot-Result: Gopher Robot <gobot@golang.org>
This commit is contained in:
parent
b6bcd0d135
commit
9cd1818a7d
@ -117,9 +117,21 @@ func Clean(path string) string {
|
||||
case os.IsPathSeparator(path[r]):
|
||||
// empty path element
|
||||
r++
|
||||
case path[r] == '.' && (r+1 == n || os.IsPathSeparator(path[r+1])):
|
||||
case path[r] == '.' && r+1 == n:
|
||||
// . element
|
||||
r++
|
||||
case path[r] == '.' && os.IsPathSeparator(path[r+1]):
|
||||
// ./ element
|
||||
r++
|
||||
|
||||
for r < len(path) && os.IsPathSeparator(path[r]) {
|
||||
r++
|
||||
}
|
||||
if out.w == 0 && volumeNameLen(path[r:]) > 0 {
|
||||
// When joining prefix "." and an absolute path on Windows,
|
||||
// the prefix should not be removed.
|
||||
out.append('.')
|
||||
}
|
||||
case path[r] == '.' && path[r+1] == '.' && (r+2 == n || os.IsPathSeparator(path[r+2])):
|
||||
// .. element: remove to last separator
|
||||
r += 2
|
||||
|
@ -93,6 +93,9 @@ var wincleantests = []PathTest{
|
||||
{`//host/share/foo/../baz`, `\\host\share\baz`},
|
||||
{`\\a\b\..\c`, `\\a\b\c`},
|
||||
{`\\a\b`, `\\a\b`},
|
||||
{`.\c:`, `.\c:`},
|
||||
{`.\c:\foo`, `.\c:\foo`},
|
||||
{`.\c:foo`, `.\c:foo`},
|
||||
}
|
||||
|
||||
func TestClean(t *testing.T) {
|
||||
|
@ -534,3 +534,29 @@ func TestNTNamespaceSymlink(t *testing.T) {
|
||||
t.Errorf(`EvalSymlinks(%q): got %q, want %q`, filelink, got, want)
|
||||
}
|
||||
}
|
||||
|
||||
func TestIssue52476(t *testing.T) {
|
||||
tests := []struct {
|
||||
lhs, rhs string
|
||||
want string
|
||||
}{
|
||||
{`..\.`, `C:`, `..\C:`},
|
||||
{`..`, `C:`, `..\C:`},
|
||||
{`.`, `:`, `:`},
|
||||
{`.`, `C:`, `.\C:`},
|
||||
{`.`, `C:/a/b/../c`, `.\C:\a\c`},
|
||||
{`.`, `\C:`, `.\C:`},
|
||||
{`C:\`, `.`, `C:\`},
|
||||
{`C:\`, `C:\`, `C:\C:`},
|
||||
{`C`, `:`, `C\:`},
|
||||
{`\.`, `C:`, `\C:`},
|
||||
{`\`, `C:`, `\C:`},
|
||||
}
|
||||
|
||||
for _, test := range tests {
|
||||
got := filepath.Join(test.lhs, test.rhs)
|
||||
if got != test.want {
|
||||
t.Errorf(`Join(%q, %q): got %q, want %q`, test.lhs, test.rhs, got, test.want)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user