From: Bjørn Erik Pedersen Date: Sat, 21 Nov 2015 20:57:26 +0000 (+0100) Subject: Improve RW-locking of template in shortcode handling X-Git-Tag: v0.15~25 X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=c5f40e8b8ba1d8eaac11bbbf3b537e3e4e94c860;p=brevno-suite%2Fhugo Improve RW-locking of template in shortcode handling See #1599 --- diff --git a/hugolib/shortcode.go b/hugolib/shortcode.go index c49418b8..4d3037dc 100644 --- a/hugolib/shortcode.go +++ b/hugolib/shortcode.go @@ -345,12 +345,12 @@ Loop: } // TODO(bep) Refactor/rename this lock strategy - isInnerShortcodeCache.Lock() + isInnerShortcodeCache.RLock() if tmpl.Tree == nil { - isInnerShortcodeCache.Unlock() + isInnerShortcodeCache.RUnlock() return sc, fmt.Errorf("Template for shortcode '%s' failed to compile for page '%s'", sc.name, p.BaseFileName()) } - isInnerShortcodeCache.Unlock() + isInnerShortcodeCache.RUnlock() isInner = isInnerShortcode(tmpl) case tScParam: @@ -523,6 +523,9 @@ func renderShortcodeWithPage(tmpl *template.Template, data *ShortcodeWithPage) s buffer := bp.GetBuffer() defer bp.PutBuffer(buffer) + // TODO(bep) Refactor/rename this lock strategy + isInnerShortcodeCache.Lock() + defer isInnerShortcodeCache.Unlock() err := tmpl.Execute(buffer, data) if err != nil { jww.ERROR.Println("error processing shortcode", tmpl.Name(), "\n ERR:", err)