From f396cffa239e948075af2224208671956d8b4a84 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B8rn=20Erik=20Pedersen?= Date: Wed, 11 Apr 2018 10:09:45 +0200 Subject: commands: Fix the config command It now also accepts the `-s` (source) flag. See #4598 --- commands/commands_test.go | 1 + commands/config.go | 77 +++++++++++++++++++++++++++++++++++++++++++++++ commands/list_config.go | 74 --------------------------------------------- 3 files changed, 78 insertions(+), 74 deletions(-) create mode 100644 commands/config.go delete mode 100644 commands/list_config.go (limited to 'commands') diff --git a/commands/commands_test.go b/commands/commands_test.go index 4eab9b99f..7e590bea0 100644 --- a/commands/commands_test.go +++ b/commands/commands_test.go @@ -51,6 +51,7 @@ func TestCommands(t *testing.T) { // no args = hugo build {nil, []string{sourceFlag}, ""}, {nil, []string{sourceFlag, "--renderToMemory"}, ""}, + {[]string{"config"}, []string{sourceFlag}, ""}, {[]string{"benchmark"}, []string{sourceFlag, "-n=1"}, ""}, {[]string{"convert", "toTOML"}, []string{sourceFlag, "-o=" + filepath.Join(dirOut, "toml")}, ""}, {[]string{"convert", "toYAML"}, []string{sourceFlag, "-o=" + filepath.Join(dirOut, "yaml")}, ""}, diff --git a/commands/config.go b/commands/config.go new file mode 100644 index 000000000..951b57540 --- /dev/null +++ b/commands/config.go @@ -0,0 +1,77 @@ +// Copyright 2015 The Hugo Authors. All rights reserved. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License.Print the version number of Hug + +package commands + +import ( + "reflect" + "sort" + + "github.com/spf13/cobra" + jww "github.com/spf13/jwalterweatherman" + "github.com/spf13/viper" +) + +var _ cmder = (*configCmd)(nil) + +type configCmd struct { + hugoBuilderCommon + *baseCmd +} + +func newConfigCmd() *configCmd { + cc := &configCmd{} + cc.baseCmd = newBaseCmd(&cobra.Command{ + Use: "config", + Short: "Print the site configuration", + Long: `Print the site configuration, both default and custom settings.`, + RunE: cc.printConfig, + }) + + cc.cmd.Flags().StringVarP(&cc.source, "source", "s", "", "filesystem path to read files relative from") + + return cc +} + +func (c *configCmd) printConfig(cmd *cobra.Command, args []string) error { + cfg, err := initializeConfig(false, &c.hugoBuilderCommon, c, nil) + + if err != nil { + return err + } + + allSettings := cfg.Cfg.(*viper.Viper).AllSettings() + + var separator string + if allSettings["metadataformat"] == "toml" { + separator = " = " + } else { + separator = ": " + } + + var keys []string + for k := range allSettings { + keys = append(keys, k) + } + sort.Strings(keys) + for _, k := range keys { + kv := reflect.ValueOf(allSettings[k]) + if kv.Kind() == reflect.String { + jww.FEEDBACK.Printf("%s%s\"%+v\"\n", k, separator, allSettings[k]) + } else { + jww.FEEDBACK.Printf("%s%s%+v\n", k, separator, allSettings[k]) + } + } + + return nil +} diff --git a/commands/list_config.go b/commands/list_config.go deleted file mode 100644 index 32b739d8a..000000000 --- a/commands/list_config.go +++ /dev/null @@ -1,74 +0,0 @@ -// Copyright 2015 The Hugo Authors. All rights reserved. -// -// Licensed under the Apache License, Version 2.0 (the "License"); -// you may not use this file except in compliance with the License. -// You may obtain a copy of the License at -// http://www.apache.org/licenses/LICENSE-2.0 -// -// Unless required by applicable law or agreed to in writing, software -// distributed under the License is distributed on an "AS IS" BASIS, -// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -// See the License for the specific language governing permissions and -// limitations under the License.Print the version number of Hug - -package commands - -import ( - "reflect" - "sort" - - "github.com/spf13/cobra" - jww "github.com/spf13/jwalterweatherman" - "github.com/spf13/viper" -) - -var _ cmder = (*configCmd)(nil) - -type configCmd struct { - *baseCmd -} - -func newConfigCmd() *configCmd { - cc := &configCmd{} - cc.baseCmd = newBaseCmd(&cobra.Command{ - Use: "config", - Short: "Print the site configuration", - Long: `Print the site configuration, both default and custom settings.`, - RunE: cc.printConfig, - }) - - return cc -} - -func (c *configCmd) printConfig(cmd *cobra.Command, args []string) error { - cfg, err := initializeConfig(false, nil, c, nil) - - if err != nil { - return err - } - - allSettings := cfg.Cfg.(*viper.Viper).AllSettings() - - var separator string - if allSettings["metadataformat"] == "toml" { - separator = " = " - } else { - separator = ": " - } - - var keys []string - for k := range allSettings { - keys = append(keys, k) - } - sort.Strings(keys) - for _, k := range keys { - kv := reflect.ValueOf(allSettings[k]) - if kv.Kind() == reflect.String { - jww.FEEDBACK.Printf("%s%s\"%+v\"\n", k, separator, allSettings[k]) - } else { - jww.FEEDBACK.Printf("%s%s%+v\n", k, separator, allSettings[k]) - } - } - - return nil -} -- cgit v1.2.3