mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
00a8a40398
Use the generate.sh script instead of md2man directly. Update Dockerfile for generating man pages. Signed-off-by: Daniel Nephin <dnephin@docker.com>
161 lines
5.2 KiB
Go
161 lines
5.2 KiB
Go
package cobraadaptor
|
|
|
|
import (
|
|
"github.com/docker/docker/api/client"
|
|
"github.com/docker/docker/api/client/container"
|
|
"github.com/docker/docker/api/client/image"
|
|
"github.com/docker/docker/api/client/network"
|
|
"github.com/docker/docker/api/client/node"
|
|
"github.com/docker/docker/api/client/plugin"
|
|
"github.com/docker/docker/api/client/registry"
|
|
"github.com/docker/docker/api/client/service"
|
|
"github.com/docker/docker/api/client/stack"
|
|
"github.com/docker/docker/api/client/swarm"
|
|
"github.com/docker/docker/api/client/system"
|
|
"github.com/docker/docker/api/client/volume"
|
|
"github.com/docker/docker/cli"
|
|
cliflags "github.com/docker/docker/cli/flags"
|
|
"github.com/docker/docker/pkg/term"
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
// CobraAdaptor is an adaptor for supporting spf13/cobra commands in the
|
|
// docker/cli framework
|
|
type CobraAdaptor struct {
|
|
rootCmd *cobra.Command
|
|
dockerCli *client.DockerCli
|
|
}
|
|
|
|
// NewCobraAdaptor returns a new handler
|
|
func NewCobraAdaptor(clientFlags *cliflags.ClientFlags) CobraAdaptor {
|
|
stdin, stdout, stderr := term.StdStreams()
|
|
dockerCli := client.NewDockerCli(stdin, stdout, stderr, clientFlags)
|
|
|
|
var rootCmd = &cobra.Command{
|
|
Use: "docker [OPTIONS]",
|
|
Short: "A self-sufficient runtime for containers",
|
|
SilenceUsage: true,
|
|
SilenceErrors: true,
|
|
}
|
|
rootCmd.SetUsageTemplate(usageTemplate)
|
|
rootCmd.SetHelpTemplate(helpTemplate)
|
|
rootCmd.SetFlagErrorFunc(cli.FlagErrorFunc)
|
|
rootCmd.SetOutput(stdout)
|
|
rootCmd.AddCommand(
|
|
node.NewNodeCommand(dockerCli),
|
|
service.NewServiceCommand(dockerCli),
|
|
stack.NewStackCommand(dockerCli),
|
|
stack.NewTopLevelDeployCommand(dockerCli),
|
|
swarm.NewSwarmCommand(dockerCli),
|
|
container.NewAttachCommand(dockerCli),
|
|
container.NewCommitCommand(dockerCli),
|
|
container.NewCopyCommand(dockerCli),
|
|
container.NewCreateCommand(dockerCli),
|
|
container.NewDiffCommand(dockerCli),
|
|
container.NewExportCommand(dockerCli),
|
|
container.NewKillCommand(dockerCli),
|
|
container.NewLogsCommand(dockerCli),
|
|
container.NewPauseCommand(dockerCli),
|
|
container.NewPortCommand(dockerCli),
|
|
container.NewPsCommand(dockerCli),
|
|
container.NewRenameCommand(dockerCli),
|
|
container.NewRestartCommand(dockerCli),
|
|
container.NewRmCommand(dockerCli),
|
|
container.NewRunCommand(dockerCli),
|
|
container.NewStartCommand(dockerCli),
|
|
container.NewStatsCommand(dockerCli),
|
|
container.NewStopCommand(dockerCli),
|
|
container.NewTopCommand(dockerCli),
|
|
container.NewUnpauseCommand(dockerCli),
|
|
container.NewUpdateCommand(dockerCli),
|
|
container.NewWaitCommand(dockerCli),
|
|
image.NewBuildCommand(dockerCli),
|
|
image.NewHistoryCommand(dockerCli),
|
|
image.NewImagesCommand(dockerCli),
|
|
image.NewLoadCommand(dockerCli),
|
|
image.NewRemoveCommand(dockerCli),
|
|
image.NewSaveCommand(dockerCli),
|
|
image.NewPullCommand(dockerCli),
|
|
image.NewPushCommand(dockerCli),
|
|
image.NewSearchCommand(dockerCli),
|
|
image.NewImportCommand(dockerCli),
|
|
image.NewTagCommand(dockerCli),
|
|
network.NewNetworkCommand(dockerCli),
|
|
system.NewEventsCommand(dockerCli),
|
|
registry.NewLoginCommand(dockerCli),
|
|
registry.NewLogoutCommand(dockerCli),
|
|
system.NewVersionCommand(dockerCli),
|
|
volume.NewVolumeCommand(dockerCli),
|
|
system.NewInfoCommand(dockerCli),
|
|
)
|
|
plugin.NewPluginCommand(rootCmd, dockerCli)
|
|
|
|
rootCmd.PersistentFlags().BoolP("help", "h", false, "Print usage")
|
|
rootCmd.PersistentFlags().MarkShorthandDeprecated("help", "please use --help")
|
|
|
|
return CobraAdaptor{
|
|
rootCmd: rootCmd,
|
|
dockerCli: dockerCli,
|
|
}
|
|
}
|
|
|
|
// Usage returns the list of commands and their short usage string for
|
|
// all top level cobra commands.
|
|
func (c CobraAdaptor) Usage() []cli.Command {
|
|
cmds := []cli.Command{}
|
|
for _, cmd := range c.rootCmd.Commands() {
|
|
if cmd.Name() != "" {
|
|
cmds = append(cmds, cli.Command{Name: cmd.Name(), Description: cmd.Short})
|
|
}
|
|
}
|
|
return cmds
|
|
}
|
|
|
|
func (c CobraAdaptor) run(cmd string, args []string) error {
|
|
if err := c.dockerCli.Initialize(); err != nil {
|
|
return err
|
|
}
|
|
// Prepend the command name to support normal cobra command delegation
|
|
c.rootCmd.SetArgs(append([]string{cmd}, args...))
|
|
return c.rootCmd.Execute()
|
|
}
|
|
|
|
// Command returns a cli command handler if one exists
|
|
func (c CobraAdaptor) Command(name string) func(...string) error {
|
|
for _, cmd := range c.rootCmd.Commands() {
|
|
if cmd.Name() == name {
|
|
return func(args ...string) error {
|
|
return c.run(name, args)
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// GetRootCommand returns the root command. Required to generate the man pages
|
|
// and reference docs from a script outside this package.
|
|
func (c CobraAdaptor) GetRootCommand() *cobra.Command {
|
|
return c.rootCmd
|
|
}
|
|
|
|
var usageTemplate = `Usage: {{if not .HasSubCommands}}{{.UseLine}}{{end}}{{if .HasSubCommands}}{{ .CommandPath}} COMMAND{{end}}
|
|
|
|
{{ .Short | trim }}{{if gt .Aliases 0}}
|
|
|
|
Aliases:
|
|
{{.NameAndAliases}}{{end}}{{if .HasExample}}
|
|
|
|
Examples:
|
|
{{ .Example }}{{end}}{{if .HasFlags}}
|
|
|
|
Options:
|
|
{{.Flags.FlagUsages | trimRightSpace}}{{end}}{{ if .HasAvailableSubCommands}}
|
|
|
|
Commands:{{range .Commands}}{{if .IsAvailableCommand}}
|
|
{{rpad .Name .NamePadding }} {{.Short}}{{end}}{{end}}{{end}}{{ if .HasSubCommands }}
|
|
|
|
Run '{{.CommandPath}} COMMAND --help' for more information on a command.{{end}}
|
|
`
|
|
|
|
var helpTemplate = `
|
|
{{if or .Runnable .HasSubCommands}}{{.UsageString}}{{end}}`
|