From c0064a04cd348d5e57676225b6d34a27c56c6700 Mon Sep 17 00:00:00 2001 From: Aaron Son Date: Mon, 28 Aug 2023 10:45:57 -0700 Subject: [PATCH] map.go: Fix Clear() to actually clear the values and keys. Because groups are using value semantics, the implementation of Clear() was accidentally clearing a copy of the group instead of the group itself. Fixes #20. --- map.go | 3 ++- map_test.go | 9 +++++++++ 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/map.go b/map.go index d9f8dd3..e5ad203 100644 --- a/map.go +++ b/map.go @@ -243,7 +243,8 @@ func (m *Map[K, V]) Clear() { } var k K var v V - for _, g := range m.groups { + for i := range m.groups { + g := &m.groups[i] for i := range g.keys { g.keys[i] = k g.values[i] = v diff --git a/map_test.go b/map_test.go index 222e3ed..503f4fe 100644 --- a/map_test.go +++ b/map_test.go @@ -216,6 +216,15 @@ func testMapClear[K comparable](t *testing.T, keys []K) { return }) assert.Equal(t, 0, calls) + + // Assert that the map was actually cleared... + var k K + for _, g := range m.groups { + for i := range g.keys { + assert.Equal(t, k, g.keys[i]) + assert.Equal(t, 0, g.values[i]) + } + } } func testMapIter[K comparable](t *testing.T, keys []K) {