From ec93ee58d7a6860b8f1be7818cf3c25f5c1c3ca5 Mon Sep 17 00:00:00 2001 From: yj-qin Date: Mon, 25 Mar 2024 10:11:00 +0800 Subject: [PATCH] Handle zero capacity grow --- hashmap/hashmap.mbt | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/hashmap/hashmap.mbt b/hashmap/hashmap.mbt index 0ece5a4a3..54dc02938 100644 --- a/hashmap/hashmap.mbt +++ b/hashmap/hashmap.mbt @@ -226,6 +226,14 @@ fn shift_back[K : Hash, V](self : HashMap[K, V], start_index : Int) -> Unit { } fn grow[K : Hash + Eq, V](self : HashMap[K, V]) -> Unit { + // handle zero capacity + if self.capacity == 0 { + self.capacity = default_init_capacity + self.growAt = calc_grow_threshold(self.capacity) + self.size = 0 + self.entries = @array.new(self.capacity, fn() { Empty }) + return + } let old_entries = self.entries self.entries = @array.new(self.capacity * 2, fn() { Empty }) self.capacity = self.capacity * 2 @@ -455,3 +463,11 @@ test "grow" { "_,(0,C,1),(0,Go,2),(0,C++,3),(0,Java,4),(0,Scala,5),(1,Julia,5),(2,Cobol,5),(2,Python,6),(2,Haskell,7),(2,Rescript,8),_,_,_,_,_", )? } + +test "zero_capacity_grow" { + let m : HashMap[String, Int] = HashMap::new(~capacity=0) + @assertion.assert_eq(m.capacity(), 0)? + m.set("a", 1) + @assertion.assert_eq(m.size(), 1)? + @assertion.assert_eq(m.capacity(), 8)? +}