Try not to leave directories behind with incorrect permissions

This commit is contained in:
Jakob Borg
2014-08-25 18:14:49 +02:00
parent e1f1ae041f
commit fe43e3b89d
3 changed files with 29 additions and 7 deletions

View File

@@ -7,17 +7,28 @@ package osutil
import (
"os"
"path/filepath"
"runtime"
)
func Rename(from, to string) error {
// Make sure the destination directory is writeable
toDir := filepath.Dir(to)
if info, err := os.Stat(toDir); err == nil {
os.Chmod(toDir, 0777)
defer os.Chmod(toDir, info.Mode())
}
// On Windows, make sure the destination file is writeable (or we can't delete it)
if runtime.GOOS == "windows" {
os.Chmod(to, 0666) // Make sure the file is user writeable
os.Chmod(to, 0666)
err := os.Remove(to)
if err != nil && !os.IsNotExist(err) {
return err
}
}
defer os.Remove(from) // Don't leave a dangling temp file in case of rename error
// Don't leave a dangling temp file in case of rename error
defer os.Remove(from)
return os.Rename(from, to)
}