{-# LANGUAGE AllowAmbiguousTypes #-} {-# LANGUAGE MagicHash #-} {-# LANGUAGE ScopedTypeVariables #-} {-# LANGUAGE TypeApplications #-} {-# LANGUAGE TypeFamilies #-} -- | -- Module: Data.Hash.Class.Mutable.Salted -- Copyright: Copyright © 2021 Lars Kuhtz -- License: MIT -- Maintainer: Lars Kuhtz -- Stability: experimental -- -- Class of Salted Mutable Hashes -- module Data.Hash.Class.Mutable.Salted ( Hash(..) , hashPtr , hashStorable , hashByteString , hashByteStringLazy , hashShortByteString , hashByteArray -- * Incremental Hashing , updateByteString , updateByteStringLazy , updateShortByteString , updateStorable , updateByteArray ) where import qualified Data.ByteString as B import qualified Data.ByteString.Lazy as BL import qualified Data.ByteString.Short as BS import Data.Kind import Data.Word import Foreign.Ptr import Foreign.Storable import GHC.Exts import GHC.IO -- internal modules import Data.Hash.Class.Mutable.Internal -- -------------------------------------------------------------------------- -- -- Class of Salted Mutable Hashes class IncrementalHash a => Hash a where type Salt a :: Type initialize :: Salt a -> IO (Context a) -- -------------------------------------------------------------------------- -- -- Hash Functions hashPtr :: forall a . Hash a => Salt a -> Ptr Word8 -> Int -> IO a hashPtr k p n = do ctx <- initialize @a k update @a ctx p n finalize ctx {-# INLINE hashPtr #-} hashByteString :: forall a . Hash a => Salt a -> B.ByteString -> a hashByteString k b = unsafeDupablePerformIO $ do ctx <- initialize @a k updateByteString @a ctx b finalize ctx {-# INLINE hashByteString #-} hashByteStringLazy :: forall a . Hash a => Salt a -> BL.ByteString -> a hashByteStringLazy k b = unsafeDupablePerformIO $ do ctx <- initialize @a k updateByteStringLazy @a ctx b finalize ctx {-# INLINE hashByteStringLazy #-} hashShortByteString :: forall a . Hash a => Salt a -> BS.ShortByteString -> IO a hashShortByteString k b = do ctx <- initialize @a k updateShortByteString @a ctx b finalize ctx {-# INLINE hashShortByteString #-} hashStorable :: forall a b . Hash a => Storable b => Salt a -> b -> IO a hashStorable k b = do ctx <- initialize @a k updateStorable @a ctx b finalize ctx {-# INLINE hashStorable #-} hashByteArray :: forall a . Hash a => Salt a -> ByteArray# -> IO a hashByteArray k b = do ctx <- initialize @a k updateByteArray @a ctx b finalize ctx {-# INLINE hashByteArray #-}