From 8c3f6577bc28f9757d8ef607a0a53ac20be753fb Mon Sep 17 00:00:00 2001
From: Philipp Hagenlocher
Date: Thu, 24 Oct 2024 22:28:49 +0200
Subject: [PATCH] dhall: Use Data.Map.Strict instead of Data.Map (#2611)
---
dhall/src/Dhall/Map.hs | 114 ++++++++++++++++++++---------------------
1 file changed, 57 insertions(+), 57 deletions(-)
diff --git a/dhall/src/Dhall/Map.hs b/dhall/src/Dhall/Map.hs
index 9d1afa961..d696fad33 100644
--- a/dhall/src/Dhall/Map.hs
+++ b/dhall/src/Dhall/Map.hs
@@ -77,7 +77,7 @@ import Language.Haskell.TH.Syntax (Lift)
import Prelude hiding (filter, lookup)
import qualified Data.List
-import qualified Data.Map
+import qualified Data.Map.Strict
import qualified Data.Set
import qualified GHC.Exts
import qualified Prelude
@@ -89,7 +89,7 @@ import qualified Prelude
This is done primarily to avoid a dependency on @insert-ordered-containers@
and also to improve performance
-}
-data Map k v = Map (Data.Map.Map k v) (Keys k)
+data Map k v = Map (Data.Map.Strict.Map k v) (Keys k)
deriving (Data, Generic, Lift, NFData)
data Keys a
@@ -99,7 +99,7 @@ data Keys a
instance (Ord k, Eq v) => Eq (Map k v) where
m1 == m2 =
- Data.Map.size (toMap m1) == Data.Map.size (toMap m2)
+ Data.Map.Strict.size (toMap m1) == Data.Map.Strict.size (toMap m2)
&& toList m1 == toList m2
{-# INLINABLE (==) #-}
@@ -142,7 +142,7 @@ prop> \x -> x <> mempty == (x :: Map Int Int)
prop> \x -> mempty <> x == (x :: Map Int Int)
-}
instance Ord k => Monoid (Map k v) where
- mempty = Map Data.Map.empty (Original [])
+ mempty = Map Data.Map.Strict.empty (Original [])
{-# INLINABLE mempty #-}
instance (Show k, Show v, Ord k) => Show (Map k v) where
@@ -170,7 +170,7 @@ fromList [("A",1)]
singleton :: k -> v -> Map k v
singleton k v = Map m ks
where
- m = Data.Map.singleton k v
+ m = Data.Map.Strict.singleton k v
ks = Original [k]
{-# INLINABLE singleton #-}
@@ -194,7 +194,7 @@ fromList [(1,False)]
fromList :: Ord k => [(k, v)] -> Map k v
fromList kvs = Map m ks
where
- m = Data.Map.fromList kvs
+ m = Data.Map.Strict.fromList kvs
ks = Original (nubOrd (map fst kvs))
{-# INLINABLE fromList #-}
@@ -207,13 +207,13 @@ fromList [("B","Bv3v1"),("A","v2")]
fromListWithKey :: Ord k => (k -> v -> v -> v) -> [(k, v)] -> Map k v
fromListWithKey f kvs = Map m ks
where
- m = Data.Map.fromListWithKey f kvs
+ m = Data.Map.Strict.fromListWithKey f kvs
ks = Original (nubOrd (map fst kvs))
{-# INLINABLE fromListWithKey #-}
--- | Create a `Map` from a @"Data.Map".`Data.Map.Map`@
-fromMap :: Data.Map.Map k v -> Map k v
+-- | Create a `Map` from a @"Data.Map.Strict".`Data.Map.Strict.Map`@
+fromMap :: Data.Map.Strict.Map k v -> Map k v
fromMap m = Map m Sorted
{-| Remove duplicates from a list
@@ -242,7 +242,7 @@ fromList [("A",1)]
unorderedSingleton :: k -> v -> Map k v
unorderedSingleton k v = Map m Sorted
where
- m = Data.Map.singleton k v
+ m = Data.Map.Strict.singleton k v
{-# INLINABLE unorderedSingleton #-}
{-| Create a `Map` from a list of key-value pairs
@@ -259,7 +259,7 @@ fromList [("A",2)]
unorderedFromList :: Ord k => [(k, v)] -> Map k v
unorderedFromList kvs = Map m Sorted
where
- m = Data.Map.fromList kvs
+ m = Data.Map.Strict.fromList kvs
{-# INLINABLE unorderedFromList #-}
{-| Sort the keys of a `Map`, forgetting the original ordering
@@ -284,7 +284,7 @@ True
-}
isSorted :: Eq k => Map k v -> Bool
isSorted (Map _ Sorted) = True
-isSorted (Map m (Original ks)) = Data.Map.keys m == ks -- Or shortcut to False here?
+isSorted (Map m (Original ks)) = Data.Map.Strict.keys m == ks -- Or shortcut to False here?
{-# INLINABLE isSorted #-}
{-| Insert a key-value pair into a `Map`, overriding any previous value stored
@@ -298,10 +298,10 @@ fromList [("C",1),("B",2),("A",3)]
fromList [("C",1),("A",3)]
-}
insert :: Ord k => k -> v -> Map k v -> Map k v
-insert k v (Map m Sorted) = Map (Data.Map.insert k v m) Sorted
+insert k v (Map m Sorted) = Map (Data.Map.Strict.insert k v m) Sorted
insert k v (Map m (Original ks)) = Map m' (Original ks')
where
- (mayOldV, m') = Data.Map.insertLookupWithKey (\_k new _old -> new) k v m
+ (mayOldV, m') = Data.Map.Strict.insertLookupWithKey (\_k new _old -> new) k v m
ks' | Just _ <- mayOldV = ks
| otherwise = k : ks
@@ -316,10 +316,10 @@ fromList [("C",1),("B",2),("A",3)]
fromList [("C",3),("A",3)]
-}
insertWith :: Ord k => (v -> v -> v) -> k -> v -> Map k v -> Map k v
-insertWith f k v (Map m Sorted) = Map (Data.Map.insertWith f k v m) Sorted
+insertWith f k v (Map m Sorted) = Map (Data.Map.Strict.insertWith f k v m) Sorted
insertWith f k v (Map m (Original ks)) = Map m' (Original ks')
where
- (mayOldV, m') = Data.Map.insertLookupWithKey (\_k new old -> f new old) k v m
+ (mayOldV, m') = Data.Map.Strict.insertLookupWithKey (\_k new old -> f new old) k v m
ks' | Just _ <- mayOldV = ks
| otherwise = k : ks
@@ -335,7 +335,7 @@ fromList [("C",1),("B",2),("A",3)]
delete :: Ord k => k -> Map k v -> Map k v
delete k (Map m ks) = Map m' ks'
where
- m' = Data.Map.delete k m
+ m' = Data.Map.Strict.delete k m
ks' = case ks of
Sorted -> Sorted
@@ -352,9 +352,9 @@ fromList [("C",3),("A",1)]
filter :: Ord k => (a -> Bool) -> Map k a -> Map k a
filter predicate (Map m ks) = Map m' ks'
where
- m' = Data.Map.filter predicate m
+ m' = Data.Map.Strict.filter predicate m
- ks' = filterKeys (\k -> Data.Map.member k m') ks
+ ks' = filterKeys (\k -> Data.Map.Strict.member k m') ks
{-# INLINABLE filter #-}
{-| Split the map into values that do and don't satisfy the predicate
@@ -367,9 +367,9 @@ filter predicate (Map m ks) = Map m' ks'
partition :: Ord k => (a -> Bool) -> Map k a -> (Map k a, Map k a)
partition predicate (Map m ks) = (Map mpass kpass, Map mfail kfail)
where
- (mpass, mfail) = Data.Map.partition predicate m
+ (mpass, mfail) = Data.Map.Strict.partition predicate m
- (kpass, kfail) = partitionKeys (\k -> Data.Map.member k mpass) ks
+ (kpass, kfail) = partitionKeys (\k -> Data.Map.Strict.member k mpass) ks
{-# INLINABLE partition #-}
{-| Restrict a 'Map' to only those keys found in a @"Data.Set".'Data.Set.Set'@.
@@ -380,7 +380,7 @@ fromList [("A",1)]
restrictKeys :: Ord k => Map k a -> Data.Set.Set k -> Map k a
restrictKeys (Map m ks) s = Map m' ks'
where
- m' = Data.Map.restrictKeys m s
+ m' = Data.Map.Strict.restrictKeys m s
ks' = filterKeys (\k -> Data.Set.member k s) ks
{-# INLINABLE restrictKeys #-}
@@ -393,7 +393,7 @@ fromList [("B",2)]
withoutKeys :: Ord k => Map k a -> Data.Set.Set k -> Map k a
withoutKeys (Map m ks) s = Map m' ks'
where
- m' = Data.Map.withoutKeys m s
+ m' = Data.Map.Strict.withoutKeys m s
ks' = filterKeys (\k -> Data.Set.notMember k s) ks
{-# INLINABLE withoutKeys #-}
@@ -407,9 +407,9 @@ fromList [("C",1),("A",3)]
mapMaybe :: Ord k => (a -> Maybe b) -> Map k a -> Map k b
mapMaybe f (Map m ks) = Map m' ks'
where
- m' = Data.Map.mapMaybe f m
+ m' = Data.Map.Strict.mapMaybe f m
- ks' = filterKeys (\k -> Data.Map.member k m') ks
+ ks' = filterKeys (\k -> Data.Map.Strict.member k m') ks
{-# INLINABLE mapMaybe #-}
{-| Retrieve a key from a `Map`
@@ -424,7 +424,7 @@ Just 2
Nothing
-}
lookup :: Ord k => k -> Map k v -> Maybe v
-lookup k (Map m _) = Data.Map.lookup k m
+lookup k (Map m _) = Data.Map.Strict.lookup k m
{-# INLINABLE lookup #-}
{-| Retrieve the first key, value of the 'Map', if present,
@@ -442,9 +442,9 @@ Nothing
uncons :: Ord k => Map k v -> Maybe (k, v, Map k v)
uncons (Map _ (Original [])) = Nothing
uncons (Map m (Original (k:ks))) =
- Just (k, m Data.Map.! k, Map (Data.Map.delete k m) (Original ks))
+ Just (k, m Data.Map.Strict.! k, Map (Data.Map.Strict.delete k m) (Original ks))
uncons (Map m Sorted)
- | Just ((k, v), m') <- Data.Map.minViewWithKey m = Just (k, v, Map m' Sorted)
+ | Just ((k, v), m') <- Data.Map.Strict.minViewWithKey m = Just (k, v, Map m' Sorted)
| otherwise = Nothing
{-# INLINABLE uncons #-}
@@ -460,7 +460,7 @@ True
False
-}
member :: Ord k => k -> Map k v -> Bool
-member k (Map m _) = Data.Map.member k m
+member k (Map m _) = Data.Map.Strict.member k m
{-# INLINABLE member #-}
{-|
@@ -468,7 +468,7 @@ member k (Map m _) = Data.Map.member k m
1
-}
size :: Map k v -> Int
-size (Map m _) = Data.Map.size m
+size (Map m _) = Data.Map.Strict.size m
{-# INLINABLE size #-}
{-| Combine two `Map`s, preferring keys from the first `Map`
@@ -483,11 +483,11 @@ fromList [("D",1),("C",2),("A",4)]
union :: Ord k => Map k v -> Map k v -> Map k v
union (Map mL ksL) (Map mR ksR) = Map m ks
where
- m = Data.Map.union mL mR
+ m = Data.Map.Strict.union mL mR
ks = case (ksL, ksR) of
(Original l, Original r) -> Original $
- l <|> Prelude.filter (\k -> Data.Map.notMember k mL) r
+ l <|> Prelude.filter (\k -> Data.Map.Strict.notMember k mL) r
_ -> Sorted
{-# INLINABLE union #-}
@@ -501,11 +501,11 @@ fromList [("D",1),("C",5),("A",4)]
unionWith :: Ord k => (v -> v -> v) -> Map k v -> Map k v -> Map k v
unionWith combine (Map mL ksL) (Map mR ksR) = Map m ks
where
- m = Data.Map.unionWith combine mL mR
+ m = Data.Map.Strict.unionWith combine mL mR
ks = case (ksL, ksR) of
(Original l, Original r) -> Original $
- l <|> Prelude.filter (\k -> Data.Map.notMember k mL) r
+ l <|> Prelude.filter (\k -> Data.Map.Strict.notMember k mL) r
_ -> Sorted
{-# INLINABLE unionWith #-}
@@ -526,7 +526,7 @@ outerJoin
-> Map k c
outerJoin fa fb fab (Map ma ksA) (Map mb ksB) = Map m ks
where
- m = Data.Map.mergeWithKey
+ m = Data.Map.Strict.mergeWithKey
(\k a b -> Just (fab k a b))
(fmap fa)
(fmap fb)
@@ -535,7 +535,7 @@ outerJoin fa fb fab (Map ma ksA) (Map mb ksB) = Map m ks
ks = case (ksA, ksB) of
(Original l, Original r) -> Original $
- l <|> Prelude.filter (\k -> Data.Map.notMember k ma) r
+ l <|> Prelude.filter (\k -> Data.Map.Strict.notMember k ma) r
_ -> Sorted
{-# INLINABLE outerJoin #-}
@@ -550,10 +550,10 @@ fromList [("B",2)]
intersection :: Ord k => Map k a -> Map k b -> Map k a
intersection (Map mL ksL) (Map mR _) = Map m ks
where
- m = Data.Map.intersection mL mR
+ m = Data.Map.Strict.intersection mL mR
-- Or forget order unless both maps are ordered?!
- ks = filterKeys (\k -> Data.Map.member k m) ksL
+ ks = filterKeys (\k -> Data.Map.Strict.member k m) ksL
{-# INLINABLE intersection #-}
{-| Combine two `Map`s on their shared keys, using the supplied function to
@@ -565,10 +565,10 @@ fromList [("B",5)]
intersectionWith :: Ord k => (a -> b -> c) -> Map k a -> Map k b -> Map k c
intersectionWith combine (Map mL ksL) (Map mR _) = Map m ks
where
- m = Data.Map.intersectionWith combine mL mR
+ m = Data.Map.Strict.intersectionWith combine mL mR
-- Or forget order unless both maps are ordered?!
- ks = filterKeys (\k -> Data.Map.member k m) ksL
+ ks = filterKeys (\k -> Data.Map.Strict.member k m) ksL
{-# INLINABLE intersectionWith #-}
{-| Compute the difference of two `Map`s by subtracting all keys from the
@@ -580,9 +580,9 @@ fromList [("C",1)]
difference :: Ord k => Map k a -> Map k b -> Map k a
difference (Map mL ksL) (Map mR _) = Map m ks
where
- m = Data.Map.difference mL mR
+ m = Data.Map.Strict.difference mL mR
- ks = filterKeys (\k -> Data.Map.notMember k mR) ksL
+ ks = filterKeys (\k -> Data.Map.Strict.notMember k mR) ksL
{-# INLINABLE difference #-}
{-| Fold all of the key-value pairs in a `Map`, in their original order
@@ -591,7 +591,7 @@ difference (Map mL ksL) (Map mR _) = Map m ks
("BA",[1,2])
-}
foldMapWithKey :: (Monoid m, Ord k) => (k -> a -> m) -> Map k a -> m
-foldMapWithKey f (Map m Sorted) = Data.Map.foldMapWithKey f m
+foldMapWithKey f (Map m Sorted) = Data.Map.Strict.foldMapWithKey f m
foldMapWithKey f m = foldMap (uncurry f) (toList m)
{-# INLINABLE foldMapWithKey #-}
@@ -611,7 +611,7 @@ fromList [("B",("B",1)),("A",("A",2))]
mapWithKey :: (k -> a -> b) -> Map k a -> Map k b
mapWithKey f (Map m ks) = Map m' ks
where
- m' = Data.Map.mapWithKey f m
+ m' = Data.Map.Strict.mapWithKey f m
{-# INLINABLE mapWithKey #-}
{-| Traverse all of the key-value pairs in a `Map`, in their original order
@@ -622,9 +622,9 @@ mapWithKey f (Map m ks) = Map m' ks
traverseWithKey
:: Ord k => Applicative f => (k -> a -> f b) -> Map k a -> f (Map k b)
traverseWithKey f (Map m Sorted) =
- fmap (\m' -> Map m' Sorted) (Data.Map.traverseWithKey f m)
+ fmap (\m' -> Map m' Sorted) (Data.Map.Strict.traverseWithKey f m)
traverseWithKey f m@(Map _ ks) =
- flip Map ks . Data.Map.fromList <$> traverse f' (toList m)
+ flip Map ks . Data.Map.Strict.fromList <$> traverse f' (toList m)
where
f' (k, a) = fmap ((,) k) (f k a)
{-# INLINABLE traverseWithKey #-}
@@ -635,7 +635,7 @@ traverseWithKey f m@(Map _ ks) =
unorderedTraverseWithKey
:: Ord k => Applicative f => (k -> a -> f b) -> Map k a -> f (Map k b)
unorderedTraverseWithKey f (Map m ks) =
- fmap (\m' -> Map m' ks) (Data.Map.traverseWithKey f m)
+ fmap (\m' -> Map m' ks) (Data.Map.Strict.traverseWithKey f m)
{-# INLINABLE unorderedTraverseWithKey #-}
{-| Traverse all of the key-value pairs in a 'Map', not preserving their
@@ -647,7 +647,7 @@ unorderedTraverseWithKey f (Map m ks) =
unorderedTraverseWithKey_
:: Ord k => Applicative f => (k -> a -> f ()) -> Map k a -> f ()
unorderedTraverseWithKey_ f (Map m _) =
- Data.Map.foldlWithKey' (\acc k v -> acc *> f k v) (pure ()) m
+ Data.Map.Strict.foldlWithKey' (\acc k v -> acc *> f k v) (pure ()) m
{-# INLINABLE unorderedTraverseWithKey_ #-}
{-| Convert a `Map` to a list of key-value pairs in the original order of keys
@@ -656,22 +656,22 @@ unorderedTraverseWithKey_ f (Map m _) =
[("B",1),("A",2)]
-}
toList :: Ord k => Map k v -> [(k, v)]
-toList (Map m Sorted) = Data.Map.toList m
-toList (Map m (Original ks)) = fmap (\k -> (k, m Data.Map.! k)) ks
+toList (Map m Sorted) = Data.Map.Strict.toList m
+toList (Map m (Original ks)) = fmap (\k -> (k, m Data.Map.Strict.! k)) ks
{-# INLINABLE toList #-}
{-| Convert a `Map` to a list of key-value pairs in ascending order of keys
-}
toAscList :: Map k v -> [(k, v)]
-toAscList (Map m _) = Data.Map.toAscList m
+toAscList (Map m _) = Data.Map.Strict.toAscList m
{-# INLINABLE toAscList #-}
-{-| Convert a @"Dhall.Map".`Map`@ to a @"Data.Map".`Data.Map.Map`@
+{-| Convert a @"Dhall.Map".`Map`@ to a @"Data.Map.Strict".`Data.Map.Strict.Map`@
>>> toMap (fromList [("B",1),("A",2)]) -- Order is lost upon conversion
fromList [("A",2),("B",1)]
-}
-toMap :: Map k v -> Data.Map.Map k v
+toMap :: Map k v -> Data.Map.Strict.Map k v
toMap (Map m _) = m
{-# INLINABLE toMap #-}
@@ -681,7 +681,7 @@ toMap (Map m _) = m
["B","A"]
-}
keys :: Map k v -> [k]
-keys (Map m Sorted) = Data.Map.keys m
+keys (Map m Sorted) = Data.Map.Strict.keys m
keys (Map _ (Original ks)) = ks
{-# INLINABLE keys #-}
@@ -691,8 +691,8 @@ keys (Map _ (Original ks)) = ks
[1,2]
-}
elems :: Ord k => Map k v -> [v]
-elems (Map m Sorted) = Data.Map.elems m
-elems (Map m (Original ks)) = fmap (\k -> m Data.Map.! k) ks
+elems (Map m Sorted) = Data.Map.Strict.elems m
+elems (Map m (Original ks)) = fmap (\k -> m Data.Map.Strict.! k) ks
{-# INLINABLE elems #-}
{-| Return the @"Data.Set".'Data.Set.Set'@ of the keys
@@ -701,7 +701,7 @@ elems (Map m (Original ks)) = fmap (\k -> m Data.Map.! k) ks
fromList ["A","B"]
-}
keysSet :: Map k v -> Data.Set.Set k
-keysSet (Map m _) = Data.Map.keysSet m
+keysSet (Map m _) = Data.Map.Strict.keysSet m
{-# INLINABLE keysSet #-}
filterKeys :: (a -> Bool) -> Keys a -> Keys a