Skip to content
This repository was archived by the owner on Oct 4, 2020. It is now read-only.

Commit d8d28ac

Browse files
committed
wip
1 parent e424494 commit d8d28ac

File tree

1 file changed

+7
-1
lines changed

1 file changed

+7
-1
lines changed

src/Data/Map.purs

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -99,7 +99,13 @@ instance functorWithIndexMap :: FunctorWithIndex k (Map k) where
9999
mapWithIndex f (Three left k1 v1 mid k2 v2 right) = Three (mapWithIndex f left) k1 (f k1 v1) (mapWithIndex f mid) k2 (f k2 v2) (mapWithIndex f right)
100100

101101
instance foldableMap :: Foldable (Map k) where
102-
foldl f z m = foldl f z (values m)
102+
foldl f z m = go acc (m : Nil)
103+
go acc Nil = acc
104+
go acc (hd : tl) = case hd of
105+
Leaf -> go acc tl
106+
Two left _ v right ->
107+
go (f acc k) (left : right : tl)
108+
103109
foldr f z m = foldr f z (values m)
104110
foldMap f m = foldMap f (values m)
105111

0 commit comments

Comments
 (0)