// Copyright 2016 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package vfs import ( "fmt" "os" "time" ) // NewNameSpace returns a NameSpace pre-initialized with an empty // emulated directory mounted on the root mount point "/". This // allows directory traversal routines to work properly even if // a folder is not explicitly mounted at root by the user. func NewNameSpace() NameSpace { ns := NameSpace{} ns.Bind("/", &emptyVFS{}, "/", BindReplace) return ns } // type emptyVFS emulates a FileSystem consisting of an empty directory type emptyVFS struct{} // Open implements Opener. Since emptyVFS is an empty directory, all // attempts to open a file should returns errors. func (e *emptyVFS) Open(path string) (ReadSeekCloser, error) { if path == "/" { return nil, fmt.Errorf("open: / is a directory") } return nil, os.ErrNotExist } // Stat returns os.FileInfo for an empty directory if the path is // is root "/" or error. os.FileInfo is implemented by emptyVFS func (e *emptyVFS) Stat(path string) (os.FileInfo, error) { if path == "/" { return e, nil } return nil, os.ErrNotExist } func (e *emptyVFS) Lstat(path string) (os.FileInfo, error) { return e.Stat(path) } // ReadDir returns an empty os.FileInfo slice for "/", else error. func (e *emptyVFS) ReadDir(path string) ([]os.FileInfo, error) { if path == "/" { return []os.FileInfo{}, nil } return nil, os.ErrNotExist } func (e *emptyVFS) String() string { return "emptyVFS(/)" } func (e *emptyVFS) RootType(path string) RootType { return "" } // These functions below implement os.FileInfo for the single // empty emulated directory. func (e *emptyVFS) Name() string { return "/" } func (e *emptyVFS) Size() int64 { return 0 } func (e *emptyVFS) Mode() os.FileMode { return os.ModeDir | os.ModePerm } func (e *emptyVFS) ModTime() time.Time { return time.Time{} } func (e *emptyVFS) IsDir() bool { return true } func (e *emptyVFS) Sys() interface{} { return nil }