2010-12-03 05:34:57 +01:00
|
|
|
// Copyright 2009 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
// Formatting of reflection types and values for debugging.
|
|
|
|
// Not defined as methods so they do not need to be linked into most binaries;
|
|
|
|
// the functions are not used by the library itself, only in tests.
|
|
|
|
|
|
|
|
package reflect_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
. "reflect"
|
|
|
|
"strconv"
|
|
|
|
)
|
|
|
|
|
|
|
|
// valueToString returns a textual representation of the reflection value val.
|
|
|
|
// For debugging only.
|
|
|
|
func valueToString(val Value) string {
|
|
|
|
var str string
|
2011-05-20 02:18:15 +02:00
|
|
|
if !val.IsValid() {
|
|
|
|
return "<zero Value>"
|
2010-12-03 05:34:57 +01:00
|
|
|
}
|
|
|
|
typ := val.Type()
|
2011-05-20 02:18:15 +02:00
|
|
|
switch val.Kind() {
|
|
|
|
case Int, Int8, Int16, Int32, Int64:
|
2011-12-14 16:41:54 +01:00
|
|
|
return strconv.FormatInt(val.Int(), 10)
|
2011-05-20 02:18:15 +02:00
|
|
|
case Uint, Uint8, Uint16, Uint32, Uint64, Uintptr:
|
2011-12-14 16:41:54 +01:00
|
|
|
return strconv.FormatUint(val.Uint(), 10)
|
2011-05-20 02:18:15 +02:00
|
|
|
case Float32, Float64:
|
2011-12-14 16:41:54 +01:00
|
|
|
return strconv.FormatFloat(val.Float(), 'g', -1, 64)
|
2011-05-20 02:18:15 +02:00
|
|
|
case Complex64, Complex128:
|
|
|
|
c := val.Complex()
|
2011-12-14 16:41:54 +01:00
|
|
|
return strconv.FormatFloat(real(c), 'g', -1, 64) + "+" + strconv.FormatFloat(imag(c), 'g', -1, 64) + "i"
|
2011-05-20 02:18:15 +02:00
|
|
|
case String:
|
|
|
|
return val.String()
|
|
|
|
case Bool:
|
|
|
|
if val.Bool() {
|
2010-12-03 05:34:57 +01:00
|
|
|
return "true"
|
|
|
|
} else {
|
|
|
|
return "false"
|
|
|
|
}
|
2011-05-20 02:18:15 +02:00
|
|
|
case Ptr:
|
2010-12-03 05:34:57 +01:00
|
|
|
v := val
|
|
|
|
str = typ.String() + "("
|
|
|
|
if v.IsNil() {
|
|
|
|
str += "0"
|
|
|
|
} else {
|
|
|
|
str += "&" + valueToString(v.Elem())
|
|
|
|
}
|
|
|
|
str += ")"
|
|
|
|
return str
|
2011-05-20 02:18:15 +02:00
|
|
|
case Array, Slice:
|
2010-12-03 05:34:57 +01:00
|
|
|
v := val
|
|
|
|
str += typ.String()
|
|
|
|
str += "{"
|
|
|
|
for i := 0; i < v.Len(); i++ {
|
|
|
|
if i > 0 {
|
|
|
|
str += ", "
|
|
|
|
}
|
2011-05-20 02:18:15 +02:00
|
|
|
str += valueToString(v.Index(i))
|
2010-12-03 05:34:57 +01:00
|
|
|
}
|
|
|
|
str += "}"
|
|
|
|
return str
|
2011-05-20 02:18:15 +02:00
|
|
|
case Map:
|
|
|
|
t := typ
|
2010-12-03 05:34:57 +01:00
|
|
|
str = t.String()
|
|
|
|
str += "{"
|
|
|
|
str += "<can't iterate on maps>"
|
|
|
|
str += "}"
|
|
|
|
return str
|
2011-05-20 02:18:15 +02:00
|
|
|
case Chan:
|
2010-12-03 05:34:57 +01:00
|
|
|
str = typ.String()
|
|
|
|
return str
|
2011-05-20 02:18:15 +02:00
|
|
|
case Struct:
|
|
|
|
t := typ
|
2010-12-03 05:34:57 +01:00
|
|
|
v := val
|
|
|
|
str += t.String()
|
|
|
|
str += "{"
|
|
|
|
for i, n := 0, v.NumField(); i < n; i++ {
|
|
|
|
if i > 0 {
|
|
|
|
str += ", "
|
|
|
|
}
|
|
|
|
str += valueToString(v.Field(i))
|
|
|
|
}
|
|
|
|
str += "}"
|
|
|
|
return str
|
2011-05-20 02:18:15 +02:00
|
|
|
case Interface:
|
2010-12-03 05:34:57 +01:00
|
|
|
return typ.String() + "(" + valueToString(val.Elem()) + ")"
|
2011-05-20 02:18:15 +02:00
|
|
|
case Func:
|
2010-12-03 05:34:57 +01:00
|
|
|
v := val
|
2011-12-14 16:41:54 +01:00
|
|
|
return typ.String() + "(" + strconv.FormatUint(uint64(v.Pointer()), 10) + ")"
|
2010-12-03 05:34:57 +01:00
|
|
|
default:
|
|
|
|
panic("valueToString: can't print type " + typ.String())
|
|
|
|
}
|
|
|
|
}
|