lib/fs: Fix MkdirAll failure due to \\?\ (fixes #4762) (#4763)

This commit is contained in:
Simon Frei 2018-02-16 15:19:20 +01:00 committed by Jakob Borg
parent 7a92f6c6b1
commit 6802505dda
3 changed files with 16 additions and 20 deletions

View File

@ -154,6 +154,19 @@ func (f *BasicFilesystem) Mkdir(name string, perm FileMode) error {
return os.Mkdir(name, os.FileMode(perm)) return os.Mkdir(name, os.FileMode(perm))
} }
// MkdirAll creates a directory named path, along with any necessary parents,
// and returns nil, or else returns an error.
// The permission bits perm are used for all directories that MkdirAll creates.
// If path is already a directory, MkdirAll does nothing and returns nil.
func (f *BasicFilesystem) MkdirAll(path string, perm FileMode) error {
path, err := f.rooted(path)
if err != nil {
return err
}
return f.mkdirAll(path, os.FileMode(perm))
}
func (f *BasicFilesystem) Lstat(name string) (FileInfo, error) { func (f *BasicFilesystem) Lstat(name string) (FileInfo, error) {
name, err := f.rooted(name) name, err := f.rooted(name)
if err != nil { if err != nil {

View File

@ -30,12 +30,8 @@ func (f *BasicFilesystem) ReadSymlink(name string) (string, error) {
return os.Readlink(name) return os.Readlink(name)
} }
func (f *BasicFilesystem) MkdirAll(name string, perm FileMode) error { func (f *BasicFilesystem) mkdirAll(path string, perm os.FileMode) error {
name, err := f.rooted(name) return os.MkdirAll(path, perm)
if err != nil {
return err
}
return os.MkdirAll(name, os.FileMode(perm))
} }
// Unhide is a noop on unix, as unhiding files requires renaming them. // Unhide is a noop on unix, as unhiding files requires renaming them.

View File

@ -32,19 +32,6 @@ func (BasicFilesystem) CreateSymlink(target, name string) error {
return errNotSupported return errNotSupported
} }
// MkdirAll creates a directory named path, along with any necessary parents,
// and returns nil, or else returns an error.
// The permission bits perm are used for all directories that MkdirAll creates.
// If path is already a directory, MkdirAll does nothing and returns nil.
func (f *BasicFilesystem) MkdirAll(path string, perm FileMode) error {
path, err := f.rooted(path)
if err != nil {
return err
}
return f.mkdirAll(path, os.FileMode(perm))
}
// Required due to https://github.com/golang/go/issues/10900 // Required due to https://github.com/golang/go/issues/10900
func (f *BasicFilesystem) mkdirAll(path string, perm os.FileMode) error { func (f *BasicFilesystem) mkdirAll(path string, perm os.FileMode) error {
// Fast path: if we can tell whether path is a directory or file, stop with success or error. // Fast path: if we can tell whether path is a directory or file, stop with success or error.
@ -75,7 +62,7 @@ func (f *BasicFilesystem) mkdirAll(path string, perm os.FileMode) error {
// Create parent // Create parent
parent := path[0 : j-1] parent := path[0 : j-1]
if parent != filepath.VolumeName(parent) { if parent != filepath.VolumeName(parent) {
err = os.MkdirAll(parent, perm) err = f.mkdirAll(parent, perm)
if err != nil { if err != nil {
return err return err
} }