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
}
import (
"fmt"
"io/ioutil"
+
+ "github.com/spf13/hugo/hugofs"
+
"log"
"net/http"
"os"
"time"
"github.com/spf13/hugo/config"
- "github.com/spf13/hugo/hugofs"
"github.com/spf13/hugo/parser"
flag "github.com/spf13/pflag"
return cfg, err
}
+ // Init file systems. This may be changed at a later point.
cfg.Cfg = config
c, err := newCommandeer(cfg)
}
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", "/")
}
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()