|
@ -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 |
|
|
|
|
|
} |