aboutsummaryrefslogtreecommitdiff
path: root/src/Data/Digest.hs
diff options
context:
space:
mode:
authorGravatar Benjamin Barenblat <bbaren@google.com>2018-09-04 18:53:20 -0400
committerGravatar Benjamin Barenblat <bbaren@google.com>2018-09-04 18:53:20 -0400
commit015079075e1e156d5934f4e716a51eb284289b5d (patch)
tree17dd43c33e0af2696dc1a61c2a9abe6c0667e1d4 /src/Data/Digest.hs
parent2e7bd84469eba730f24dd3e448cca22f5aed16f4 (diff)
Marshal `ForeignPtr` to `Ptr` within c2hs code
Diffstat (limited to 'src/Data/Digest.hs')
-rw-r--r--src/Data/Digest.hs10
1 files changed, 4 insertions, 6 deletions
diff --git a/src/Data/Digest.hs b/src/Data/Digest.hs
index a17c438..594fef1 100644
--- a/src/Data/Digest.hs
+++ b/src/Data/Digest.hs
@@ -40,7 +40,6 @@ module Data.Digest
import qualified Data.ByteString.Lazy as Lazy (ByteString)
import qualified Data.ByteString.Lazy as ByteString.Lazy
-import Foreign (withForeignPtr)
import Foreign.Marshal.Unsafe (unsafeLocalState)
import BTLS.BoringSSL.Base
@@ -88,8 +87,7 @@ sha512 = Algorithm evpSHA512
hash :: Algorithm -> Lazy.ByteString -> Digest
hash (Algorithm md) bytes =
unsafeLocalState $ do
- ctxFP <- mallocEVPMDCtx
- withForeignPtr ctxFP $ \ctx -> do
- evpDigestInitEx ctx md noEngine
- mapM_ (evpDigestUpdate ctx) (ByteString.Lazy.toChunks bytes)
- Digest <$> onBufferOfMaxSize evpMaxMDSize (evpDigestFinalEx ctx)
+ ctx <- mallocEVPMDCtx
+ evpDigestInitEx ctx md noEngine
+ mapM_ (evpDigestUpdate ctx) (ByteString.Lazy.toChunks bytes)
+ Digest <$> onBufferOfMaxSize evpMaxMDSize (evpDigestFinalEx ctx)