mirror of
https://github.com/weaveworks/scope.git
synced 2026-05-01 14:58:46 +00:00
This will
Add:
- golang.org/x/time
upgrade:
- k8s.io/client-go v8.0.0
- k8s.io/api version to kubernetes-1.11.0
- k8s.io/apimachinery version to kubernetes-1.11.0
- github.com/json-iterator/go version to latest because `https://github.com/kubernetes/kubernetes/issues/64612`
delete:
- vendor/github.com/juju/ratelimit because k8s-client-go is shifted to golang.org/x/time
Please refer: acc52496ce
```
gvt delete k8s.io/client-go
gvt delete k8s.io/api
gvt delete k8s.io/apimachinery
gvt delete github.com/json-iterator/go
gvt delete github.com/juju/ratelimit
gvt fetch --no-recurse -tag v8.0.0 k8s.io/client-go
gvt fetch --no-recurse -tag kubernetes-1.11.0 k8s.io/api
gvt fetch --no-recurse -tag kubernetes-1.11.0 k8s.io/apimachinery
gvt fetch github.com/json-iterator/go
gvt fetch golang.org/x/time
```
fixes: #3284
Signed-off-by: Satyam Zode <satyamzode@gmail.com>
55 lines
1.4 KiB
Go
55 lines
1.4 KiB
Go
package extra
|
|
|
|
import (
|
|
"github.com/json-iterator/go"
|
|
"strings"
|
|
"unicode"
|
|
)
|
|
|
|
// SupportPrivateFields include private fields when encoding/decoding
|
|
func SupportPrivateFields() {
|
|
jsoniter.RegisterExtension(&privateFieldsExtension{})
|
|
}
|
|
|
|
type privateFieldsExtension struct {
|
|
jsoniter.DummyExtension
|
|
}
|
|
|
|
func (extension *privateFieldsExtension) UpdateStructDescriptor(structDescriptor *jsoniter.StructDescriptor) {
|
|
for _, binding := range structDescriptor.Fields {
|
|
isPrivate := unicode.IsLower(rune(binding.Field.Name()[0]))
|
|
if isPrivate {
|
|
tag, hastag := binding.Field.Tag().Lookup("json")
|
|
if !hastag {
|
|
binding.FromNames = []string{binding.Field.Name()}
|
|
binding.ToNames = []string{binding.Field.Name()}
|
|
continue
|
|
}
|
|
tagParts := strings.Split(tag, ",")
|
|
names := calcFieldNames(binding.Field.Name(), tagParts[0], tag)
|
|
binding.FromNames = names
|
|
binding.ToNames = names
|
|
}
|
|
}
|
|
}
|
|
|
|
func calcFieldNames(originalFieldName string, tagProvidedFieldName string, wholeTag string) []string {
|
|
// ignore?
|
|
if wholeTag == "-" {
|
|
return []string{}
|
|
}
|
|
// rename?
|
|
var fieldNames []string
|
|
if tagProvidedFieldName == "" {
|
|
fieldNames = []string{originalFieldName}
|
|
} else {
|
|
fieldNames = []string{tagProvidedFieldName}
|
|
}
|
|
// private?
|
|
isNotExported := unicode.IsLower(rune(originalFieldName[0]))
|
|
if isNotExported {
|
|
fieldNames = []string{}
|
|
}
|
|
return fieldNames
|
|
}
|