ref: 080302eb8757fd94ccbd6bf99103432cd98e716c
parent: 094ec171420e659cdf962a19dd90105912ce9901
author: Bjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
date: Sat Apr 7 07:27:22 EDT 2018
Fix handling of --contentDir etc. flag We need to revisit the commands package re globals and tests, but this should fix the init order of flags and languages. Fixes #4589
--- a/commands/commandeer.go
+++ b/commands/commandeer.go
@@ -19,6 +19,8 @@
"sync"
"time"
+ "github.com/gohugoio/hugo/config"
+
"github.com/spf13/cobra"
"github.com/gohugoio/hugo/utils"
@@ -56,8 +58,9 @@
// Used in cases where we get flooded with events in server mode.
debounce func(f func())
- serverPorts []int
- languages helpers.Languages
+ serverPorts []int
+ languagesConfigured bool
+ languages helpers.Languages
configured bool
}
@@ -135,72 +138,89 @@
sourceFs = c.DepsCfg.Fs.Source
}
- config, configFiles, err := hugolib.LoadConfig(hugolib.ConfigSourceDescriptor{Fs: sourceFs, Path: source, WorkingDir: dir, Filename: cfgFile})- if err != nil {- return err
- }
+ doWithConfig := func(cfg config.Provider) error {+ for _, cmdV := range c.subCmdVs {+ initializeFlags(cmdV, cfg)
+ }
- c.Cfg = config
- c.configFiles = configFiles
+ if baseURL != "" {+ cfg.Set("baseURL", baseURL)+ }
- for _, cmdV := range c.subCmdVs {- c.initializeFlags(cmdV)
- }
+ if len(disableKinds) > 0 {+ cfg.Set("disableKinds", disableKinds)+ }
- if l, ok := c.Cfg.Get("languagesSorted").(helpers.Languages); ok {- c.languages = l
- }
+ cfg.Set("logI18nWarnings", logI18nWarnings)- if baseURL != "" {- config.Set("baseURL", baseURL)- }
+ if theme != "" {+ cfg.Set("theme", theme)+ }
- if c.doWithCommandeer != nil {- err = c.doWithCommandeer(c)
- }
+ if themesDir != "" {+ cfg.Set("themesDir", themesDir)+ }
- if err != nil {- return err
- }
+ if destination != "" {+ cfg.Set("publishDir", destination)+ }
- if len(disableKinds) > 0 {- c.Set("disableKinds", disableKinds)- }
+ cfg.Set("workingDir", dir)- logger, err := createLogger(cfg.Cfg)
- if err != nil {- return err
- }
+ if contentDir != "" {+ cfg.Set("contentDir", contentDir)+ }
- cfg.Logger = logger
+ if layoutDir != "" {+ cfg.Set("layoutDir", layoutDir)+ }
- config.Set("logI18nWarnings", logI18nWarnings)+ if cacheDir != "" {+ cfg.Set("cacheDir", cacheDir)+ }
- if theme != "" {- config.Set("theme", theme)+ return nil
}
- if themesDir != "" {- config.Set("themesDir", themesDir)+ doWithCommandeer := func(cfg config.Provider) error {+ c.Cfg = cfg
+ if c.doWithCommandeer == nil {+ return nil
+ }
+ err := c.doWithCommandeer(c)
+ return err
}
- if destination != "" {- config.Set("publishDir", destination)+ config, configFiles, err := hugolib.LoadConfig(
+ hugolib.ConfigSourceDescriptor{Fs: sourceFs, Path: source, WorkingDir: dir, Filename: cfgFile},+ doWithCommandeer,
+ doWithConfig)
+
+ if err != nil {+ return err
}
- config.Set("workingDir", dir)+ c.configFiles = configFiles
- if contentDir != "" {- config.Set("contentDir", contentDir)+ if l, ok := c.Cfg.Get("languagesSorted").(helpers.Languages); ok {+ c.languagesConfigured = true
+ c.languages = l
}
- if layoutDir != "" {- config.Set("layoutDir", layoutDir)+ // This is potentially double work, but we need to do this one more time now
+ // that all the languages have been configured.
+ if c.doWithCommandeer != nil {+ if err := c.doWithCommandeer(c); err != nil {+ return err
+ }
}
- if cacheDir != "" {- config.Set("cacheDir", cacheDir)+ logger, err := createLogger(config)
+ if err != nil {+ return err
}
+
+ cfg.Logger = logger
createMemFs := config.GetBool("renderToMemory")--- a/commands/hugo.go
+++ b/commands/hugo.go
@@ -348,7 +348,7 @@
return jww.NewNotepad(stdoutThreshold, logThreshold, outHandle, logHandle, "", log.Ldate|log.Ltime), nil
}
-func (c *commandeer) initializeFlags(cmd *cobra.Command) {+func initializeFlags(cmd *cobra.Command, cfg config.Provider) { persFlagKeys := []string{"debug", "verbose", "logFile"} flagKeys := []string{"cleanDestinationDir",
@@ -370,10 +370,10 @@
}
for _, key := range persFlagKeys {- c.setValueFromFlag(cmd.PersistentFlags(), key)
+ setValueFromFlag(cmd.PersistentFlags(), key, cfg)
}
for _, key := range flagKeys {- c.setValueFromFlag(cmd.Flags(), key)
+ setValueFromFlag(cmd.Flags(), key, cfg)
}
}
@@ -385,7 +385,7 @@
strings.ToLower("canonifyURLs"): true,}
-func (c *commandeer) setValueFromFlag(flags *flag.FlagSet, key string) {+func setValueFromFlag(flags *flag.FlagSet, key string, cfg config.Provider) { if flags.Changed(key) { if _, deprecated := deprecatedFlags[strings.ToLower(key)]; deprecated {msg := fmt.Sprintf(`Set "%s = true" in your config.toml.
@@ -394,7 +394,7 @@
helpers.Deprecated("hugo", "--"+key+" flag", msg, true)}
f := flags.Lookup(key)
- c.Set(key, f.Value.String())
+ cfg.Set(key, f.Value.String())
}
}
--- a/commands/server.go
+++ b/commands/server.go
@@ -137,6 +137,11 @@
c.Set("watch", true)}
+ // TODO(bep) yes, we should fix.
+ if !c.languagesConfigured {+ return nil
+ }
+
var err error
// We can only do this once.
--- a/hugolib/config.go
+++ b/hugolib/config.go
@@ -54,7 +54,7 @@
// LoadConfig loads Hugo configuration into a new Viper and then adds
// a set of defaults.
-func LoadConfig(d ConfigSourceDescriptor) (*viper.Viper, []string, error) {+func LoadConfig(d ConfigSourceDescriptor, doWithConfig ...func(cfg config.Provider) error) (*viper.Viper, []string, error) {var configFiles []string
fs := d.Fs
@@ -106,6 +106,14 @@
if themeConfigFile != "" {configFiles = append(configFiles, themeConfigFile)
+ }
+
+ // We create languages based on the settings, so we need to make sure that
+ // all configuration is loaded/set before doing that.
+ for _, d := range doWithConfig {+ if err := d(v); err != nil {+ return v, configFiles, err
+ }
}
if err := loadLanguageSettings(v, nil); err != nil {--
⑨