From: Bjørn Erik Pedersen Date: Tue, 3 Mar 2020 10:00:45 +0000 (+0100) Subject: commands: Add --all flag to hugo mod clean X-Git-Tag: v0.66.0~7 X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=760a87a45a0a3e6a581851e5cf4fe440e9a8c655;p=brevno-suite%2Fhugo commands: Add --all flag to hugo mod clean --- diff --git a/commands/mod.go b/commands/mod.go index 0b88df66..81f660f4 100644 --- a/commands/mod.go +++ b/commands/mod.go @@ -18,6 +18,7 @@ import ( "fmt" "os" "path/filepath" + "regexp" "github.com/gohugoio/hugo/modules" "github.com/spf13/cobra" @@ -49,8 +50,11 @@ func (c *modCmd) newVerifyCmd() *cobra.Command { return verifyCmd } +var moduleNotFoundRe = regexp.MustCompile("module.*not found") + func (c *modCmd) newCleanCmd() *cobra.Command { var pattern string + var all bool cmd := &cobra.Command{ Use: "clean", Short: "Delete the Hugo Module cache for the current project.", @@ -62,6 +66,16 @@ Also note that if you configure a positive maxAge for the "modules" file cache, `, RunE: func(cmd *cobra.Command, args []string) error { + if all { + com, err := c.initConfig(false) + + if err != nil && !moduleNotFoundRe.MatchString(err.Error()) { + return err + } + + _, err = com.hugo().FileCaches.ModulesCache().Prune(true) + return err + } return c.withModsClient(true, func(c *modules.Client) error { return c.Clean(pattern) }) @@ -69,6 +83,7 @@ Also note that if you configure a positive maxAge for the "modules" file cache, } cmd.Flags().StringVarP(&pattern, "pattern", "", "", `pattern matching module paths to clean (all if not set), e.g. "**hugo*"`) + cmd.Flags().BoolVarP(&all, "all", "", false, "clean entire module cache") return cmd }