From a9be687b81df01c7343f78f0d3760042f467baa4 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Bj=C3=B8rn=20Erik=20Pedersen?= Date: Sat, 11 Nov 2017 09:39:43 +0100 Subject: [PATCH] hugolib: Pre-allocate some slices --- hugolib/pageGroup.go | 7 ++++--- hugolib/page_collections.go | 6 +++--- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/hugolib/pageGroup.go b/hugolib/pageGroup.go index 3ccd35a0..00b8e278 100644 --- a/hugolib/pageGroup.go +++ b/hugolib/pageGroup.go @@ -142,9 +142,10 @@ func (p Pages) GroupBy(key string, order ...string) (PagesGroup, error) { tmp.SetMapIndex(fv, reflect.Append(tmp.MapIndex(fv), ppv)) } - var r []PageGroup - for _, k := range sortKeys(tmp.MapKeys(), direction) { - r = append(r, PageGroup{Key: k.Interface(), Pages: tmp.MapIndex(k).Interface().([]*Page)}) + sortedKeys := sortKeys(tmp.MapKeys(), direction) + r := make([]PageGroup, len(sortedKeys)) + for i, k := range sortedKeys { + r[i] = PageGroup{Key: k.Interface(), Pages: tmp.MapIndex(k).Interface().([]*Page)} } return r, nil diff --git a/hugolib/page_collections.go b/hugolib/page_collections.go index e72f9a73..1eda67b1 100644 --- a/hugolib/page_collections.go +++ b/hugolib/page_collections.go @@ -76,10 +76,10 @@ func (c *PageCollections) refreshPageCaches() { } } - var partitions []cache.Partition + partitions := make([]cache.Partition, len(allKindsInPages)) - for _, kind := range allKindsInPages { - partitions = append(partitions, cache.Partition{Key: kind, Load: cacheLoader(kind)}) + for i, kind := range allKindsInPages { + partitions[i] = cache.Partition{Key: kind, Load: cacheLoader(kind)} } c.pageCache = cache.NewPartitionedLazyCache(partitions...) -- 2.30.2