commands: Re-add the missing releaser command
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 16 Apr 2018 06:23:32 +0000 (08:23 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 16 Apr 2018 06:23:32 +0000 (08:23 +0200)
commands/commands.go
commands/commands_test.go
commands/release.go
commands/release_noop.go [new file with mode: 0644]

index d0cc97b85aa0dc98e846724aa81ac26838e7cc15..8ba28e10dcbc8255391a7d7e644d9f9b7eb92939 100644 (file)
@@ -49,6 +49,7 @@ func (b *commandsBuilder) addAll() *commandsBuilder {
                newListCmd(),
                newImportCmd(),
                newGenCmd(),
+               createReleaser(),
        )
 
        return b
@@ -62,7 +63,11 @@ func (b *commandsBuilder) build() *hugoCmd {
 
 func addCommands(root *cobra.Command, commands ...cmder) {
        for _, command := range commands {
-               root.AddCommand(command.getCommand())
+               cmd := command.getCommand()
+               if cmd == nil {
+                       continue
+               }
+               root.AddCommand(cmd)
        }
 }
 
@@ -110,6 +115,19 @@ type hugoCmd struct {
        c *commandeer
 }
 
+var _ cmder = (*nilCommand)(nil)
+
+type nilCommand struct {
+}
+
+func (c *nilCommand) getCommand() *cobra.Command {
+       return nil
+}
+
+func (c *nilCommand) flagsToConfig(cfg config.Provider) {
+
+}
+
 func (b *commandsBuilder) newHugoCmd() *hugoCmd {
        cc := &hugoCmd{}
 
index 376ca7976fbb0eea029362e8527773cc973147d1..907f003c0bde72d5a2a9ad1fb7994391f6400dac 100644 (file)
@@ -118,6 +118,9 @@ func TestCommandsPersistentFlags(t *testing.T) {
                root := b.addAll().build()
 
                for _, c := range b.commands {
+                       if c.getCommand() == nil {
+                               continue
+                       }
                        // We are only intereseted in the flag handling here.
                        c.getCommand().RunE = noOpRunE
                }
index a95697e49e93b48ee400625bc3a7f65285cf515e..4de165f35bf6bda54b5afa92e875ea6e2f3c234f 100644 (file)
@@ -18,10 +18,13 @@ package commands
 import (
        "errors"
 
+       "github.com/gohugoio/hugo/config"
        "github.com/gohugoio/hugo/releaser"
        "github.com/spf13/cobra"
 )
 
+var _ cmder = (*releaseCommandeer)(nil)
+
 type releaseCommandeer struct {
        cmd *cobra.Command
 
@@ -31,7 +34,7 @@ type releaseCommandeer struct {
        try         bool
 }
 
-func createReleaser() *releaseCommandeer {
+func createReleaser() cmder {
        // Note: This is a command only meant for internal use and must be run
        // via "go run -tags release main.go release" on the actual code base that is in the release.
        r := &releaseCommandeer{
@@ -53,6 +56,14 @@ func createReleaser() *releaseCommandeer {
        return r
 }
 
+func (c *releaseCommandeer) getCommand() *cobra.Command {
+       return c.cmd
+}
+
+func (c *releaseCommandeer) flagsToConfig(cfg config.Provider) {
+
+}
+
 func (r *releaseCommandeer) release() error {
        if r.version == "" {
                return errors.New("must set the --rel flag to the relevant version number")
diff --git a/commands/release_noop.go b/commands/release_noop.go
new file mode 100644 (file)
index 0000000..ccf34b6
--- /dev/null
@@ -0,0 +1,20 @@
+// +build !release
+
+// Copyright 2018 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.
+
+package commands
+
+func createReleaser() cmder {
+       return &nilCommand{}
+}