mirror of https://github.com/hashicorp/consul
86 lines
1.8 KiB
Go
86 lines
1.8 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: BUSL-1.1
|
|
|
|
package client
|
|
|
|
import (
|
|
"bytes"
|
|
"flag"
|
|
"fmt"
|
|
"io"
|
|
"strings"
|
|
|
|
"github.com/kr/text"
|
|
)
|
|
|
|
func Usage(txt string, flags *flag.FlagSet) string {
|
|
u := &Usager{
|
|
Usage: txt,
|
|
Flags: flags,
|
|
}
|
|
return u.String()
|
|
}
|
|
|
|
type Usager struct {
|
|
Usage string
|
|
Flags *flag.FlagSet
|
|
}
|
|
|
|
func (u *Usager) String() string {
|
|
out := new(bytes.Buffer)
|
|
out.WriteString(strings.TrimSpace(u.Usage))
|
|
out.WriteString("\n")
|
|
out.WriteString("\n")
|
|
|
|
if u.Flags != nil {
|
|
var cmdFlags *flag.FlagSet
|
|
u.Flags.VisitAll(func(f *flag.Flag) {
|
|
if cmdFlags == nil {
|
|
cmdFlags = flag.NewFlagSet("", flag.ContinueOnError)
|
|
}
|
|
cmdFlags.Var(f.Value, f.Name, f.Usage)
|
|
})
|
|
|
|
if cmdFlags != nil {
|
|
printTitle(out, "Command Options")
|
|
cmdFlags.VisitAll(func(f *flag.Flag) {
|
|
printFlag(out, f)
|
|
})
|
|
}
|
|
}
|
|
|
|
return strings.TrimRight(out.String(), "\n")
|
|
}
|
|
|
|
// printTitle prints a consistently-formatted title to the given writer.
|
|
func printTitle(w io.Writer, s string) {
|
|
fmt.Fprintf(w, "%s\n\n", s)
|
|
}
|
|
|
|
// printFlag prints a single flag to the given writer.
|
|
func printFlag(w io.Writer, f *flag.Flag) {
|
|
example, _ := flag.UnquoteUsage(f)
|
|
if example != "" {
|
|
fmt.Fprintf(w, " -%s=<%s>\n", f.Name, example)
|
|
} else {
|
|
fmt.Fprintf(w, " -%s\n", f.Name)
|
|
}
|
|
|
|
indented := wrapAtLength(f.Usage, 5)
|
|
fmt.Fprintf(w, "%s\n\n", indented)
|
|
}
|
|
|
|
// maxLineLength is the maximum width of any line.
|
|
const maxLineLength int = 72
|
|
|
|
// wrapAtLength wraps the given text at the maxLineLength, taking into account
|
|
// any provided left padding.
|
|
func wrapAtLength(s string, pad int) string {
|
|
wrapped := text.Wrap(s, maxLineLength-pad)
|
|
lines := strings.Split(wrapped, "\n")
|
|
for i, line := range lines {
|
|
lines[i] = strings.Repeat(" ", pad) + line
|
|
}
|
|
return strings.Join(lines, "\n")
|
|
}
|