32 lines
671 B
Go
32 lines
671 B
Go
|
package objects
|
||
|
|
||
|
// CountObjects returns the number of objects that a given object o contains.
|
||
|
// For scalar value types, it will always be 1. For compound value types,
|
||
|
// this will include its elements and all of their elements recursively.
|
||
|
func CountObjects(o Object) (c int) {
|
||
|
c = 1
|
||
|
|
||
|
switch o := o.(type) {
|
||
|
case *Array:
|
||
|
for _, v := range o.Value {
|
||
|
c += CountObjects(v)
|
||
|
}
|
||
|
case *ImmutableArray:
|
||
|
for _, v := range o.Value {
|
||
|
c += CountObjects(v)
|
||
|
}
|
||
|
case *Map:
|
||
|
for _, v := range o.Value {
|
||
|
c += CountObjects(v)
|
||
|
}
|
||
|
case *ImmutableMap:
|
||
|
for _, v := range o.Value {
|
||
|
c += CountObjects(v)
|
||
|
}
|
||
|
case *Error:
|
||
|
c += CountObjects(o.Value)
|
||
|
}
|
||
|
|
||
|
return
|
||
|
}
|