From c2bc68204bfa5a24054c53b443c45bf98434a9f5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gr=C3=A9goire=20Leroy?= Date: Tue, 5 May 2020 18:24:07 +0200 Subject: [PATCH] increase GetObjectSliceDiff performances (#41) --- storage.go | 32 ++++++++++++++------------------ 1 file changed, 14 insertions(+), 18 deletions(-) diff --git a/storage.go b/storage.go index 32b173ec..ed6fe55d 100644 --- a/storage.go +++ b/storage.go @@ -56,30 +56,26 @@ func (object Object) HasExtension(extension string) bool { // GetObjectSliceDiff takes two objects slices and returns an ObjectSliceDiff func GetObjectSliceDiff(os1 []Object, os2 []Object, timestampTolerance time.Duration) ObjectSliceDiff { var diff ObjectSliceDiff + om1 := make(map[string]Object) + om2 := make(map[string]Object) for _, o1 := range os1 { - found := false - for _, o2 := range os2 { - if o1.Path == o2.Path { - found = true - if o2.LastModified.Sub(o1.LastModified) > timestampTolerance { - diff.Updated = append(diff.Updated, o2) - } - break + om1[o1.Path] = o1 + } + for _, o2 := range os2 { + om2[o2.Path] = o2 + } + for _, o1 := range os1 { + if o2, found := om2[o1.Path]; found { + if o2.LastModified.Sub(o1.LastModified) > timestampTolerance { + diff.Updated = append(diff.Updated, o2) } - } - if !found { + } else { diff.Removed = append(diff.Removed, o1) } } + for _, o2 := range os2 { - found := false - for _, o1 := range os1 { - if o2.Path == o1.Path { - found = true - break - } - } - if !found { + if _, found := om1[o2.Path]; !found { diff.Added = append(diff.Added, o2) } }