ip.go 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. package pflag
  2. import (
  3. "fmt"
  4. "net"
  5. "strings"
  6. )
  7. // -- net.IP value
  8. type ipValue net.IP
  9. func newIPValue(val net.IP, p *net.IP) *ipValue {
  10. *p = val
  11. return (*ipValue)(p)
  12. }
  13. func (i *ipValue) String() string { return net.IP(*i).String() }
  14. func (i *ipValue) Set(s string) error {
  15. if s == "" {
  16. return nil
  17. }
  18. ip := net.ParseIP(strings.TrimSpace(s))
  19. if ip == nil {
  20. return fmt.Errorf("failed to parse IP: %q", s)
  21. }
  22. *i = ipValue(ip)
  23. return nil
  24. }
  25. func (i *ipValue) Type() string {
  26. return "ip"
  27. }
  28. func ipConv(sval string) (interface{}, error) {
  29. ip := net.ParseIP(sval)
  30. if ip != nil {
  31. return ip, nil
  32. }
  33. return nil, fmt.Errorf("invalid string being converted to IP address: %s", sval)
  34. }
  35. // GetIP return the net.IP value of a flag with the given name
  36. func (f *FlagSet) GetIP(name string) (net.IP, error) {
  37. val, err := f.getFlagType(name, "ip", ipConv)
  38. if err != nil {
  39. return nil, err
  40. }
  41. return val.(net.IP), nil
  42. }
  43. // IPVar defines an net.IP flag with specified name, default value, and usage string.
  44. // The argument p points to an net.IP variable in which to store the value of the flag.
  45. func (f *FlagSet) IPVar(p *net.IP, name string, value net.IP, usage string) {
  46. f.VarP(newIPValue(value, p), name, "", usage)
  47. }
  48. // IPVarP is like IPVar, but accepts a shorthand letter that can be used after a single dash.
  49. func (f *FlagSet) IPVarP(p *net.IP, name, shorthand string, value net.IP, usage string) {
  50. f.VarP(newIPValue(value, p), name, shorthand, usage)
  51. }
  52. // IPVar defines an net.IP flag with specified name, default value, and usage string.
  53. // The argument p points to an net.IP variable in which to store the value of the flag.
  54. func IPVar(p *net.IP, name string, value net.IP, usage string) {
  55. CommandLine.VarP(newIPValue(value, p), name, "", usage)
  56. }
  57. // IPVarP is like IPVar, but accepts a shorthand letter that can be used after a single dash.
  58. func IPVarP(p *net.IP, name, shorthand string, value net.IP, usage string) {
  59. CommandLine.VarP(newIPValue(value, p), name, shorthand, usage)
  60. }
  61. // IP defines an net.IP flag with specified name, default value, and usage string.
  62. // The return value is the address of an net.IP variable that stores the value of the flag.
  63. func (f *FlagSet) IP(name string, value net.IP, usage string) *net.IP {
  64. p := new(net.IP)
  65. f.IPVarP(p, name, "", value, usage)
  66. return p
  67. }
  68. // IPP is like IP, but accepts a shorthand letter that can be used after a single dash.
  69. func (f *FlagSet) IPP(name, shorthand string, value net.IP, usage string) *net.IP {
  70. p := new(net.IP)
  71. f.IPVarP(p, name, shorthand, value, usage)
  72. return p
  73. }
  74. // IP defines an net.IP flag with specified name, default value, and usage string.
  75. // The return value is the address of an net.IP variable that stores the value of the flag.
  76. func IP(name string, value net.IP, usage string) *net.IP {
  77. return CommandLine.IPP(name, "", value, usage)
  78. }
  79. // IPP is like IP, but accepts a shorthand letter that can be used after a single dash.
  80. func IPP(name, shorthand string, value net.IP, usage string) *net.IP {
  81. return CommandLine.IPP(name, shorthand, value, usage)
  82. }