commands: Make sure all language homes are always re-rendered in fast render mode
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 29 Dec 2017 08:37:37 +0000 (09:37 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 29 Dec 2017 08:37:37 +0000 (09:37 +0100)
Fixes #4125

commands/hugo.go
helpers/pathspec.go
helpers/url.go

index 200a5e1c3ec9c661bece66e665265b57adaca424..743c5a26712a16a1005e7503eb968cd01d5fd832 100644 (file)
@@ -940,9 +940,17 @@ func (c *commandeer) rebuildSites(events []fsnotify.Event) error {
        visited := c.visitedURLs.PeekAllSet()
        doLiveReload := !buildWatch && !c.Cfg.GetBool("disableLiveReload")
        if doLiveReload && !c.Cfg.GetBool("disableFastRender") {
-               home := c.pathSpec.PrependBasePath("/")
-               // Make sure we always render the home page
-               visited[home] = true
+
+               // Make sure we always render the home pages
+               for _, l := range c.languages {
+                       langPath := c.PathSpec().GetLangSubDir(l.Lang)
+                       if langPath != "" {
+                               langPath = langPath + "/"
+                       }
+                       home := c.pathSpec.PrependBasePath("/" + langPath)
+                       visited[home] = true
+               }
+
        }
        return Hugo.Build(hugolib.BuildCfg{RecentlyVisited: visited}, events...)
 }
index d5a2c92e8da5349cce2a3b2c23252ab1947dbad4..2812037123bf98c71a737ccc6a8d9b7d4351258b 100644 (file)
@@ -31,8 +31,8 @@ type PathSpec struct {
        uglyURLs           bool
        canonifyURLs       bool
 
-       language *Language
-       //StatsCounter *siteSta
+       language  *Language
+       languages Languages
 
        // pagination path handling
        paginatePath string
@@ -85,9 +85,20 @@ func NewPathSpec(fs *hugofs.Fs, cfg config.Provider) (*PathSpec, error) {
                staticDirs = append(staticDirs, getStringOrStringSlice(cfg, "staticDir", i)...)
        }
 
-       var lang string
+       var (
+               lang      string
+               language  *Language
+               languages Languages
+       )
+
        if l, ok := cfg.(*Language); ok {
+               language = l
                lang = l.Lang
+
+       }
+
+       if l, ok := cfg.Get("languagesSorted").(Languages); ok {
+               languages = l
        }
 
        ps := &PathSpec{
@@ -98,6 +109,8 @@ func NewPathSpec(fs *hugofs.Fs, cfg config.Provider) (*PathSpec, error) {
                uglyURLs:                       cfg.GetBool("uglyURLs"),
                canonifyURLs:                   cfg.GetBool("canonifyURLs"),
                multilingual:                   cfg.GetBool("multilingual"),
+               language:                       language,
+               languages:                      languages,
                defaultContentLanguageInSubdir: cfg.GetBool("defaultContentLanguageInSubdir"),
                defaultContentLanguage:         cfg.GetString("defaultContentLanguage"),
                paginatePath:                   cfg.GetString("paginatePath"),
@@ -119,10 +132,6 @@ func NewPathSpec(fs *hugofs.Fs, cfg config.Provider) (*PathSpec, error) {
 
        ps.PublishDir = publishDir
 
-       if language, ok := cfg.(*Language); ok {
-               ps.language = language
-       }
-
        return ps, nil
 }
 
index 9c1a643ccc60f06d037e06c884d5bb235ac4eea4..8faefeefa2876e7a1f9960031d640d6bcbb830fe 100644 (file)
@@ -215,6 +215,23 @@ func (p *PathSpec) getLanguagePrefix() string {
        return currentLang
 }
 
+// GetLangSubDir returns the given language's subdir if needed.
+func (p *PathSpec) GetLangSubDir(lang string) string {
+       if !p.multilingual {
+               return ""
+       }
+
+       if p.languages.IsMultihost() {
+               return ""
+       }
+
+       if lang == "" || (lang == p.defaultContentLanguage && !p.defaultContentLanguageInSubdir) {
+               return ""
+       }
+
+       return lang
+}
+
 // IsAbsURL determines whether the given path points to an absolute URL.
 func IsAbsURL(path string) bool {
        url, err := url.Parse(path)