Skip to content

Commit

Permalink
internal/astinternal: use reflect.Value.IsNil consistently
Browse files Browse the repository at this point in the history
The code was using a mix of IsValid and IsNil checks on reflect.Value;
use IsNil consistently. This is a few more lines of code, but it's
also more obvious. While here, make the comments a bit clearer.

Signed-off-by: Daniel Martí <mvdan@mvdan.cc>
Change-Id: I8fcd0f2cb43e9861807a4eccd78de4e66f6a419b
Dispatch-Trailer: {"type":"trybot","CL":1200889,"patchset":2,"ref":"refs/changes/89/1200889/2","targetBranch":"master"}
  • Loading branch information
mvdan authored and cueckoo committed Sep 9, 2024
1 parent f4f38bf commit 34ae84c
Showing 1 changed file with 19 additions and 16 deletions.
35 changes: 19 additions & 16 deletions internal/astinternal/debug.go
Original file line number Diff line number Diff line change
Expand Up @@ -71,24 +71,26 @@ func (d *debugPrinter) value0(v reflect.Value, impliedType reflect.Type) {
if d.cfg.Filter != nil && !d.cfg.Filter(v) {
return
}
// Skip over interface types.
if v.Kind() == reflect.Interface {
// Skip over interfaces and pointers, stopping early if nil.
concreteType := v.Type()
for {
k := v.Kind()
if k != reflect.Interface && k != reflect.Pointer {
break
}
if v.IsNil() {
if !d.cfg.OmitEmpty {
d.printf("nil")
}
return
}
v = v.Elem()
}
// Indirecting a nil interface gives a zero value. We
// can also have a nil pointer inside a non-nil interface.
if !v.IsValid() || (v.Kind() == reflect.Pointer && v.IsNil()) {
if !d.cfg.OmitEmpty {
d.printf("nil")
if k == reflect.Interface {
// For example, *ast.Ident can be the concrete type behind an ast.Expr.
concreteType = v.Type()
}
return
}

// We print the original pointer type if there was one.
origType := v.Type()

v = reflect.Indirect(v)

if d.cfg.OmitEmpty && v.IsZero() {
return
}
Expand Down Expand Up @@ -121,8 +123,9 @@ func (d *debugPrinter) value0(v reflect.Value, impliedType reflect.Type) {

case reflect.Slice, reflect.Struct:
valueStart := d.pos()
if origType != impliedType {
d.printf("%s", origType)
// We print the concrete type when it differs from an implied type.
if concreteType != impliedType {
d.printf("%s", concreteType)
}
d.printf("{")
d.level++
Expand Down

0 comments on commit 34ae84c

Please sign in to comment.