aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorBjørn Erik Pedersen <[email protected]>2024-07-17 12:51:49 +0200
committerBjørn Erik Pedersen <[email protected]>2024-07-17 12:51:49 +0200
commit4d8bfa7f1c21a4b7ece26acdcba3f2e38e54d923 (patch)
tree80070a3432f325b825932247d60186f943bead6e
parentf0ed91caba9ab962593479e745a0df1a5518c4bf (diff)
downloadhugo-4d8bfa7f1c21a4b7ece26acdcba3f2e38e54d923.tar.gz
hugo-4d8bfa7f1c21a4b7ece26acdcba3f2e38e54d923.zip
tpl: Use xxHash instead of MD5 to hash the deferred templates
Motivation is performance. These templates are typically very small, so the win is minor, I guess.
-rw-r--r--helpers/general.go9
-rw-r--r--tpl/tplimpl/template_ast_transformers.go2
2 files changed, 10 insertions, 1 deletions
diff --git a/helpers/general.go b/helpers/general.go
index af854041d..fa65265b8 100644
--- a/helpers/general.go
+++ b/helpers/general.go
@@ -27,6 +27,7 @@ import (
"unicode"
"unicode/utf8"
+ "github.com/cespare/xxhash/v2"
"github.com/spf13/afero"
"github.com/jdkato/prose/transform"
@@ -257,6 +258,14 @@ func SliceToLower(s []string) []string {
return l
}
+// XxHashString takes a string and returns its xxHash hash.
+func XxHashString(f string) string {
+ h := xxhash.New()
+ h.WriteString(f)
+ hash := h.Sum(nil)
+ return hex.EncodeToString(hash)
+}
+
// MD5String takes a string and returns its MD5 hash.
func MD5String(f string) string {
h := md5.New()
diff --git a/tpl/tplimpl/template_ast_transformers.go b/tpl/tplimpl/template_ast_transformers.go
index 57730f82e..9eee64235 100644
--- a/tpl/tplimpl/template_ast_transformers.go
+++ b/tpl/tplimpl/template_ast_transformers.go
@@ -254,7 +254,7 @@ func (c *templateContext) handleDefer(withNode *parse.WithNode) {
c.err = errors.New("resources.PostProcess cannot be used in a deferred template")
return
}
- innerHash := helpers.MD5String(s)
+ innerHash := helpers.XxHashString(s)
deferredID := tpl.HugoDeferredTemplatePrefix + innerHash
c.deferNodes[deferredID] = inner