mirror of
https://github.com/github/semantic.git
synced 2024-12-22 22:31:36 +03:00
Define intersectionWith
.
This commit is contained in:
parent
253f21d885
commit
1e7dc0ff98
@ -9,6 +9,7 @@ module OrderedMap (
|
|||||||
, empty
|
, empty
|
||||||
, union
|
, union
|
||||||
, unions
|
, unions
|
||||||
|
, intersectionWith
|
||||||
) where
|
) where
|
||||||
|
|
||||||
data OrderedMap key value = OrderedMap { toList :: [(key, value)] }
|
data OrderedMap key value = OrderedMap { toList :: [(key, value)] }
|
||||||
@ -42,3 +43,6 @@ union (OrderedMap a) (OrderedMap b) = OrderedMap $ a ++ filter (not . (`elem` ex
|
|||||||
|
|
||||||
unions :: Eq key => [OrderedMap key value] -> OrderedMap key value
|
unions :: Eq key => [OrderedMap key value] -> OrderedMap key value
|
||||||
unions = foldl union empty
|
unions = foldl union empty
|
||||||
|
|
||||||
|
intersectionWith :: Eq key => (a -> b -> c) -> OrderedMap key a -> OrderedMap key b -> OrderedMap key c
|
||||||
|
intersectionWith combine (OrderedMap a) (OrderedMap b) = OrderedMap $ a >>= (\ (key, value) -> maybe [] (pure . ((,) key) . combine value) $ Prelude.lookup key b)
|
||||||
|
Loading…
Reference in New Issue
Block a user