mirror of
https://github.com/protocolbuffers/protobuf-go.git
synced 2025-01-01 03:14:16 +00:00
internal/impl: fix panic calling XXX_MessageName on aberrant messages
Call XXX_MessageName with best-effort. If it panics, oh-well. Change-Id: I605ea074470b0c90b0bea8b36fa7d4a69368692d Reviewed-on: https://go-review.googlesource.com/c/protobuf/+/194598 Reviewed-by: Damien Neil <dneil@google.com>
This commit is contained in:
parent
3e80249d38
commit
e87cf53d57
@ -202,10 +202,14 @@ func aberrantDeriveMessageName(t reflect.Type, name pref.FullName) pref.FullName
|
|||||||
if name.IsValid() {
|
if name.IsValid() {
|
||||||
return name
|
return name
|
||||||
}
|
}
|
||||||
if m, ok := reflect.New(t).Interface().(interface{ XXX_MessageName() string }); ok {
|
func() {
|
||||||
if name := pref.FullName(m.XXX_MessageName()); name.IsValid() {
|
defer func() { recover() }() // swallow possible nil panics
|
||||||
return name
|
if m, ok := reflect.New(t).Interface().(interface{ XXX_MessageName() string }); ok {
|
||||||
|
name = pref.FullName(m.XXX_MessageName())
|
||||||
}
|
}
|
||||||
|
}()
|
||||||
|
if name.IsValid() {
|
||||||
|
return name
|
||||||
}
|
}
|
||||||
return aberrantDeriveFullName(t)
|
return aberrantDeriveFullName(t)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user