Adjust for window path

fix https://github.com/chrislusf/seaweedfs/issues/161
This commit is contained in:
chrislusf 2015-07-08 01:43:26 -07:00
parent 3b2645979d
commit 95855da282

View file

@ -62,7 +62,7 @@ func NewDirectoryManagerInMap(dirLogFile string) (dm *DirectoryManagerInMap, err
//dm.Root do not use NewDirectoryEntryInMap, since dm.max will be changed //dm.Root do not use NewDirectoryEntryInMap, since dm.max will be changed
dm.Root = &DirectoryEntryInMap{SubDirectories: make(map[string]*DirectoryEntryInMap)} dm.Root = &DirectoryEntryInMap{SubDirectories: make(map[string]*DirectoryEntryInMap)}
if dm.logFile, err = os.OpenFile(dirLogFile, os.O_RDWR|os.O_CREATE, 0644); err != nil { if dm.logFile, err = os.OpenFile(dirLogFile, os.O_RDWR|os.O_CREATE, 0644); err != nil {
return nil, fmt.Errorf("cannot write directory log file %s.idx: %v", dirLogFile, err) return nil, fmt.Errorf("cannot write directory log file %s: %v", dirLogFile, err)
} }
return dm, dm.load() return dm, dm.load()
} }
@ -128,7 +128,7 @@ func (dm *DirectoryManagerInMap) findDirectory(dirPath string) (*DirectoryEntryI
if dirPath == "" { if dirPath == "" {
return dm.Root, nil return dm.Root, nil
} }
dirPath = filepath.Clean(dirPath) dirPath = CleanFilePath(dirPath)
if dirPath == "/" { if dirPath == "/" {
return dm.Root, nil return dm.Root, nil
} }
@ -152,7 +152,7 @@ func (dm *DirectoryManagerInMap) FindDirectory(dirPath string) (filer.DirectoryI
} }
func (dm *DirectoryManagerInMap) loadDirectory(dirPath string, dirId filer.DirectoryId) error { func (dm *DirectoryManagerInMap) loadDirectory(dirPath string, dirId filer.DirectoryId) error {
dirPath = filepath.Clean(dirPath) dirPath = CleanFilePath(dirPath)
if dirPath == "/" { if dirPath == "/" {
return nil return nil
} }
@ -180,7 +180,7 @@ func (dm *DirectoryManagerInMap) loadDirectory(dirPath string, dirId filer.Direc
} }
func (dm *DirectoryManagerInMap) makeDirectory(dirPath string) (dir *DirectoryEntryInMap, created bool) { func (dm *DirectoryManagerInMap) makeDirectory(dirPath string) (dir *DirectoryEntryInMap, created bool) {
dirPath = filepath.Clean(dirPath) dirPath = CleanFilePath(dirPath)
if dirPath == "/" { if dirPath == "/" {
return dm.Root, false return dm.Root, false
} }
@ -257,3 +257,11 @@ func (dm *DirectoryManagerInMap) DeleteDirectory(dirPath string) error {
dm.log("del", dirPath) dm.log("del", dirPath)
return nil return nil
} }
func CleanFilePath(fp string) string {
ret := filepath.Clean(fp)
if os.PathSeparator == '\\' {
return strings.Replace(ret, "\\", "/", -1)
}
return ret
}