ref: 2955f93fc63f658797afa8690f4f39198054db45
parent: 1f0c4e1fb347bb233f3312c424fbf5a013c03604
author: Bjørn Erik Pedersen <[email protected]>
date: Thu Jun 28 08:20:03 EDT 2018
commands: Fix broken server-reload on config changes This was accidently broken in Hugo 0.42. Fixes #4878
--- a/commands/commandeer.go
+++ b/commands/commandeer.go
@@ -37,24 +37,28 @@
"github.com/gohugoio/hugo/langs"
)
-type commandeer struct {
+type commandeerHugoState struct {
*deps.DepsCfg
+ hugo *hugolib.HugoSites
+ fsCreate sync.Once
+}
- hugo *hugolib.HugoSites
+type commandeer struct {
+ *commandeerHugoState
+ // We need to reuse this on server rebuilds.
+ destinationFs afero.Fs
+
h *hugoBuilderCommon
ftch flagsToConfigHandler
visitedURLs *types.EvictingStringQueue
+ doWithCommandeer func(c *commandeer) error
+
// We watch these for changes.
configFiles []string
- doWithCommandeer func(c *commandeer) error
-
- // We can do this only once.
- fsCreate sync.Once
-
// Used in cases where we get flooded with events in server mode.
debounce func(f func())
@@ -73,6 +77,7 @@
}
func (c *commandeer) initFs(fs *hugofs.Fs) error {
+ c.destinationFs = fs.Destination
c.DepsCfg.Fs = fs
return nil
@@ -89,11 +94,12 @@
}
c := &commandeer{
- h: h,
- ftch: f,
- doWithCommandeer: doWithCommandeer,
- visitedURLs: types.NewEvictingStringQueue(10),
- debounce: rebuildDebouncer,
+ h: h,
+ ftch: f,
+ commandeerHugoState: &commandeerHugoState{},
+ doWithCommandeer: doWithCommandeer,
+ visitedURLs: types.NewEvictingStringQueue(10),
+ debounce: rebuildDebouncer,
}
return c, c.loadConfig(mustHaveConfigFile, running)
@@ -188,8 +194,11 @@
c.fsCreate.Do(func() {
fs := hugofs.NewFrom(sourceFs, config)
- // Hugo writes the output to memory instead of the disk.
- if createMemFs {
+ if c.destinationFs != nil {
+ // Need to reuse the destination on server rebuilds.
+ fs.Destination = c.destinationFs
+ } else if createMemFs {
+ // Hugo writes the output to memory instead of the disk.
fs.Destination = new(afero.MemMapFs)
}
--- a/commands/hugo.go
+++ b/commands/hugo.go
@@ -596,14 +596,6 @@
return a, nil
}
-func (c *commandeer) recreateAndBuildSites(watching bool) (err error) {
- defer c.timeTrack(time.Now(), "Total")
- if !c.h.quiet {
- c.Logger.FEEDBACK.Println("Started building sites ...")
- }
- return c.hugo.Build(hugolib.BuildCfg{CreateSitesFromConfig: true})
-}
-
func (c *commandeer) resetAndBuildSites() (err error) {
if !c.h.quiet {
c.Logger.FEEDBACK.Println("Started building sites ...")
@@ -637,9 +629,10 @@
}
func (c *commandeer) fullRebuild() {
+ c.commandeerHugoState = &commandeerHugoState{}
if err := c.loadConfig(true, true); err != nil {
jww.ERROR.Println("Failed to reload config:", err)
- } else if err := c.recreateAndBuildSites(true); err != nil {
+ } else if err := c.buildSites(); err != nil {
jww.ERROR.Println(err)
} else if !c.h.buildWatch && !c.Cfg.GetBool("disableLiveReload") {
livereload.ForceRefresh()
--- a/commands/server.go
+++ b/commands/server.go
@@ -298,7 +298,7 @@
}
}
- httpFs := afero.NewHttpFs(f.c.Fs.Destination)
+ httpFs := afero.NewHttpFs(f.c.destinationFs)
fs := filesOnlyFs{httpFs.Dir(absPublishDir)}
doLiveReload := !f.s.buildWatch && !f.c.Cfg.GetBool("disableLiveReload")