]
revision = "85c342e3e3d715ad780edd0ba8728161e99cce24"
+[[projects]]
+ branch = "master"
+ name = "github.com/bep/debounce"
+ packages = ["."]
+ revision = "4d3a5ad34e592abc468ed5c6b2a23fcca372ebcd"
+
[[projects]]
branch = "master"
name = "github.com/bep/gitmap"
[solve-meta]
analyzer-name = "dep"
analyzer-version = 1
- inputs-digest = "edb250b53926de21df1740c379c76351b7e9b110c96a77078a10ba69bf31a2d4"
+ inputs-digest = "49464f23053ef206ad23f65c511943ef50f188a1d0023db3ac5223051a3bba78"
solver-name = "gps-cdcl"
solver-version = 1
[[constraint]]
name = "github.com/sanity-io/litter"
version = "1.1.0"
+
+[[constraint]]
+ branch = "master"
+ name = "github.com/bep/debounce"
"os"
"path/filepath"
"sync"
+ "time"
"github.com/spf13/cobra"
"github.com/gohugoio/hugo/hugolib"
+ "github.com/bep/debounce"
"github.com/gohugoio/hugo/common/types"
"github.com/gohugoio/hugo/deps"
"github.com/gohugoio/hugo/helpers"
// 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())
+
serverPorts []int
languages helpers.Languages
func newCommandeer(running bool, doWithCommandeer func(c *commandeer) error, subCmdVs ...*cobra.Command) (*commandeer, error) {
+ var rebuildDebouncer func(f func())
+ if running {
+ // The time value used is tested with mass content replacements in a fairly big Hugo site.
+ // It is better to wait for some seconds in those cases rather than get flooded
+ // with rebuilds.
+ rebuildDebouncer, _ = debounce.New(4 * time.Second)
+ }
+
c := &commandeer{
doWithCommandeer: doWithCommandeer,
subCmdVs: append([]*cobra.Command{hugoCmdV}, subCmdVs...),
- visitedURLs: types.NewEvictingStringQueue(10)}
+ visitedURLs: types.NewEvictingStringQueue(10),
+ debounce: rebuildDebouncer,
+ }
return c, c.loadConfig(running)
}
return Hugo.Build(hugolib.BuildCfg{RecentlyVisited: visited}, events...)
}
+func (c *commandeer) fullRebuild() {
+ if err := c.loadConfig(true); err != nil {
+ jww.ERROR.Println("Failed to reload config:", err)
+ } else if err := c.recreateAndBuildSites(true); err != nil {
+ jww.ERROR.Println(err)
+ } else if !buildWatch && !c.Cfg.GetBool("disableLiveReload") {
+ livereload.ForceRefresh()
+ }
+}
+
// newWatcher creates a new watcher to watch filesystem events.
func (c *commandeer) newWatcher(dirList ...string) (*watcher.Batcher, error) {
if runtime.GOOS == "darwin" {
for {
select {
case evs := <-watcher.Events:
+ if len(evs) > 50 {
+ // This is probably a mass edit of the content dir.
+ // Schedule a full rebuild for when it slows down.
+ c.debounce(c.fullRebuild)
+ continue
+ }
+
c.Logger.INFO.Println("Received System Events:", evs)
staticEvents := []fsnotify.Event{}
continue
}
// Config file changed. Need full rebuild.
- if err := c.loadConfig(true); err != nil {
- jww.ERROR.Println("Failed to reload config:", err)
- } else if err := c.recreateAndBuildSites(true); err != nil {
- jww.ERROR.Println(err)
- } else if !buildWatch && !c.Cfg.GetBool("disableLiveReload") {
- livereload.ForceRefresh()
- }
+ c.fullRebuild()
break
}