Files
dolt/cmd/util/command.go
Sungguk Lim 6697c2e6fc Replace github.com/tsuru/gnuflag with github.com/juju/gnuflag (#2340)
Replace vendor folder and where it is used.
2016-08-11 10:29:57 -07:00

70 lines
1.6 KiB
Go

// Copyright 2016 Attic Labs, Inc. All rights reserved.
// Licensed under the Apache License, version 2.0:
// http://www.apache.org/licenses/LICENSE-2.0
// This is the Command struct used by the noms utility. It is packaged in a separate util can be used by other programs as well.
package util
import (
"fmt"
"os"
"strings"
flag "github.com/juju/gnuflag"
)
type Command struct {
// Run runs the command.
// The args are the arguments after the command name.
Run func(args []string) int
// UsageLine is the one-line usage message.
// The first word in the line is taken to be the command name.
UsageLine string
// Short is the short description shown in the 'help' output.
Short string
// Long is the long message shown in the 'help <this-command>' output.
Long string
// Flag is a set of flags specific to this command.
Flags func() *flag.FlagSet
// Nargs is the minimum number of arguments expected after flags, specific to this command.
Nargs int
}
// Name returns the command's name: the first word in the usage line.
func (nc *Command) Name() string {
name := nc.UsageLine
i := strings.Index(name, " ")
if i >= 0 {
name = name[:i]
}
return name
}
func countFlags(flags *flag.FlagSet) int {
if flags == nil {
return 0
} else {
n := 0
flags.VisitAll(func(f *flag.Flag) {
n++
})
return n
}
}
func (nc *Command) Usage() {
fmt.Fprintf(os.Stderr, "usage: %s\n\n", nc.UsageLine)
fmt.Fprintf(os.Stderr, "%s\n", strings.TrimSpace(nc.Long))
flags := nc.Flags()
if countFlags(flags) > 0 {
fmt.Fprintf(os.Stderr, "\noptions:\n")
flags.PrintDefaults()
}
os.Exit(1)
}