Merge pull request #1747 from Zillode/fix-1743

Partial fix for #1743
This commit is contained in:
Jakob Borg 2015-05-04 10:51:40 +02:00
commit df59bc7194
2 changed files with 32 additions and 18 deletions

View File

@ -32,7 +32,7 @@ func TryRename(from, to string) error {
renameLock.Lock() renameLock.Lock()
defer renameLock.Unlock() defer renameLock.Unlock()
return withPreparedTarget(to, func() error { return withPreparedTarget(from, to, func() error {
return os.Rename(from, to) return os.Rename(from, to)
}) })
} }
@ -44,7 +44,9 @@ func TryRename(from, to string) error {
// permissions and removing the destination file when necessary. // permissions and removing the destination file when necessary.
func Rename(from, to string) error { func Rename(from, to string) error {
// Don't leave a dangling temp file in case of rename error // Don't leave a dangling temp file in case of rename error
if !(runtime.GOOS == "windows" && strings.EqualFold(from, to)) {
defer os.Remove(from) defer os.Remove(from)
}
return TryRename(from, to) return TryRename(from, to)
} }
@ -52,7 +54,7 @@ func Rename(from, to string) error {
// Tries hard to succeed on various systems by temporarily tweaking directory // Tries hard to succeed on various systems by temporarily tweaking directory
// permissions and removing the destination file when necessary. // permissions and removing the destination file when necessary.
func Copy(from, to string) (err error) { func Copy(from, to string) (err error) {
return withPreparedTarget(to, func() error { return withPreparedTarget(from, to, func() error {
return copyFileContents(from, to) return copyFileContents(from, to)
}) })
} }
@ -143,7 +145,7 @@ func getHomeDir() (string, error) {
// Tries hard to succeed on various systems by temporarily tweaking directory // Tries hard to succeed on various systems by temporarily tweaking directory
// permissions and removing the destination file when necessary. // permissions and removing the destination file when necessary.
func withPreparedTarget(to string, f func() error) error { func withPreparedTarget(from, to string, f func() error) error {
// Make sure the destination directory is writeable // Make sure the destination directory is writeable
toDir := filepath.Dir(to) toDir := filepath.Dir(to)
if info, err := os.Stat(toDir); err == nil && info.IsDir() && info.Mode()&0200 == 0 { if info, err := os.Stat(toDir); err == nil && info.IsDir() && info.Mode()&0200 == 0 {
@ -154,11 +156,13 @@ func withPreparedTarget(to string, f func() error) error {
// On Windows, make sure the destination file is writeable (or we can't delete it) // On Windows, make sure the destination file is writeable (or we can't delete it)
if runtime.GOOS == "windows" { if runtime.GOOS == "windows" {
os.Chmod(to, 0666) os.Chmod(to, 0666)
if !strings.EqualFold(from, to) {
err := os.Remove(to) err := os.Remove(to)
if err != nil && !os.IsNotExist(err) { if err != nil && !os.IsNotExist(err) {
return err return err
} }
} }
}
return f() return f()
} }

View File

@ -23,6 +23,7 @@ import (
"sort" "sort"
"strings" "strings"
"time" "time"
"unicode"
"github.com/syncthing/syncthing/internal/osutil" "github.com/syncthing/syncthing/internal/osutil"
"github.com/syncthing/syncthing/internal/symlinks" "github.com/syncthing/syncthing/internal/symlinks"
@ -133,9 +134,7 @@ func alterFiles(dir string) error {
case r == 0 && comps > 2: case r == 0 && comps > 2:
// Delete every tenth file or directory, except top levels // Delete every tenth file or directory, except top levels
err := removeAll(path) err := removeAll(path)
if err != nil {
return err return err
}
case r == 1 && info.Mode().IsRegular(): case r == 1 && info.Mode().IsRegular():
if info.Mode()&0200 != 0200 { if info.Mode()&0200 != 0200 {
@ -161,10 +160,22 @@ func alterFiles(dir string) error {
return err return err
} }
err = fd.Close() err = fd.Close()
if err != nil {
return err return err
}
// Change capitalization
case r == 2 && comps > 3 && rand.Float64() < 0.2:
base := []rune(filepath.Base(path))
for i, r := range base {
if rand.Float64() < 0.5 {
base[i] = unicode.ToLower(r)
} else {
base[i] = unicode.ToUpper(r)
}
}
err = osutil.TryRename(path, strings.Replace(path, filepath.Base(path), string(base), 1))
return err
// Switch between files and directories
case r == 2 && comps > 3 && rand.Float64() < 0.2: case r == 2 && comps > 3 && rand.Float64() < 0.2:
if !info.Mode().IsRegular() { if !info.Mode().IsRegular() {
err = removeAll(path) err = removeAll(path)
@ -177,7 +188,7 @@ func alterFiles(dir string) error {
return err return err
} }
} else { } else {
err := os.Remove(path) err := osutil.Remove(path)
if err != nil { if err != nil {
return err return err
} }
@ -187,6 +198,7 @@ func alterFiles(dir string) error {
} }
generateFiles(path, 10, 20, "../LICENSE") generateFiles(path, 10, 20, "../LICENSE")
} }
return err
case r == 3 && comps > 2 && (info.Mode().IsRegular() || rand.Float64() < 0.2): case r == 3 && comps > 2 && (info.Mode().IsRegular() || rand.Float64() < 0.2):
rpath := filepath.Dir(path) rpath := filepath.Dir(path)
@ -195,11 +207,9 @@ func alterFiles(dir string) error {
rpath = filepath.Join(rpath, "..") rpath = filepath.Join(rpath, "..")
} }
} }
err = os.Rename(path, filepath.Join(rpath, randomName())) err = osutil.TryRename(path, filepath.Join(rpath, randomName()))
if err != nil {
return err return err
} }
}
return nil return nil
}) })
if err != nil { if err != nil {