mattermost/server/cmd/mmctl/commands/docs.go
Alejandro García Montoro 350714f390
Bump Go to v1.23.7 (#30455)
* Update Go version to v1.23.7

* Bump golangci-lint to a version supporting Go 1.23

* Fix golangci-lint warnings

Several rules from gosimple, revive and staticcheck linters were
failing:
- Redefinition of built-in identifiers (max, min, new, recover...)
- Use of printf-like functions with simple strings
- Check for nil slices, when len already takes it into account

* Trigger Build

* Trigger Build

---------

Co-authored-by: Mattermost Build <build@mattermost.com>
2025-03-17 14:22:07 +01:00

48 lines
965 B
Go

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
package commands
import (
"fmt"
"os"
"github.com/spf13/cobra"
"github.com/spf13/cobra/doc"
)
var DocsCmd = &cobra.Command{
Use: "docs",
Short: "Generates mmctl documentation",
Args: cobra.NoArgs,
RunE: docsCmdF,
}
func init() {
DocsCmd.Flags().StringP("directory", "d", "docs", "The directory where the docs would be generated in.")
RootCmd.AddCommand(DocsCmd)
}
func docsCmdF(cmd *cobra.Command, args []string) error {
outDir, _ := cmd.Flags().GetString("directory")
fileInfo, err := os.Stat(outDir)
if err != nil {
if !os.IsNotExist(err) {
return err
}
if createErr := os.Mkdir(outDir, 0755); createErr != nil {
return createErr
}
} else if !fileInfo.IsDir() {
return fmt.Errorf("File %q is not a directory", outDir)
}
err = doc.GenReSTTree(RootCmd, outDir)
if err != nil {
return err
}
return nil
}