From fd653373a687cb860efcbaf2fd0743fee18872db Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=96mer=20Faruk=20IRMAK?= Date: Fri, 18 Nov 2022 11:19:53 +0300 Subject: [PATCH] Fix Shrink not clearing unused bits when new length requires multiple words --- bitset.go | 5 +++-- bitset_test.go | 9 +++++++++ 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/bitset.go b/bitset.go index 7f01221..fbf0496 100644 --- a/bitset.go +++ b/bitset.go @@ -272,8 +272,9 @@ func (b *BitSet) Shrink(lastbitindex uint) *BitSet { copy(shrunk, b.set[:idx]) b.set = shrunk b.length = length - if length < 64 { - b.set[idx-1] &= allBits >> uint64(64-wordsIndex(length)) + lastWordUsedBits := length % 64 + if lastWordUsedBits != 0 { + b.set[idx-1] &= allBits >> uint64(64-wordsIndex(lastWordUsedBits)) } return b } diff --git a/bitset_test.go b/bitset_test.go index 4720f2a..efa202f 100644 --- a/bitset_test.go +++ b/bitset_test.go @@ -707,6 +707,15 @@ func TestShrink(t *testing.T) { t.Error("24 should be set") return } + + b = New(110) + b.Set(80) + b.Shrink(70) + for _, word := range b.set { + if (word != 0) { + t.Error("word should be 0", word) + } + } } func TestInsertAtWithSet(t *testing.T) {