1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-01-11 17:18:28 +02:00

Stop recursive loop where its a recursive type

This commit is contained in:
Asim 2015-12-25 01:06:51 +00:00
parent 4f15d823c9
commit 3dd911fb33

View File

@ -20,7 +20,10 @@ func init() {
} }
} }
func extractValue(v reflect.Type) *registry.Value { func extractValue(v reflect.Type, d int) *registry.Value {
if d == 3 {
return nil
}
if v == nil { if v == nil {
return nil return nil
} }
@ -37,7 +40,10 @@ func extractValue(v reflect.Type) *registry.Value {
switch v.Kind() { switch v.Kind() {
case reflect.Struct: case reflect.Struct:
for i := 0; i < v.NumField(); i++ { for i := 0; i < v.NumField(); i++ {
val := extractValue(v.Field(i).Type) val := extractValue(v.Field(i).Type, d+1)
if val == nil {
continue
}
val.Name = v.Field(i).Name val.Name = v.Field(i).Name
arg.Values = append(arg.Values, val) arg.Values = append(arg.Values, val)
} }
@ -47,7 +53,10 @@ func extractValue(v reflect.Type) *registry.Value {
p = p.Elem() p = p.Elem()
} }
arg.Type = "[]" + p.Name() arg.Type = "[]" + p.Name()
arg.Values = append(arg.Values, extractValue(v.Elem())) val := extractValue(v.Elem(), d+1)
if val != nil {
arg.Values = append(arg.Values, val)
}
} }
return arg return arg
@ -77,8 +86,8 @@ func extractEndpoint(method reflect.Method) *registry.Endpoint {
stream = true stream = true
} }
request := extractValue(reqType) request := extractValue(reqType, 0)
response := extractValue(rspType) response := extractValue(rspType, 0)
return &registry.Endpoint{ return &registry.Endpoint{
Name: method.Name, Name: method.Name,
@ -102,7 +111,7 @@ func extractSubValue(typ reflect.Type) *registry.Value {
default: default:
return nil return nil
} }
return extractValue(reqType) return extractValue(reqType, 0)
} }
func extractAddress(addr string) (string, error) { func extractAddress(addr string) (string, error) {