Remove hugo gen autocomplete
authorJoe Mooring <joe.mooring@veriphor.com>
Sun, 30 Jan 2022 23:33:15 +0000 (15:33 -0800)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 1 Feb 2022 22:23:30 +0000 (23:23 +0100)
Closes #8862

commands/commands_test.go
commands/gen.go
commands/genautocomplete.go [deleted file]
docs/content/en/commands/hugo.md
docs/content/en/commands/hugo_gen.md
docs/content/en/commands/hugo_gen_autocomplete.md [deleted file]
snap/snapcraft.yaml

index 9966cd93787a38519e08e9053b96be2b3409034b..beb8175277330f6486d190dfc1c8cf39d95db0be 100644 (file)
@@ -274,11 +274,14 @@ func TestCommandsExecute(t *testing.T) {
                // no args = hugo build
                {nil, []string{sourceFlag}, ""},
                {nil, []string{sourceFlag, "--renderToMemory"}, ""},
+               {[]string{"completion", "bash"}, nil, ""},
+               {[]string{"completion", "fish"}, nil, ""},
+               {[]string{"completion", "powershell"}, nil, ""},
+               {[]string{"completion", "zsh"}, nil, ""},
                {[]string{"config"}, []string{sourceFlag}, ""},
                {[]string{"convert", "toTOML"}, []string{sourceFlag, "-o=" + filepath.Join(dirOut, "toml")}, ""},
                {[]string{"convert", "toYAML"}, []string{sourceFlag, "-o=" + filepath.Join(dirOut, "yaml")}, ""},
                {[]string{"convert", "toJSON"}, []string{sourceFlag, "-o=" + filepath.Join(dirOut, "json")}, ""},
-               {[]string{"gen", "autocomplete"}, []string{"--completionfile=" + filepath.Join(dirOut, "autocomplete.txt")}, ""},
                {[]string{"gen", "chromastyles"}, []string{"--style=manni"}, ""},
                {[]string{"gen", "doc"}, []string{"--dir=" + filepath.Join(dirOut, "doc")}, ""},
                {[]string{"gen", "man"}, []string{"--dir=" + filepath.Join(dirOut, "man")}, ""},
index 6878cfe70e28bf833d6c3d7ebf8a931fcb8c760b..c44eba36c492c5ffbf9f0b658e9d5d4a0da9c185 100644 (file)
@@ -31,7 +31,6 @@ func newGenCmd() *genCmd {
        })
 
        cc.cmd.AddCommand(
-               newGenautocompleteCmd().getCommand(),
                newGenDocCmd().getCommand(),
                newGenManCmd().getCommand(),
                createGenDocsHelper().getCommand(),
diff --git a/commands/genautocomplete.go b/commands/genautocomplete.go
deleted file mode 100644 (file)
index 5cdb7b6..0000000
+++ /dev/null
@@ -1,93 +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.
-
-package commands
-
-import (
-       "io"
-       "os"
-
-       "github.com/spf13/cobra"
-       jww "github.com/spf13/jwalterweatherman"
-)
-
-var _ cmder = (*genautocompleteCmd)(nil)
-
-type genautocompleteCmd struct {
-       autocompleteTarget string
-
-       // bash, zsh, fish or powershell
-       autocompleteType string
-
-       *baseCmd
-}
-
-func newGenautocompleteCmd() *genautocompleteCmd {
-       cc := &genautocompleteCmd{}
-
-       cc.baseCmd = newBaseCmd(&cobra.Command{
-               Use:   "autocomplete",
-               Short: "Generate shell autocompletion script for Hugo",
-               Long: `Generates a shell autocompletion script for Hugo.
-
-The script is written to the console (stdout).
-
-To write to file, add the ` + "`--completionfile=/path/to/file`" + ` flag.
-
-Add ` + "`--type={bash, zsh, fish or powershell}`" + ` flag to set alternative
-shell type.
-
-Logout and in again to reload the completion scripts,
-or just source them in directly:
-
-       $ . /etc/bash_completion or /path/to/file`,
-
-               RunE: func(cmd *cobra.Command, args []string) error {
-                       var err error
-                       var target io.Writer
-
-                       if cc.autocompleteTarget == "" {
-                               target = os.Stdout
-                       } else {
-                               target, _ = os.OpenFile(cc.autocompleteTarget, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
-                       }
-
-                       switch cc.autocompleteType {
-                       case "bash":
-                               err = cmd.Root().GenBashCompletion(target)
-                       case "zsh":
-                               err = cmd.Root().GenZshCompletion(target)
-                       case "fish":
-                               err = cmd.Root().GenFishCompletion(target, true)
-                       case "powershell":
-                               err = cmd.Root().GenPowerShellCompletion(target)
-                       default:
-                               return newUserError("Unsupported completion type")
-                       }
-
-                       if err != nil {
-                               return err
-                       }
-
-                       if cc.autocompleteTarget != "" {
-                               jww.FEEDBACK.Println(cc.autocompleteType+" completion file for Hugo saved to", cc.autocompleteTarget)
-                       }
-                       return nil
-               },
-       })
-
-       cc.cmd.PersistentFlags().StringVarP(&cc.autocompleteTarget, "completionfile", "f", "", "autocompletion file, defaults to stdout")
-       cc.cmd.PersistentFlags().StringVarP(&cc.autocompleteType, "type", "t", "bash", "autocompletion type (bash, zsh, fish, or powershell)")
-
-       return cc
-}
index 94d933c8aae14d4704f5483410494756ff1188c3..827bb89e6cbedb3ea8452887ba96b9cae70e4b38 100644 (file)
@@ -68,7 +68,6 @@ hugo [flags]
 
 ### SEE ALSO
 
-* [hugo check](/commands/hugo_check/)   - Contains some verification checks
 * [hugo completion](/commands/hugo_completion/)         - generate the autocompletion script for the specified shell
 * [hugo config](/commands/hugo_config/)         - Print the site configuration
 * [hugo convert](/commands/hugo_convert/)       - Convert your content to different formats
index fc321a9e96b842d7406705fcffc5db4e11078136..55fb1f2bbb9e3ac286708f4a239718ce27518ae2 100644 (file)
@@ -33,7 +33,6 @@ A collection of several useful generators.
 ### SEE ALSO
 
 * [hugo](/commands/hugo/)       - hugo builds your site
-* [hugo gen autocomplete](/commands/hugo_gen_autocomplete/)     - Generate shell autocompletion script for Hugo
 * [hugo gen chromastyles](/commands/hugo_gen_chromastyles/)     - Generate CSS stylesheet for the Chroma code highlighter
 * [hugo gen doc](/commands/hugo_gen_doc/)       - Generate Markdown documentation for the Hugo CLI.
 * [hugo gen man](/commands/hugo_gen_man/)       - Generate man pages for the Hugo CLI
diff --git a/docs/content/en/commands/hugo_gen_autocomplete.md b/docs/content/en/commands/hugo_gen_autocomplete.md
deleted file mode 100644 (file)
index 77f2fa0..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
----
-title: "hugo gen autocomplete"
-slug: hugo_gen_autocomplete
-url: /commands/hugo_gen_autocomplete/
----
-## hugo gen autocomplete
-
-Generate shell autocompletion script for Hugo
-
-### Synopsis
-
-Generates a shell autocompletion script for Hugo.
-
-The script is written to the console (stdout).
-
-To write to file, add the `--completionfile=/path/to/file` flag.
-
-Add `--type={bash, zsh, fish or powershell}` flag to set alternative
-shell type.
-
-Logout and in again to reload the completion scripts,
-or just source them in directly:
-
-       $ . /etc/bash_completion or /path/to/file
-
-```
-hugo gen autocomplete [flags]
-```
-
-### Options
-
-```
-  -f, --completionfile string   autocompletion file, defaults to stdout
-  -h, --help                    help for autocomplete
-  -t, --type string             autocompletion type (bash, zsh, fish, or powershell) (default "bash")
-```
-
-### Options inherited from parent commands
-
-```
-      --config string              config file (default is path/config.yaml|json|toml)
-      --configDir string           config dir (default "config")
-      --debug                      debug output
-  -e, --environment string         build environment
-      --ignoreVendorPaths string   ignores any _vendor for module paths matching the given Glob pattern
-      --log                        enable Logging
-      --logFile string             log File path (if set, logging enabled automatically)
-      --quiet                      build in quiet mode
-  -s, --source string              filesystem path to read files relative from
-      --themesDir string           filesystem path to themes directory
-  -v, --verbose                    verbose output
-      --verboseLog                 verbose logging
-```
-
-### SEE ALSO
-
-* [hugo gen](/commands/hugo_gen/)       - A collection of several useful generators.
-
index fa9605949fefc40dd59bd612a89b35d5999cb550..bb11afc7233c0d159191ba972c51bf6da82d7a1b 100644 (file)
@@ -65,7 +65,7 @@ parts:
       ldd hugo || :
 
       echo " * Building shell completion..."
-      ./hugo gen autocomplete --completionfile=hugo-completion
+      ./hugo completion bash > hugo-completion
 
       echo " * Installing to ${SNAPCRAFT_PART_INSTALL}..."
       install -d $SNAPCRAFT_PART_INSTALL/bin