From: Bjørn Erik Pedersen Date: Sun, 7 Jan 2018 10:29:02 +0000 (+0100) Subject: resource: Avoid processing and storing same image for each language X-Git-Tag: v0.32.3~5 X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=4b04db0f0855a1f54895d6c93c52dcea4b1ce3ca;p=brevno-suite%2Fhugo resource: Avoid processing and storing same image for each language Fixes #4231 --- diff --git a/resource/image.go b/resource/image.go index 8a65be1b..678a78ad 100644 --- a/resource/image.go +++ b/resource/image.go @@ -219,7 +219,7 @@ func (i *Image) doWithImageConfig(action, spec string, f func(src image.Image, c } if conf.Rotate != 0 { - // Rotate it befor any scaling to get the dimensions correct. + // Rotate it before any scaling to get the dimensions correct. src = imaging.Rotate(src, float64(conf.Rotate), color.Transparent) } diff --git a/resource/image_cache.go b/resource/image_cache.go index 14350986..c2d5d0ad 100644 --- a/resource/image_cache.go +++ b/resource/image_cache.go @@ -51,6 +51,15 @@ func (c *imageCache) deleteByPrefix(prefix string) { func (c *imageCache) getOrCreate( spec *Spec, key string, create func(resourceCacheFilename string) (*Image, error)) (*Image, error) { + + relTargetFilename := key + + if c.pathSpec.Language != nil { + // Avoid do and store more work than needed. The language versions will in + // most cases be duplicates of the same image files. + key = strings.TrimPrefix(key, "/"+c.pathSpec.Language.Lang) + } + // First check the in-memory store, then the disk. c.mu.RLock() img, found := c.store[key] @@ -68,7 +77,7 @@ func (c *imageCache) getOrCreate( // but the count of processed image variations for this site. c.pathSpec.ProcessingStats.Incr(&c.pathSpec.ProcessingStats.ProcessedImages) - r, err := spec.NewResourceFromFilename(nil, c.absPublishDir, cacheFilename, key) + r, err := spec.NewResourceFromFilename(nil, c.absPublishDir, cacheFilename, relTargetFilename) notFound := err != nil && os.IsNotExist(err) if err != nil && !os.IsNotExist(err) { return nil, err