-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathgoptions.go
99 lines (80 loc) · 3.58 KB
/
goptions.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
89
90
91
92
93
94
95
96
97
98
99
/*
package goptions implements a flexible parser for command line options.
Key targets were the support for both long and short flag versions, mutually
exclusive flags, and verbs. Flags and their corresponding variables are defined
by the tags in a (possibly anonymous) struct.
var options struct {
Name string `goptions:"-n, --name"`
Force bool `goptions:"-f, --force"`
Verbosity int `goptions:"-v, --verbose"`
}
Short flags can be combined (e.g. `-nfv`). Long flags take their value after a
separating space. The equals notation (`--long-flag=value`) is NOT supported
right now.
Every member of the struct which is supposed to catch a command line value
has to have a "goptions" tag. The contains the short and long flag names for this
member but can additionally specify any of these options below.
obligatory - Flag must be specified. Otherwise an error will be returned
when Parse() is called.
description='...' - Set the description for this particular flag. Will be
used by the HelpFunc.
mutexgroup='...' - Add this flag to a MutexGroup. Only one flag of the
ones sharing a MutexGroup can be set. Otherwise an error
will be returned when Parse() is called. If one flag in a
MutexGroup is `obligatory` one flag of the group must be
specified. A flag can be in multiple MutexGroups at once.
Depending on the type of the struct member, additional options might become available:
Type: *os.File
The given string is interpreted as a path to a file. If the string is "-"
os.Stdin or os.Stdout will be used. os.Stdin will be returned, if the
`rdonly` flag was set. os.Stdout will be returned, if `wronly` was set.
Available options:
Any combination of create, append, rdonly, wronly, rdwr,
excl, sync, trunc and perm can be specified and correspond directly with
the combination of the homonymous flags in the os package.
Type: *net.TCPAddr
The given string is interpreted as a tcp address. It is passed to
net.ResolvTCPAddr() with "tcp" as the network type identifier.
Type: *net/url.URL
The given string is parsed by net/url.Parse()
Type: time.Duration
The given string is parsed by time.ParseDuration()
If a member is a slice type, multiple definitions of the flags are possible. For each
specification the underlying type will be used.
var options struct {
Servers []string `goptions:"-s, --server, description='Servers to connect to'"`
}{}
goptions also has support for verbs. Each verb accepts its own set of flags which
take exactly the same tag format as global options. For an usage example of verbs
see the PrintHelp() example.
*/
package goptions
import (
"os"
"path/filepath"
)
const (
VERSION = "2.5.11"
)
var (
globalFlagSet *FlagSet
)
// ParseAndFail is a convenience function to parse os.Args[1:] and print
// the help if an error occurs. This should cover 90% of this library's
// applications.
func ParseAndFail(v interface{}) {
globalFlagSet = NewFlagSet(filepath.Base(os.Args[0]), v)
globalFlagSet.ParseAndFail(os.Stderr, os.Args[1:])
}
// Parse parses the command-line flags from os.Args[1:].
func Parse(v interface{}) error {
globalFlagSet = NewFlagSet(filepath.Base(os.Args[0]), v)
return globalFlagSet.Parse(os.Args[1:])
}
// PrintHelp renders the default help to os.Stderr.
func PrintHelp() {
if globalFlagSet == nil {
panic("Must call Parse() before PrintHelp()")
}
globalFlagSet.PrintHelp(os.Stderr)
}