vanity

vanity - A tiny server for golang vanity redirects
Log | Files | Refs | README | LICENSE

ipmask.go (4052B)


      1 package pflag
      2 
      3 import (
      4 	"fmt"
      5 	"net"
      6 	"strconv"
      7 )
      8 
      9 // -- net.IPMask value
     10 type ipMaskValue net.IPMask
     11 
     12 func newIPMaskValue(val net.IPMask, p *net.IPMask) *ipMaskValue {
     13 	*p = val
     14 	return (*ipMaskValue)(p)
     15 }
     16 
     17 func (i *ipMaskValue) String() string { return net.IPMask(*i).String() }
     18 func (i *ipMaskValue) Set(s string) error {
     19 	ip := ParseIPv4Mask(s)
     20 	if ip == nil {
     21 		return fmt.Errorf("failed to parse IP mask: %q", s)
     22 	}
     23 	*i = ipMaskValue(ip)
     24 	return nil
     25 }
     26 
     27 func (i *ipMaskValue) Type() string {
     28 	return "ipMask"
     29 }
     30 
     31 // ParseIPv4Mask written in IP form (e.g. 255.255.255.0).
     32 // This function should really belong to the net package.
     33 func ParseIPv4Mask(s string) net.IPMask {
     34 	mask := net.ParseIP(s)
     35 	if mask == nil {
     36 		if len(s) != 8 {
     37 			return nil
     38 		}
     39 		// net.IPMask.String() actually outputs things like ffffff00
     40 		// so write a horrible parser for that as well  :-(
     41 		m := []int{}
     42 		for i := 0; i < 4; i++ {
     43 			b := "0x" + s[2*i:2*i+2]
     44 			d, err := strconv.ParseInt(b, 0, 0)
     45 			if err != nil {
     46 				return nil
     47 			}
     48 			m = append(m, int(d))
     49 		}
     50 		s := fmt.Sprintf("%d.%d.%d.%d", m[0], m[1], m[2], m[3])
     51 		mask = net.ParseIP(s)
     52 		if mask == nil {
     53 			return nil
     54 		}
     55 	}
     56 	return net.IPv4Mask(mask[12], mask[13], mask[14], mask[15])
     57 }
     58 
     59 func parseIPv4Mask(sval string) (interface{}, error) {
     60 	mask := ParseIPv4Mask(sval)
     61 	if mask == nil {
     62 		return nil, fmt.Errorf("unable to parse %s as net.IPMask", sval)
     63 	}
     64 	return mask, nil
     65 }
     66 
     67 // GetIPv4Mask return the net.IPv4Mask value of a flag with the given name
     68 func (f *FlagSet) GetIPv4Mask(name string) (net.IPMask, error) {
     69 	val, err := f.getFlagType(name, "ipMask", parseIPv4Mask)
     70 	if err != nil {
     71 		return nil, err
     72 	}
     73 	return val.(net.IPMask), nil
     74 }
     75 
     76 // IPMaskVar defines an net.IPMask flag with specified name, default value, and usage string.
     77 // The argument p points to an net.IPMask variable in which to store the value of the flag.
     78 func (f *FlagSet) IPMaskVar(p *net.IPMask, name string, value net.IPMask, usage string) {
     79 	f.VarP(newIPMaskValue(value, p), name, "", usage)
     80 }
     81 
     82 // IPMaskVarP is like IPMaskVar, but accepts a shorthand letter that can be used after a single dash.
     83 func (f *FlagSet) IPMaskVarP(p *net.IPMask, name, shorthand string, value net.IPMask, usage string) {
     84 	f.VarP(newIPMaskValue(value, p), name, shorthand, usage)
     85 }
     86 
     87 // IPMaskVar defines an net.IPMask flag with specified name, default value, and usage string.
     88 // The argument p points to an net.IPMask variable in which to store the value of the flag.
     89 func IPMaskVar(p *net.IPMask, name string, value net.IPMask, usage string) {
     90 	CommandLine.VarP(newIPMaskValue(value, p), name, "", usage)
     91 }
     92 
     93 // IPMaskVarP is like IPMaskVar, but accepts a shorthand letter that can be used after a single dash.
     94 func IPMaskVarP(p *net.IPMask, name, shorthand string, value net.IPMask, usage string) {
     95 	CommandLine.VarP(newIPMaskValue(value, p), name, shorthand, usage)
     96 }
     97 
     98 // IPMask defines an net.IPMask flag with specified name, default value, and usage string.
     99 // The return value is the address of an net.IPMask variable that stores the value of the flag.
    100 func (f *FlagSet) IPMask(name string, value net.IPMask, usage string) *net.IPMask {
    101 	p := new(net.IPMask)
    102 	f.IPMaskVarP(p, name, "", value, usage)
    103 	return p
    104 }
    105 
    106 // IPMaskP is like IPMask, but accepts a shorthand letter that can be used after a single dash.
    107 func (f *FlagSet) IPMaskP(name, shorthand string, value net.IPMask, usage string) *net.IPMask {
    108 	p := new(net.IPMask)
    109 	f.IPMaskVarP(p, name, shorthand, value, usage)
    110 	return p
    111 }
    112 
    113 // IPMask defines an net.IPMask flag with specified name, default value, and usage string.
    114 // The return value is the address of an net.IPMask variable that stores the value of the flag.
    115 func IPMask(name string, value net.IPMask, usage string) *net.IPMask {
    116 	return CommandLine.IPMaskP(name, "", value, usage)
    117 }
    118 
    119 // IPMaskP is like IP, but accepts a shorthand letter that can be used after a single dash.
    120 func IPMaskP(name, shorthand string, value net.IPMask, usage string) *net.IPMask {
    121 	return CommandLine.IPMaskP(name, shorthand, value, usage)
    122 }