{-# LINE 1 "src/Crypto/Hash/BLAKE2/BLAKE2s.hsc" #-}
module Crypto.Hash.BLAKE2.BLAKE2s
(
BLAKE2sState,
initialize,
initialize',
update,
finalize,
hash
) where
import Data.ByteString (ByteString)
import Foreign.C.Types (CInt(..), CSize(..))
import Foreign.ForeignPtr (ForeignPtr)
import Foreign.Storable (Storable(..))
import Crypto.Hash.BLAKE2.Internal
data BLAKE2sStruct
instance Storable BLAKE2sStruct where
sizeOf _ = (136)
{-# LINE 32 "src/Crypto/Hash/BLAKE2/BLAKE2s.hsc" #-}
alignment _ = 8
{-# LINE 33 "src/Crypto/Hash/BLAKE2/BLAKE2s.hsc" #-}
peek = error "peek not implemented"
poke = error "poke not implemented"
type BLAKE2sState = ForeignPtr BLAKE2sStruct
initialize :: Int
-> BLAKE2sState
initialize = initializer c_blake2s_init
{-# INLINE initialize #-}
initialize' :: Int
-> ByteString
-> BLAKE2sState
initialize' = initializer' c_blake2s_init_key
{-# INLINE initialize' #-}
update :: ByteString
-> BLAKE2sState
-> BLAKE2sState
update = updater c_blake2s_update
{-# INLINE update #-}
finalize :: Int
-> BLAKE2sState
-> ByteString
finalize = finalizer c_blake2s_final
{-# INLINE finalize #-}
hash :: Int
-> ByteString
-> ByteString
-> ByteString
hash = hasher c_blake2s
{-# INLINE hash #-}
foreign import ccall unsafe "blake2.h blake2s"
c_blake2s :: HashFunc
foreign import ccall unsafe "blake2.h blake2s_init"
c_blake2s_init :: InitFunc BLAKE2sStruct
foreign import ccall unsafe "blake2.h blake2s_init_key"
c_blake2s_init_key :: InitKeyFunc BLAKE2sStruct
foreign import ccall unsafe "blake2.h blake2s_update"
c_blake2s_update :: UpdateFunc BLAKE2sStruct
foreign import ccall unsafe "blake2.h blake2s_final"
c_blake2s_final :: FinalFunc BLAKE2sStruct