From 201b4767ea4489733641d7d61783fd759878ca96 Mon Sep 17 00:00:00 2001 From: David Feuer Date: Mon, 20 Dec 2021 21:40:47 -0500 Subject: [PATCH] Add Lift instances Closes #342 --- Data/HashMap/Internal.hs | 15 ++++++++++----- Data/HashMap/Internal/Array.hs | 13 +++++++++++++ Data/HashSet/Internal.hs | 7 +++++-- unordered-containers.cabal | 3 ++- 4 files changed, 30 insertions(+), 8 deletions(-) diff --git a/Data/HashMap/Internal.hs b/Data/HashMap/Internal.hs index 7af93c0e..e66d77fa 100644 --- a/Data/HashMap/Internal.hs +++ b/Data/HashMap/Internal.hs @@ -1,10 +1,14 @@ -{-# LANGUAGE BangPatterns, CPP, DeriveDataTypeable, MagicHash #-} -{-# LANGUAGE ScopedTypeVariables #-} +{-# LANGUAGE CPP #-} +{-# LANGUAGE BangPatterns #-} +{-# LANGUAGE DeriveDataTypeable #-} +{-# LANGUAGE DeriveLift #-} +{-# LANGUAGE LambdaCase #-} +{-# LANGUAGE MagicHash #-} {-# LANGUAGE PatternGuards #-} {-# LANGUAGE RoleAnnotations #-} +{-# LANGUAGE ScopedTypeVariables #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE UnboxedTuples #-} -{-# LANGUAGE LambdaCase #-} #if __GLASGOW_HASKELL__ >= 802 {-# LANGUAGE TypeInType #-} {-# LANGUAGE UnboxedSums #-} @@ -180,6 +184,7 @@ import GHC.Exts (TYPE, Int (..), Int#) import Data.Functor.Identity (Identity (..)) import Control.Applicative (Const (..)) import Data.Coerce (coerce) +import qualified Language.Haskell.TH.Syntax as TH -- | A set of values. A set cannot contain duplicate values. ------------------------------------------------------------------------ @@ -189,7 +194,7 @@ hash :: H.Hashable a => a -> Hash hash = fromIntegral . H.hash data Leaf k v = L !k v - deriving (Eq) + deriving (Eq, TH.Lift) instance (NFData k, NFData v) => NFData (Leaf k v) where rnf (L k v) = rnf k `seq` rnf v @@ -215,7 +220,7 @@ data HashMap k v | Leaf !Hash !(Leaf k v) | Full !(A.Array (HashMap k v)) | Collision !Hash !(A.Array (Leaf k v)) - deriving (Typeable) + deriving (Typeable, TH.Lift) type role HashMap nominal representational diff --git a/Data/HashMap/Internal/Array.hs b/Data/HashMap/Internal/Array.hs index 0ed6b088..1accbe9b 100644 --- a/Data/HashMap/Internal/Array.hs +++ b/Data/HashMap/Internal/Array.hs @@ -1,4 +1,5 @@ {-# LANGUAGE BangPatterns, CPP, MagicHash, Rank2Types, UnboxedTuples, ScopedTypeVariables #-} +{-# LANGUAGE TemplateHaskellQuotes #-} {-# OPTIONS_GHC -fno-full-laziness -funbox-strict-fields #-} {-# OPTIONS_HADDOCK not-home #-} @@ -84,6 +85,8 @@ import GHC.Exts (SmallArray#, newSmallArray#, readSmallArray#, writeSmallArray#, SmallMutableArray#, sizeofSmallArray#, copySmallArray#, thawSmallArray#, sizeofSmallMutableArray#, copySmallMutableArray#, cloneSmallMutableArray#) +import qualified Language.Haskell.TH.Syntax as TH + #if defined(ASSERTS) import qualified Prelude #endif @@ -474,6 +477,16 @@ fromList n xs0 = go (x:xs) mary i = do write mary i x go xs mary (i+1) +instance TH.Lift a => TH.Lift (Array a) where +#if MIN_VERSION_template_haskell(2,16,0) + liftTyped ar = [|| fromList arlen arlist ||] +#else + lift ar = [| fromList arlen arlist |] +#endif + where + arlen = length ar + arlist = toList ar + toList :: Array a -> [a] toList = foldr (:) [] diff --git a/Data/HashSet/Internal.hs b/Data/HashSet/Internal.hs index c5037bc7..682bd829 100644 --- a/Data/HashSet/Internal.hs +++ b/Data/HashSet/Internal.hs @@ -1,4 +1,6 @@ -{-# LANGUAGE CPP, DeriveDataTypeable #-} +{-# LANGUAGE CPP #-} +{-# LANGUAGE DeriveDataTypeable #-} +{-# LANGUAGE DeriveLift #-} {-# LANGUAGE RoleAnnotations #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE Trustworthy #-} @@ -114,11 +116,12 @@ import qualified Data.Hashable.Lifted as H #if MIN_VERSION_deepseq(1,4,3) import qualified Control.DeepSeq as NF #endif +import qualified Language.Haskell.TH.Syntax as TH -- | A set of values. A set cannot contain duplicate values. newtype HashSet a = HashSet { asMap :: HashMap a () - } deriving (Typeable) + } deriving (Typeable, TH.Lift) type role HashSet nominal diff --git a/unordered-containers.cabal b/unordered-containers.cabal index b52052c4..33b656d6 100644 --- a/unordered-containers.cabal +++ b/unordered-containers.cabal @@ -56,7 +56,8 @@ library build-depends: base >= 4.9 && < 5, deepseq >= 1.1, - hashable >= 1.0.1.1 && < 1.5 + hashable >= 1.0.1.1 && < 1.5, + template-haskell default-language: Haskell2010