diff options
Diffstat (limited to 'commands')
-rw-r--r-- | commands/config.go | 66 |
1 files changed, 64 insertions, 2 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, + }) +} |