summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>2019-07-31 10:31:26 +0200
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>2019-07-31 12:10:05 +0200
commitd7c233afee6a16b1947f60b7e5450e40612997bb (patch)
tree91c87d17642655308ab9806e5afcb9b77415541f
parent45ee8a7a52213bf394c7f41a72be78084ddc789a (diff)
commands: Add "hugo config mounts" command
This prints the effective file mounts in a project. Fixes #6144
-rw-r--r--commands/config.go66
-rw-r--r--hugolib/config.go2
-rw-r--r--hugolib/filesystems/basefs.go13
-rw-r--r--hugolib/filesystems/basefs_test.go2
-rw-r--r--modules/collect.go4
5 files changed, 74 insertions, 13 deletions
diff --git a/commands/config.go b/commands/config.go
index 64f0cdbbf..72c2a0d97 100644
--- a/commands/config.go
+++ b/commands/config.go
@@ -14,11 +14,18 @@
package commands
import (
+ "encoding/json"
+ "os"
"reflect"
"regexp"
"sort"
"strings"
+ "github.com/gohugoio/hugo/parser"
+ "github.com/gohugoio/hugo/parser/metadecoders"
+
+ "github.com/gohugoio/hugo/modules"
+
"github.com/spf13/cobra"
jww "github.com/spf13/jwalterweatherman"
"github.com/spf13/viper"
@@ -40,14 +47,37 @@ func newConfigCmd() *configCmd {
RunE: cc.printConfig,
})
- cc.cmd.Flags().StringVarP(&cc.source, "source", "s", "", "filesystem path to read files relative from")
+ cc.cmd.PersistentFlags().StringVarP(&cc.source, "source", "s", "", "filesystem path to read files relative from")
+
+ printMountsCmd := &cobra.Command{
+ Use: "mounts",
+ Short: "Print the configured file mounts",
+ RunE: cc.printMounts,
+ }
+
+ cc.cmd.AddCommand(printMountsCmd)
return cc
}
-func (c *configCmd) printConfig(cmd *cobra.Command, args []string) error {
+func (c *configCmd) printMounts(cmd *cobra.Command, args []string) error {
cfg, err := initializeConfig(true, false, &c.hugoBuilderCommon, c, nil)
+ if err != nil {
+ return err
+ }
+ allModules := cfg.Cfg.Get("allmodules").(modules.Modules)
+
+ for _, m := range allModules {
+ if err := parser.InterfaceToConfig(&modMounts{m: m}, metadecoders.JSON, os.Stdout); err != nil {
+ return err
+ }
+ }
+ return nil
+}
+
+func (c *configCmd) printConfig(cmd *cobra.Command, args []string) error {
+ cfg, err := initializeConfig(true, false, &c.hugoBuilderCommon, c, nil)
if err != nil {
return err
}
@@ -83,3 +113,35 @@ func (c *configCmd) printConfig(cmd *cobra.Command, args []string) error {
return nil
}
+
+type modMounts struct {
+ m modules.Module
+}
+
+type modMount struct {
+ Source string `json:"source"`
+ Target string `json:"target"`
+ Lang string `json:"lang,omitempty"`
+}
+
+func (m *modMounts) MarshalJSON() ([]byte, error) {
+ var mounts []modMount
+
+ for _, mount := range m.m.Mounts() {
+ mounts = append(mounts, modMount{
+ Source: mount.Source,
+ Target: mount.Target,
+ Lang: mount.Lang,
+ })
+ }
+
+ return json.Marshal(&struct {
+ Path string `json:"path"`
+ Dir string `json:"dir"`
+ Mounts []modMount `json:"mounts"`
+ }{
+ Path: m.m.Path(),
+ Dir: m.m.Dir(),
+ Mounts: mounts,
+ })
+}
diff --git a/hugolib/config.go b/hugolib/config.go
index 07a8d4100..8c2e44c10 100644
--- a/hugolib/config.go
+++ b/hugolib/config.go
@@ -217,7 +217,7 @@ func LoadConfig(d ConfigSourceDescriptor, doWithConfig ...func(cfg config.Provid
mods := m.ActiveModules
// Apply default project mounts.
- if err := modules.ApplyProjectConfigDefaults(v, mods[len(mods)-1]); err != nil {
+ if err := modules.ApplyProjectConfigDefaults(v, mods[0]); err != nil {
return err
}
diff --git a/hugolib/filesystems/basefs.go b/hugolib/filesystems/basefs.go
index e550d7f35..2d8f54d65 100644
--- a/hugolib/filesystems/basefs.go
+++ b/hugolib/filesystems/basefs.go
@@ -452,20 +452,19 @@ func (b *sourceFilesystemsBuilder) createMainOverlayFs(p *paths.Paths) (*filesys
// The theme components are ordered from left to right.
// We need to revert it to get the
- // overlay logic below working as expected, with the project on top (last).
- for i, mod := range mods {
+ // overlay logic below working as expected, with the project on top.
+ j := 0
+ for i := len(mods) - 1; i >= 0; i-- {
+ mod := mods[i]
dir := mod.Dir()
- if i < len(mods)-1 {
- i = len(mods) - 2 - i
- }
-
isMainProject := mod.Owner() == nil
- modsReversed[i] = mountsDescriptor{
+ modsReversed[j] = mountsDescriptor{
Module: mod,
dir: dir,
isMainProject: isMainProject,
}
+ j++
}
err := b.createOverlayFs(collector, modsReversed)
diff --git a/hugolib/filesystems/basefs_test.go b/hugolib/filesystems/basefs_test.go
index e4efa68e2..3b4e4cd16 100644
--- a/hugolib/filesystems/basefs_test.go
+++ b/hugolib/filesystems/basefs_test.go
@@ -62,7 +62,7 @@ func initConfig(fs afero.Fs, cfg config.Provider) error {
return err
}
- if err := modules.ApplyProjectConfigDefaults(cfg, moduleConfig.ActiveModules[len(moduleConfig.ActiveModules)-1]); err != nil {
+ if err := modules.ApplyProjectConfigDefaults(cfg, moduleConfig.ActiveModules[0]); err != nil {
return err
}
diff --git a/modules/collect.go b/modules/collect.go
index 808353608..9a18f5579 100644
--- a/modules/collect.go
+++ b/modules/collect.go
@@ -478,8 +478,8 @@ func (c *collector) collect() {
return
}
- // Append the project module at the tail.
- c.modules = append(c.modules, projectMod)
+ // Add the project mod on top.
+ c.modules = append(Modules{projectMod}, c.modules...)
}