Skip to content
This repository

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
tree: 1f86b8f184
Fetching contributors…

Cannot retrieve contributors at this time

file 39 lines (33 sloc) 1.186 kb
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
{-# LANGUAGE ForeignFunctionInterface #-}

-- |
-- Module: Codec.Compression.Snappy
-- Copyright: (c) 2011 MailRank, Inc.
-- License: Apache
-- Maintainer: Bryan O'Sullivan <bos@serpentine.com>
-- Stability: experimental
-- Portability: portable
--
-- This module provides fast, pure Haskell bindings to Google's
-- Snappy compression and decompression library:
-- <http://code.google.com/p/snappy/>
--
-- These functions operate on strict bytestrings, and thus use as much
-- memory as both the entire compressed and uncompressed data.

module Codec.Compression.Snappy.Internal
    (
      check
    , maxCompressedLength
    ) where

import Control.Monad (when)
import Foreign.C.Types (CSize(..))

maxCompressedLength :: Int -> Int
maxCompressedLength = fromIntegral . c_MaxCompressedLength . fromIntegral
{-# INLINE maxCompressedLength #-}

check :: (Integral a) => String -> IO a -> IO ()
check func act = do
  ok <- act
  when (ok == 0) . fail $ "Codec.Compression.Snappy." ++ func ++
                          ": corrupt input "
{-# INLINE check #-}

foreign import ccall unsafe "hs_snappy.h _hsnappy_MaxCompressedLength"
    c_MaxCompressedLength :: CSize -> CSize
Something went wrong with that request. Please try again.