本文整理汇总了Golang中reflect.Value.SetBool方法的典型用法代码示例。如果您正苦于以下问题:Golang Value.SetBool方法的具体用法?Golang Value.SetBool怎么用?Golang Value.SetBool使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类reflect.Value
的用法示例。
在下文中一共展示了Value.SetBool方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: processField
func processField(value string, field reflect.Value) error {
typ := field.Type()
decoder := decoderFrom(field)
if decoder != nil {
return decoder.Decode(value)
}
switch typ.Kind() {
case reflect.String:
field.SetString(value)
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
var (
val int64
err error
)
if field.Kind() == reflect.Int64 && typ.PkgPath() == "time" && typ.Name() == "Duration" {
var d time.Duration
d, err = time.ParseDuration(value)
val = int64(d)
} else {
val, err = strconv.ParseInt(value, 0, typ.Bits())
}
if err != nil {
return err
}
field.SetInt(val)
case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64:
val, err := strconv.ParseUint(value, 0, typ.Bits())
if err != nil {
return err
}
field.SetUint(val)
case reflect.Bool:
val, err := strconv.ParseBool(value)
if err != nil {
return err
}
field.SetBool(val)
case reflect.Float32, reflect.Float64:
val, err := strconv.ParseFloat(value, typ.Bits())
if err != nil {
return err
}
field.SetFloat(val)
case reflect.Slice:
vals := strings.Split(value, ",")
sl := reflect.MakeSlice(typ, len(vals), len(vals))
for i, val := range vals {
err := processField(val, sl.Index(i))
if err != nil {
return err
}
}
field.Set(sl)
}
return nil
}
示例2: decodeBool
func decodeBool(b []byte, v reflect.Value) error {
if len(b) != 1 {
return SyntaxError(fmt.Sprintf("booleans must be only one byte (len = %d)", len(b)))
}
v.SetBool(b[0] != 0)
return nil
}
示例3: decodeField
func (d *Decoder) decodeField(v reflect.Value, val string) error {
switch v.Type() {
case reflect.TypeOf(time.Duration(0)):
a, err := time.ParseDuration(val)
if err != nil {
return err
}
v.SetInt(int64(a))
default:
switch v.Kind() {
case reflect.String:
v.SetString(val)
case reflect.Int, reflect.Int32, reflect.Int64:
v.Type()
nv, err := strconv.ParseInt(val, 10, 64)
if err != nil {
return err
}
v.SetInt(nv)
case reflect.Bool:
b, err := strconv.ParseBool(val)
if err != nil {
return err
}
v.SetBool(b)
case reflect.Float32, reflect.Float64:
f, err := strconv.ParseFloat(val, 64)
if err != nil {
return err
}
v.SetFloat(f)
}
}
return nil
}
示例4: ParseValue
func (par *boolParser) ParseValue(ctx *parseContext, valueOf reflect.Value, location int, err *Error) int {
if strAt(ctx.str, location, "true") {
valueOf.SetBool(true)
location += 4
} else if strAt(ctx.str, location, "false") {
valueOf.SetBool(false)
location += 5
} else {
err.Location = location
err.Message = boolError
return -1
}
if location < len(ctx.str) {
if ctx.str[location] == '_' ||
(ctx.str[location] >= 'a' && ctx.str[location] <= 'z') ||
(ctx.str[location] >= 'A' && ctx.str[location] <= 'Z') ||
(ctx.str[location] >= '0' && ctx.str[location] <= '9') {
err.Location = location
err.Message = boolError
return -1
}
}
return location
}
示例5: setVal
func (tbl *Table) setVal(field *reflect.Value, val interface{}) {
str, ok := val.(string)
log.Println("trying to set")
if ok {
log.Println("setting string")
field.SetString(str)
return
}
i, ok := val.(int64)
if ok {
field.SetInt(i)
return
}
ui, ok := val.(uint64)
if ok {
field.SetUint(ui)
return
}
b, ok := val.(bool)
if ok {
field.SetBool(b)
return
}
f, ok := val.(float64)
if ok {
field.SetFloat(f)
return
}
t, ok := val.(time.Time)
if ok {
field.Set(reflect.ValueOf(t))
return
}
}
示例6: luaU_FetchBool
func luaU_FetchBool(l Lua_State, v *reflect.Value) (ok bool) {
if ok = Lua_isboolean(l, -1); ok {
v.SetBool(Lua_toboolean(l, -1))
}
Lua_pop(l, 1)
return
}
示例7: setValue
// setValue updates the field value in fv to the data extracted from config
// with key.
func setValue(fv *reflect.Value, c *Config, key string) error {
// Update the value with the correct type
switch fv.Kind() {
case reflect.Int:
val, err := c.GetInt(key)
if err != nil {
return err
}
fv.SetInt(int64(val))
case reflect.Float64:
val, err := c.GetFloat(key)
if err != nil {
return err
}
fv.SetFloat(val)
case reflect.Bool:
val, err := c.GetBool(key)
if err != nil {
return err
}
fv.SetBool(val)
case reflect.String:
val, err := c.GetString(key)
if err != nil {
return err
}
fv.SetString(val)
}
return nil
}
示例8: setWithProperType
// setWithProperType sets proper value to field based on its type,
// but it does not return error for failing parsing,
// because we want to use default value that is already assigned to strcut.
func setWithProperType(t reflect.Type, key *Key, field reflect.Value, delim string) error {
switch t.Kind() {
case reflect.String:
if len(key.String()) == 0 {
return nil
}
field.SetString(key.String())
case reflect.Bool:
boolVal, err := key.Bool()
if err != nil {
return nil
}
field.SetBool(boolVal)
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
durationVal, err := key.Duration()
// Skip zero value
if err == nil && int(durationVal) > 0 {
field.Set(reflect.ValueOf(durationVal))
return nil
}
intVal, err := key.Int64()
if err != nil || intVal == 0 {
return nil
}
field.SetInt(intVal)
// byte is an alias for uint8, so supporting uint8 breaks support for byte
case reflect.Uint, reflect.Uint16, reflect.Uint32, reflect.Uint64:
durationVal, err := key.Duration()
// Skip zero value
if err == nil && int(durationVal) > 0 {
field.Set(reflect.ValueOf(durationVal))
return nil
}
uintVal, err := key.Uint64()
if err != nil {
return nil
}
field.SetUint(uintVal)
case reflect.Float64:
floatVal, err := key.Float64()
if err != nil {
return nil
}
field.SetFloat(floatVal)
case reflectTime:
timeVal, err := key.Time()
if err != nil {
return nil
}
field.Set(reflect.ValueOf(timeVal))
case reflect.Slice:
return setSliceWithProperType(key, field, delim)
default:
return fmt.Errorf("unsupported type '%s'", t)
}
return nil
}
示例9: setConfigVal
func setConfigVal(str string, field reflect.Value) error {
t := field.Kind()
switch {
case t == reflect.String:
field.SetString(str)
case t >= reflect.Int && t <= reflect.Int64:
if x, err := strconv.ParseInt(str, 10, 64); err != nil {
return err
} else {
field.SetInt(x)
}
case t >= reflect.Uint && t <= reflect.Uint64:
if x, err := strconv.ParseUint(str, 10, 64); err != nil {
return err
} else {
field.SetUint(x)
}
case t >= reflect.Float32 && t <= reflect.Float64:
if x, err := strconv.ParseFloat(str, 64); err != nil {
return err
} else {
field.SetFloat(x)
}
case t == reflect.Bool:
if x, err := strconv.ParseBool(str); err != nil {
return err
} else {
field.SetBool(x)
}
default:
return nil
}
return nil
}
示例10: bool
// type(1) | name length(1) | raw name bytes | 0x00 | 0x00/0x01
func (d *decodeState) bool(v reflect.Value) {
d.off += 1 // type
klen := int(Int8(d.data[d.off:]))
d.off += 1 // name length
if klen > 0 {
key := d.data[d.off : d.off+klen-1]
d.off += klen
v = fieldByTag(v, key)
u, pv := d.indirect(v, false)
if u != nil {
d.off -= 1 + 1 + klen
if err := u.UnmarshalMCPACK(d.next()); err != nil {
d.error(err)
}
return
}
v = pv
}
val := d.data[d.off]
d.off += 1
if !v.IsValid() {
return
}
if val == 0 {
v.SetBool(false)
} else {
v.SetBool(true)
}
}
示例11: setWithProperType
// This sets the value in a struct of an indeterminate type to the
// matching value from the request (via Form middleware) in the
// same type, so that not all deserialized values have to be strings.
// Supported types are string, int, float, and bool.
func setWithProperType(valueKind reflect.Kind, val string, structField reflect.Value, nameInTag string, errors Errors) {
if scan, ok := structField.Addr().Interface().(sql.Scanner); ok {
scan.Scan(val)
return
}
switch valueKind {
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
if val == "" {
val = "0"
}
intVal, err := strconv.ParseInt(val, 10, 64)
if err != nil {
errors.Add([]string{nameInTag}, TypeError, "Value could not be parsed as integer")
} else {
structField.SetInt(intVal)
}
case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64:
if val == "" {
val = "0"
}
uintVal, err := strconv.ParseUint(val, 10, 64)
if err != nil {
errors.Add([]string{nameInTag}, TypeError, "Value could not be parsed as unsigned integer")
} else {
structField.SetUint(uintVal)
}
case reflect.Bool:
if val == "" {
val = "false"
}
boolVal, err := strconv.ParseBool(val)
if err != nil {
errors.Add([]string{nameInTag}, TypeError, "Value could not be parsed as boolean")
} else {
structField.SetBool(boolVal)
}
case reflect.Float32:
if val == "" {
val = "0.0"
}
floatVal, err := strconv.ParseFloat(val, 32)
if err != nil {
errors.Add([]string{nameInTag}, TypeError, "Value could not be parsed as 32-bit float")
} else {
structField.SetFloat(floatVal)
}
case reflect.Float64:
if val == "" {
val = "0.0"
}
floatVal, err := strconv.ParseFloat(val, 64)
if err != nil {
errors.Add([]string{nameInTag}, TypeError, "Value could not be parsed as 64-bit float")
} else {
structField.SetFloat(floatVal)
}
case reflect.String:
structField.SetString(val)
}
}
示例12: unifyBool
func unifyBool(data interface{}, rv reflect.Value) error {
if b, ok := data.(bool); ok {
rv.SetBool(b)
return nil
}
return badtype("integer", data)
}
示例13: setFieldVal
// setFieldVal first converts v to the type of structField, then uses reflection
// to set the field to the converted value.
func setFieldVal(structField reflect.Value, name string, v string) error {
switch structField.Kind() {
case reflect.String:
structField.SetString(v)
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
vInt, err := strconv.Atoi(v)
if err != nil {
return fmt.Errorf("envvar: Error parsing environment variable %s: %s\n%s", name, v, err.Error())
}
structField.SetInt(int64(vInt))
case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64:
vUint, err := strconv.ParseUint(v, 10, 64)
if err != nil {
return fmt.Errorf("envvar: Error parsing environment variable %s: %s\n%s", name, v, err.Error())
}
structField.SetUint(uint64(vUint))
case reflect.Float32, reflect.Float64:
vFloat, err := strconv.ParseFloat(v, 64)
if err != nil {
return fmt.Errorf("envvar: Error parsing environment variable %s: %s\n%s", name, v, err.Error())
}
structField.SetFloat(vFloat)
case reflect.Bool:
vBool, err := strconv.ParseBool(v)
if err != nil {
return fmt.Errorf("envvar: Error parsing environment variable %s: %s\n%s", name, v, err.Error())
}
structField.SetBool(vBool)
default:
return fmt.Errorf("envvar: Unsupported struct field type: %s", structField.Type().String())
}
return nil
}
示例14: convertAssignBulkString
func convertAssignBulkString(d reflect.Value, s []byte) (err error) {
switch d.Type().Kind() {
case reflect.Float32, reflect.Float64:
var x float64
x, err = strconv.ParseFloat(string(s), d.Type().Bits())
d.SetFloat(x)
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
var x int64
x, err = strconv.ParseInt(string(s), 10, d.Type().Bits())
d.SetInt(x)
case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64:
var x uint64
x, err = strconv.ParseUint(string(s), 10, d.Type().Bits())
d.SetUint(x)
case reflect.Bool:
var x bool
x, err = strconv.ParseBool(string(s))
d.SetBool(x)
case reflect.String:
d.SetString(string(s))
case reflect.Slice:
if d.Type().Elem().Kind() != reflect.Uint8 {
err = cannotConvert(d, s)
} else {
d.SetBytes(s)
}
default:
err = cannotConvert(d, s)
}
return
}
示例15: setWithProperType
// setWithProperType sets proper value to field based on its type,
// but it does not return error for failing parsing,
// because we want to use default value that is already assigned to strcut.
func setWithProperType(kind reflect.Kind, key *Key, field reflect.Value, delim string) error {
switch kind {
case reflect.String:
if len(key.String()) == 0 {
return nil
}
field.SetString(key.String())
case reflect.Bool:
boolVal, err := key.Bool()
if err != nil {
return nil
}
field.SetBool(boolVal)
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
intVal, err := key.Int64()
if err != nil {
return nil
}
field.SetInt(intVal)
case reflect.Float64:
floatVal, err := key.Float64()
if err != nil {
return nil
}
field.SetFloat(floatVal)
case reflectTime:
timeVal, err := key.Time()
if err != nil {
return nil
}
field.Set(reflect.ValueOf(timeVal))
case reflect.Slice:
vals := key.Strings(delim)
numVals := len(vals)
if numVals == 0 {
return nil
}
sliceOf := field.Type().Elem().Kind()
var times []time.Time
if sliceOf == reflectTime {
times = key.Times(delim)
}
slice := reflect.MakeSlice(field.Type(), numVals, numVals)
for i := 0; i < numVals; i++ {
switch sliceOf {
case reflectTime:
slice.Index(i).Set(reflect.ValueOf(times[i]))
default:
slice.Index(i).Set(reflect.ValueOf(vals[i]))
}
}
field.Set(slice)
default:
return fmt.Errorf("unsupported type '%s'", kind)
}
return nil
}