-
-
Notifications
You must be signed in to change notification settings - Fork 398
/
Copy pathgeneratedocs.go
88 lines (79 loc) · 2.82 KB
/
generatedocs.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
// This file is part of arduino-cli.
//
// Copyright 2020 ARDUINO SA (http://www.arduino.cc/)
//
// This software is released under the GNU General Public License version 3,
// which covers the main part of arduino-cli.
// The terms of this license can be found at:
// https://www.gnu.org/licenses/gpl-3.0.en.html
//
// You can be released from the requirements of the above licenses by purchasing
// a commercial license. Buying such a license is mandatory if you want to
// modify or otherwise use the software for commercial activities involving the
// Arduino software without disclosing the source code of your own applications.
// To purchase a commercial license, send an email to license@arduino.cc.
package generatedocs
import (
"os"
"path/filepath"
"github.com/arduino/arduino-cli/internal/cli/feedback"
"github.com/arduino/arduino-cli/internal/i18n"
"github.com/sirupsen/logrus"
"github.com/spf13/cobra"
"github.com/spf13/cobra/doc"
)
var (
outputDir = ""
tr = i18n.Tr
)
// NewCommand created a new `generate-docs` command
func NewCommand() *cobra.Command {
generateDocsCommand := &cobra.Command{
Use: "generate-docs",
Short: i18n.Tr("Generates bash completion and command manpages."),
Long: i18n.Tr("Generates bash completion and command manpages."),
Example: " " + os.Args[0] + " generate-docs bash-completions",
Hidden: true,
}
generateDocsCommand.PersistentFlags().StringVarP(&outputDir, "output-dir", "o", "",
i18n.Tr("Directory where to save generated files. Default is './docs', the directory must exist."))
generateDocsCommand.AddCommand(&cobra.Command{
Use: "manpage",
Args: cobra.NoArgs,
Run: generateManPages,
})
generateDocsCommand.AddCommand(&cobra.Command{
Use: "bash-completions",
Args: cobra.NoArgs,
Run: generateBashCompletions,
})
return generateDocsCommand
}
func generateBashCompletions(cmd *cobra.Command, args []string) {
logrus.Info("Executing `arduino-cli generate-docs`")
if outputDir == "" {
outputDir = "docs/bash_completions"
}
logrus.WithField("outputDir", outputDir).Info("Generating bash completion")
err := cmd.Root().GenBashCompletionFile(filepath.Join(outputDir, "arduino"))
if err != nil {
logrus.WithError(err).Warn("Error Generating bash autocompletions")
feedback.FatalError(err, feedback.ErrGeneric)
}
}
// Generates man pages for all commands and puts them in $PROJECT_DIR/docs/manpages.
func generateManPages(cmd *cobra.Command, args []string) {
if outputDir == "" {
outputDir = "docs/manpages"
}
logrus.WithField("outputDir", outputDir).Info("Generating manpages")
header := &doc.GenManHeader{
Title: i18n.Tr("ARDUINO COMMAND LINE MANUAL"),
Section: "1",
}
err := doc.GenManTree(cmd.Root(), header, outputDir)
if err != nil {
logrus.WithError(err).Warn("Error Generating manpages")
feedback.FatalError(err, feedback.ErrGeneric)
}
}