summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--deps/deps.go29
-rw-r--r--hugolib/hugo_sites_build.go5
-rw-r--r--tpl/partials/init_test.go4
-rw-r--r--tpl/partials/partials.go16
4 files changed, 51 insertions, 3 deletions
diff --git a/deps/deps.go b/deps/deps.go
index b32c7e2e9..5a97ec7f2 100644
--- a/deps/deps.go
+++ b/deps/deps.go
@@ -1,6 +1,7 @@
package deps
import (
+ "sync"
"time"
"github.com/gohugoio/hugo/common/loggers"
@@ -22,6 +23,7 @@ import (
// There will be normally only one instance of deps in play
// at a given time, i.e. one per Site built.
type Deps struct {
+
// The logger to use.
Log *jww.Notepad `json:"-"`
@@ -69,6 +71,30 @@ type Deps struct {
// Timeout is configurable in site config.
Timeout time.Duration
+
+ // BuildStartListeners will be notified before a build starts.
+ BuildStartListeners *Listeners
+}
+
+type Listeners struct {
+ sync.Mutex
+
+ // A list of funcs to be notified about an event.
+ listeners []func()
+}
+
+func (b *Listeners) Add(f func()) {
+ b.Lock()
+ defer b.Unlock()
+ b.listeners = append(b.listeners, f)
+}
+
+func (b *Listeners) Notify() {
+ b.Lock()
+ defer b.Unlock()
+ for _, notify := range b.listeners {
+ notify()
+ }
}
// ResourceProvider is used to create and refresh, and clone resources needed.
@@ -168,6 +194,7 @@ func New(cfg DepsCfg) (*Deps, error) {
ResourceSpec: resourceSpec,
Cfg: cfg.Language,
Language: cfg.Language,
+ BuildStartListeners: &Listeners{},
Timeout: time.Duration(timeoutms) * time.Millisecond,
}
@@ -210,6 +237,8 @@ func (d Deps) ForLanguage(cfg DepsCfg) (*Deps, error) {
return nil, err
}
+ d.BuildStartListeners = &Listeners{}
+
return &d, nil
}
diff --git a/hugolib/hugo_sites_build.go b/hugolib/hugo_sites_build.go
index 7769b68dc..8ca2128a1 100644
--- a/hugolib/hugo_sites_build.go
+++ b/hugolib/hugo_sites_build.go
@@ -28,6 +28,7 @@ import (
// Build builds all sites. If filesystem events are provided,
// this is considered to be a potential partial rebuild.
func (h *HugoSites) Build(config BuildCfg, events ...fsnotify.Event) error {
+
if h.Metrics != nil {
h.Metrics.Reset()
}
@@ -42,6 +43,10 @@ func (h *HugoSites) Build(config BuildCfg, events ...fsnotify.Event) error {
conf.whatChanged = &whatChanged{source: true, other: true}
}
+ for _, s := range h.Sites {
+ s.Deps.BuildStartListeners.Notify()
+ }
+
if len(events) > 0 {
// Rebuild
if err := h.initRebuild(conf); err != nil {
diff --git a/tpl/partials/init_test.go b/tpl/partials/init_test.go
index ef284a826..4832e6b66 100644
--- a/tpl/partials/init_test.go
+++ b/tpl/partials/init_test.go
@@ -26,7 +26,9 @@ func TestInit(t *testing.T) {
var ns *internal.TemplateFuncsNamespace
for _, nsf := range internal.TemplateFuncsNamespaceRegistry {
- ns = nsf(&deps.Deps{})
+ ns = nsf(&deps.Deps{
+ BuildStartListeners: &deps.Listeners{},
+ })
if ns.Name == name {
found = true
break
diff --git a/tpl/partials/partials.go b/tpl/partials/partials.go
index 18b8d7ed6..266329721 100644
--- a/tpl/partials/partials.go
+++ b/tpl/partials/partials.go
@@ -34,18 +34,30 @@ type partialCache struct {
p map[string]interface{}
}
+func (p *partialCache) clear() {
+ p.Lock()
+ defer p.Unlock()
+ p.p = make(map[string]interface{})
+}
+
// New returns a new instance of the templates-namespaced template functions.
func New(deps *deps.Deps) *Namespace {
+ cache := &partialCache{p: make(map[string]interface{})}
+ deps.BuildStartListeners.Add(
+ func() {
+ cache.clear()
+ })
+
return &Namespace{
deps: deps,
- cachedPartials: partialCache{p: make(map[string]interface{})},
+ cachedPartials: cache,
}
}
// Namespace provides template functions for the "templates" namespace.
type Namespace struct {
deps *deps.Deps
- cachedPartials partialCache
+ cachedPartials *partialCache
}
// Include executes the named partial and returns either a string,