feat: try hard link first

This commit is contained in:
Simon Ding
2024-07-30 21:15:35 +08:00
parent 2c3fd89f2a
commit 3525d1bb83

View File

@@ -55,6 +55,8 @@ func (l *LocalStorage) Move(src, destDir string) error {
if info.IsDir() { if info.IsDir() {
os.Mkdir(destName, os.ModePerm) os.Mkdir(destName, os.ModePerm)
} else { //is file } else { //is file
if err := os.Link(path, destName); err != nil {
log.Warnf("hard file error, will try copy file, source: %s, dest: %s", path, destName)
if writer, err := os.OpenFile(destName, os.O_RDWR|os.O_CREATE|os.O_TRUNC, os.ModePerm); err != nil { if writer, err := os.OpenFile(destName, os.O_RDWR|os.O_CREATE|os.O_TRUNC, os.ModePerm); err != nil {
return errors.Wrapf(err, "create file %s", destName) return errors.Wrapf(err, "create file %s", destName)
} else { } else {
@@ -69,6 +71,8 @@ func (l *LocalStorage) Move(src, destDir string) error {
} }
} }
} }
}
} }
log.Infof("file copy complete: %v", destName) log.Infof("file copy complete: %v", destName)
return nil return nil