summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/lib/json/generic.go3
-rw-r--r--src/lib/json/generic_test.go4
2 files changed, 6 insertions, 1 deletions
diff --git a/src/lib/json/generic.go b/src/lib/json/generic.go
index 4393e4d08..e3194eb17 100644
--- a/src/lib/json/generic.go
+++ b/src/lib/json/generic.go
@@ -33,7 +33,7 @@ type Json interface {
Bool() bool; // boolean (BoolKind)
Get(s string) Json; // field lookup (MapKind)
Elem(i int) Json; // element lookup (ArrayKind)
- Len() int; // length (ArrayKind)
+ Len() int; // length (ArrayKind, MapKind)
}
// JsonToString returns the textual JSON syntax representation
@@ -112,6 +112,7 @@ func (j *_Bool) String() string {
type _Map struct { m map[string]Json; _Null }
func (j *_Map) Kind() int { return MapKind }
+func (j *_Map) Len() int { return len(j.m) }
func (j *_Map) Get(s string) Json {
if j.m == nil {
return Null
diff --git a/src/lib/json/generic_test.go b/src/lib/json/generic_test.go
index ab3e24fb8..68868d7a5 100644
--- a/src/lib/json/generic_test.go
+++ b/src/lib/json/generic_test.go
@@ -64,6 +64,10 @@ func TestJsonMap(t *testing.T) {
if mapv == nil {
t.Fatalf("StringToJson(%#q) => nil, %v, %v", mapstr, ok, errtok);
}
+ if cnt := mapv.Len(); cnt != len(jsontests) {
+ t.Errorf("StringToJson(%#q).Len() => %v, want %v", mapstr, cnt,
+ len(jsontests));
+ }
for k,v := range values {
if v1 := mapv.Get(k); !Equal(v1, v) {
t.Errorf("MapTest: Walk(%#q) => %v, want %v", k, v1, v);