command: implement help builder
Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
parent
7bd48d3489
commit
8000a2febb
@ -1,7 +1,10 @@
|
|||||||
// Package command implements generic nested command parsing.
|
// Package command implements generic nested command parsing.
|
||||||
package command
|
package command
|
||||||
|
|
||||||
import "flag"
|
import (
|
||||||
|
"flag"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
type (
|
type (
|
||||||
// HandlerFunc is called when matching a directly handled subcommand tree.
|
// HandlerFunc is called when matching a directly handled subcommand tree.
|
||||||
@ -13,7 +16,7 @@ type (
|
|||||||
// FlagDefiner is a deferred flag definer value, usually encapsulating the default value.
|
// FlagDefiner is a deferred flag definer value, usually encapsulating the default value.
|
||||||
FlagDefiner interface {
|
FlagDefiner interface {
|
||||||
// Define defines the flag in set.
|
// Define defines the flag in set.
|
||||||
Define(set *flag.FlagSet, p any, name, usage string)
|
Define(b *strings.Builder, set *flag.FlagSet, p any, name, usage string)
|
||||||
}
|
}
|
||||||
|
|
||||||
Command interface {
|
Command interface {
|
||||||
|
49
command/help.go
Normal file
49
command/help.go
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
package command
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"strings"
|
||||||
|
"text/tabwriter"
|
||||||
|
)
|
||||||
|
|
||||||
|
var ErrHelp = errors.New("help requested")
|
||||||
|
|
||||||
|
func (n *node) writeHelp() error {
|
||||||
|
if _, err := fmt.Fprintf(n.out,
|
||||||
|
"\nUsage:\t%s [-h | --help]%s COMMAND [OPTIONS]\n",
|
||||||
|
strings.Join(append(n.prefix, n.name), " "), &n.suffix,
|
||||||
|
); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if n.child != nil {
|
||||||
|
if _, err := fmt.Fprint(n.out, "\nCommands:\n"); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tw := tabwriter.NewWriter(n.out, 0, 1, 4, ' ', 0)
|
||||||
|
if err := n.child.writeCommands(tw); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if err := tw.Flush(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err := n.out.Write([]byte{'\n'})
|
||||||
|
if err == nil {
|
||||||
|
err = ErrHelp
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (n *node) writeCommands(w io.Writer) error {
|
||||||
|
if n == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
if _, err := fmt.Fprintf(w, "\t%s\t%s\n", n.name, n.usage); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return n.next.writeCommands(w)
|
||||||
|
}
|
@ -3,6 +3,7 @@ package command
|
|||||||
import (
|
import (
|
||||||
"flag"
|
"flag"
|
||||||
"io"
|
"io"
|
||||||
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
type node struct {
|
type node struct {
|
||||||
@ -12,6 +13,9 @@ type node struct {
|
|||||||
out io.Writer
|
out io.Writer
|
||||||
logf LogFunc
|
logf LogFunc
|
||||||
|
|
||||||
|
prefix []string
|
||||||
|
suffix strings.Builder
|
||||||
|
|
||||||
f HandlerFunc
|
f HandlerFunc
|
||||||
set *flag.FlagSet
|
set *flag.FlagSet
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user