Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

added filterWithKey to IsMap #231

Closed
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions mono-traversable/ChangeLog.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,10 @@
# ChangeLog for mono-traversable

## 1.0.19.0

* Added `filterWithKey` to class `IsMap`
[#231](https://github.com/snoyberg/mono-traversable/pull/231)

## 1.0.18.0

* Added MonoPointed instance for text Builder
Expand Down
2 changes: 1 addition & 1 deletion mono-traversable/package.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
name: mono-traversable
version: 1.0.18.0
version: 1.0.19.0
synopsis: Type classes for mapping, folding, and traversing monomorphic containers
description: Please see the README at <https://www.stackage.org/package/mono-traversable>
category: Data
Expand Down
16 changes: 14 additions & 2 deletions mono-traversable/src/Data/Containers.hs
Original file line number Diff line number Diff line change
Expand Up @@ -548,8 +548,14 @@ class (MonoTraversable map, SetContainer map) => IsMap map where
-- | Filter values in a map.
--
-- @since 1.0.9.0
filterMap :: IsMap map => (MapValue map -> Bool) -> map -> map
filterMap p = mapFromList . filter (p . snd) . mapToList
filterMap :: (MapValue map -> Bool) -> map -> map
filterMap = filterWithKey . const

-- | Filter a map with keys and values.
--
-- @since 1.0.19.0
filterWithKey :: (ContainerKey map -> MapValue map -> Bool) -> map -> map
filterWithKey p = mapFromList . filter (uncurry p) . mapToList

-- | This instance uses the functions from "Data.Map.Strict".
instance Ord key => IsMap (Map.Map key value) where
Expand Down Expand Up @@ -599,6 +605,8 @@ instance Ord key => IsMap (Map.Map key value) where
{-# INLINE omapKeysWith #-}
filterMap = Map.filter
{-# INLINE filterMap #-}
filterWithKey = Map.filterWithKey
{-# INLINE filterWithKey #-}

-- | This instance uses the functions from "Data.HashMap.Strict".
instance (Eq key, Hashable key) => IsMap (HashMap.HashMap key value) where
Expand Down Expand Up @@ -636,6 +644,8 @@ instance (Eq key, Hashable key) => IsMap (HashMap.HashMap key value) where
--mapKeysWith = HashMap.mapKeysWith
filterMap = HashMap.filter
{-# INLINE filterMap #-}
filterWithKey = HashMap.filterWithKey
{-# INLINE filterWithKey #-}

-- | This instance uses the functions from "Data.IntMap.Strict".
instance IsMap (IntMap.IntMap value) where
Expand Down Expand Up @@ -684,6 +694,8 @@ instance IsMap (IntMap.IntMap value) where
{-# INLINE omapKeysWith #-}
filterMap = IntMap.filter
{-# INLINE filterMap #-}
filterWithKey = IntMap.filterWithKey
{-# INLINE filterWithKey #-}

instance Eq key => IsMap [(key, value)] where
type MapValue [(key, value)] = value
Expand Down
Loading