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
|
// Copyright 2017 Google Inc. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package getopt
import (
"fmt"
"strconv"
)
type counterValue int
func (b *counterValue) Set(value string, opt Option) error {
if value == "" {
*b++
} else {
v, err := strconv.ParseInt(value, 0, strconv.IntSize)
if err != nil {
if e, ok := err.(*strconv.NumError); ok {
switch e.Err {
case strconv.ErrRange:
err = fmt.Errorf("value out of range: %s", value)
case strconv.ErrSyntax:
err = fmt.Errorf("not a valid number: %s", value)
}
}
return err
}
*b = counterValue(v)
}
return nil
}
func (b *counterValue) String() string {
return strconv.Itoa(int(*b))
}
// Counter creates a counting flag stored as an int. Each time the option
// is seen while parsing the value is incremented. The value of the counter
// may be explicitly set by using the long form:
//
// --counter=5
// --c=5
//
// Further instances of the option will increment from the set value.
func Counter(name rune, helpvalue ...string) *int {
var p int
CommandLine.FlagLong((*counterValue)(&p), "", name, helpvalue...).SetFlag()
return &p
}
func (s *Set) Counter(name rune, helpvalue ...string) *int {
var p int
s.FlagLong((*counterValue)(&p), "", name, helpvalue...).SetFlag()
return &p
}
func CounterLong(name string, short rune, helpvalue ...string) *int {
var p int
CommandLine.FlagLong((*counterValue)(&p), name, short, helpvalue...).SetFlag()
return &p
}
func (s *Set) CounterLong(name string, short rune, helpvalue ...string) *int {
var p int
s.FlagLong((*counterValue)(&p), name, short, helpvalue...).SetFlag()
return &p
}
|