commands: Fix broken commandeer
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sat, 25 Mar 2017 18:48:28 +0000 (19:48 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 27 Mar 2017 13:43:56 +0000 (15:43 +0200)
commands/commandeer.go
commands/hugo.go

index 19eadda10fc0fceeb508f7ae91232ab4222eaa37..7f7e20f7b343b11e7baee8b5f5d6a8ffd52f765f 100644 (file)
@@ -39,9 +39,22 @@ func (c *commandeer) PathSpec() *helpers.PathSpec {
        return c.pathSpec
 }
 
+func (c *commandeer) initFs(fs *hugofs.Fs) error {
+       c.DepsCfg.Fs = fs
+       ps, err := helpers.NewPathSpec(fs, c.Cfg)
+       if err != nil {
+               return err
+       }
+       c.pathSpec = ps
+       return nil
+}
+
 func newCommandeer(cfg *deps.DepsCfg) (*commandeer, error) {
-       fs := hugofs.NewDefault(cfg.Language)
-       ps, err := helpers.NewPathSpec(fs, cfg.Cfg)
+       l := cfg.Language
+       if l == nil {
+               l = helpers.NewDefaultLanguage(cfg.Cfg)
+       }
+       ps, err := helpers.NewPathSpec(cfg.Fs, l)
        if err != nil {
                return nil, err
        }
index de5798df9d2f6ff94bc96cb9c218cb8499afb254..5a056996d2e5cc0d348ddb1116b73fd6cc47a9b2 100644 (file)
@@ -18,6 +18,9 @@ package commands
 import (
        "fmt"
        "io/ioutil"
+
+       "github.com/spf13/hugo/hugofs"
+
        "log"
        "net/http"
        "os"
@@ -28,7 +31,6 @@ import (
        "time"
 
        "github.com/spf13/hugo/config"
-       "github.com/spf13/hugo/hugofs"
 
        "github.com/spf13/hugo/parser"
        flag "github.com/spf13/pflag"
@@ -288,6 +290,7 @@ func InitializeConfig(subCmdVs ...*cobra.Command) (*deps.DepsCfg, error) {
                return cfg, err
        }
 
+       // Init file systems. This may be changed at a later point.
        cfg.Cfg = config
 
        c, err := newCommandeer(cfg)
@@ -343,13 +346,13 @@ func InitializeConfig(subCmdVs ...*cobra.Command) (*deps.DepsCfg, error) {
        }
        config.Set("workingDir", dir)
 
-       cfg.Fs = hugofs.NewFrom(osFs, config)
+       fs := hugofs.NewFrom(osFs, config)
 
        // Hugo writes the output to memory instead of the disk.
        // This is only used for benchmark testing. Cause the content is only visible
        // in memory.
        if renderToMemory {
-               c.Fs.Destination = new(afero.MemMapFs)
+               fs.Destination = new(afero.MemMapFs)
                // Rendering to memoryFS, publish to Root regardless of publishDir.
                c.Set("publishDir", "/")
        }
@@ -371,16 +374,18 @@ func InitializeConfig(subCmdVs ...*cobra.Command) (*deps.DepsCfg, error) {
                if helpers.FilePathSeparator != cacheDir[len(cacheDir)-1:] {
                        cacheDir = cacheDir + helpers.FilePathSeparator
                }
-               isDir, err := helpers.DirExists(cacheDir, cfg.Fs.Source)
+               isDir, err := helpers.DirExists(cacheDir, fs.Source)
                utils.CheckErr(cfg.Logger, err)
                if !isDir {
                        mkdir(cacheDir)
                }
                config.Set("cacheDir", cacheDir)
        } else {
-               config.Set("cacheDir", helpers.GetTempDir("hugo_cache", cfg.Fs.Source))
+               config.Set("cacheDir", helpers.GetTempDir("hugo_cache", fs.Source))
        }
 
+       c.initFs(fs)
+
        cfg.Logger.INFO.Println("Using config file:", viper.ConfigFileUsed())
 
        themeDir := c.PathSpec().GetThemeDir()