From e6caf56ea4ab10e747aa5dfc0a768cb8176ebe6a Mon Sep 17 00:00:00 2001 From: Jakob Unterwurzacher Date: Mon, 2 Apr 2018 16:56:29 +0200 Subject: fsck: sort files alphabetically This makes fsck runs deterministic. --- fsck.go | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/fsck.go b/fsck.go index 7741d19..32788e5 100644 --- a/fsck.go +++ b/fsck.go @@ -4,6 +4,8 @@ import ( "fmt" "os" "path/filepath" + "sort" + "strings" "syscall" "github.com/hanwen/go-fuse/fuse" @@ -27,6 +29,8 @@ func (ck *fsckObj) dir(path string) { ck.errorCount++ return } + // Sort alphabetically + sort.Sort(sortableDirEntries(entries)) for _, entry := range entries { if entry.Name == "." || entry.Name == ".." { continue @@ -102,3 +106,17 @@ func fsck(args *argContainer) { os.Exit(exitcodes.FsckErrors) } } + +type sortableDirEntries []fuse.DirEntry + +func (s sortableDirEntries) Len() int { + return len(s) +} + +func (s sortableDirEntries) Swap(i, j int) { + s[i], s[j] = s[j], s[i] +} + +func (s sortableDirEntries) Less(i, j int) bool { + return strings.Compare(s[i].Name, s[j].Name) < 0 +} -- cgit v1.2.3