graphql-engine/server/src-lib/Hasura/GraphQL/Execute/Subscription/TMap.hs
Tom Harding 7e334e08a4 Import HashMap, not HM, Map, M...
PR-URL: https://github.com/hasura/graphql-engine-mono/pull/8947
GitOrigin-RevId: 18e52c928e1df535579e2077b4af6c2ce92bdcef
2023-04-26 15:43:44 +00:00

61 lines
1.8 KiB
Haskell

module Hasura.GraphQL.Execute.Subscription.TMap
( TMap,
new,
reset,
null,
lookup,
insert,
delete,
toList,
replace,
union,
filterWithKey,
getMap,
)
where
import Control.Concurrent.STM
import Data.HashMap.Strict qualified as HashMap
import Hasura.Prelude hiding (lookup, null, toList, union)
-- | A coarse-grained transactional map implemented by simply wrapping a 'HashMap.HashMap' in a 'TVar'.
-- Compared to "StmContainers.Map", this provides much faster iteration over the elements at the
-- cost of significantly increased contention on writes.
newtype TMap k v = TMap {unTMap :: TVar (HashMap.HashMap k v)}
new :: STM (TMap k v)
new = TMap <$> newTVar HashMap.empty
reset :: TMap k v -> STM ()
reset = flip writeTVar HashMap.empty . unTMap
null :: TMap k v -> STM Bool
null = fmap HashMap.null . readTVar . unTMap
lookup :: Hashable k => k -> TMap k v -> STM (Maybe v)
lookup k = fmap (HashMap.lookup k) . readTVar . unTMap
insert :: Hashable k => v -> k -> TMap k v -> STM ()
insert !v k mapTv = modifyTVar' (unTMap mapTv) $ HashMap.insert k v
delete :: Hashable k => k -> TMap k v -> STM ()
delete k mapTv = modifyTVar' (unTMap mapTv) $ HashMap.delete k
toList :: TMap k v -> STM [(k, v)]
toList = fmap HashMap.toList . readTVar . unTMap
filterWithKey :: (k -> v -> Bool) -> TMap k v -> STM ()
filterWithKey f mapTV = modifyTVar' (unTMap mapTV) $ HashMap.filterWithKey f
replace :: TMap k v -> HashMap.HashMap k v -> STM ()
replace mapTV v = void $ swapTVar (unTMap mapTV) v
union :: Hashable k => TMap k v -> TMap k v -> STM (TMap k v)
union mapA mapB = do
l <- readTVar $ unTMap mapA
r <- readTVar $ unTMap mapB
TMap <$> newTVar (HashMap.union l r)
getMap :: TMap k v -> STM (HashMap.HashMap k v)
getMap = readTVar . unTMap