mirror of
https://github.com/gohugoio/hugo.git
synced 2024-11-21 20:46:30 -05:00
parent
5b9c2a40f1
commit
f023dfd763
2 changed files with 61 additions and 34 deletions
|
@ -713,43 +713,13 @@ func getDirList() []string {
|
||||||
}
|
}
|
||||||
|
|
||||||
func buildSites(watching ...bool) (err error) {
|
func buildSites(watching ...bool) (err error) {
|
||||||
fmt.Println("Started building site")
|
fmt.Println("Started building sites ...")
|
||||||
t0 := time.Now()
|
w := len(watching) > 0 && watching[0]
|
||||||
|
return Hugo.Build(w, true)
|
||||||
for _, site := range Hugo {
|
|
||||||
t1 := time.Now()
|
|
||||||
if len(watching) > 0 && watching[0] {
|
|
||||||
site.RunMode.Watching = true
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := site.Build(); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
site.Stats(t1)
|
|
||||||
}
|
|
||||||
|
|
||||||
jww.FEEDBACK.Printf("total in %v ms\n", int(1000*time.Since(t0).Seconds()))
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func rebuildSites(events []fsnotify.Event) error {
|
func rebuildSites(events []fsnotify.Event) error {
|
||||||
t0 := time.Now()
|
return Hugo.Rebuild(events, true)
|
||||||
|
|
||||||
for _, site := range Hugo {
|
|
||||||
t1 := time.Now()
|
|
||||||
|
|
||||||
if err := site.ReBuild(events); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
site.Stats(t1)
|
|
||||||
}
|
|
||||||
|
|
||||||
jww.FEEDBACK.Printf("total in %v ms\n", int(1000*time.Since(t0).Seconds()))
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewWatcher creates a new watcher to watch filesystem events.
|
// NewWatcher creates a new watcher to watch filesystem events.
|
||||||
|
|
|
@ -13,6 +13,14 @@
|
||||||
|
|
||||||
package hugolib
|
package hugolib
|
||||||
|
|
||||||
|
import (
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/fsnotify/fsnotify"
|
||||||
|
|
||||||
|
jww "github.com/spf13/jwalterweatherman"
|
||||||
|
)
|
||||||
|
|
||||||
// HugoSites represents the sites to build. Each site represents a language.
|
// HugoSites represents the sites to build. Each site represents a language.
|
||||||
type HugoSites []*Site
|
type HugoSites []*Site
|
||||||
|
|
||||||
|
@ -23,3 +31,52 @@ func (h HugoSites) Reset() {
|
||||||
h[i] = s.Reset()
|
h[i] = s.Reset()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Build builds all sites.
|
||||||
|
func (h HugoSites) Build(watching, printStats bool) error {
|
||||||
|
t0 := time.Now()
|
||||||
|
|
||||||
|
for _, site := range h {
|
||||||
|
t1 := time.Now()
|
||||||
|
|
||||||
|
site.RunMode.Watching = watching
|
||||||
|
|
||||||
|
if err := site.Build(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if printStats {
|
||||||
|
site.Stats(t1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if printStats {
|
||||||
|
jww.FEEDBACK.Printf("total in %v ms\n", int(1000*time.Since(t0).Seconds()))
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Rebuild rebuilds all sites.
|
||||||
|
func (h HugoSites) Rebuild(events []fsnotify.Event, printStats bool) error {
|
||||||
|
t0 := time.Now()
|
||||||
|
|
||||||
|
for _, site := range h {
|
||||||
|
t1 := time.Now()
|
||||||
|
|
||||||
|
if err := site.ReBuild(events); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if printStats {
|
||||||
|
site.Stats(t1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if printStats {
|
||||||
|
jww.FEEDBACK.Printf("total in %v ms\n", int(1000*time.Since(t0).Seconds()))
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue