{-# LANGUAGE OverloadedStrings #-} module Octane.Type.Primitive.ListBench (benchmarks) where import Criterion import Octane import qualified Data.Binary as Binary import qualified Data.Binary.Get as Binary import qualified Data.ByteString.Lazy as BSL benchmarks :: Benchmark benchmarks = bgroup "List" [ bench "decode basic" (nf decodeBooleanList "\0\0\0\0") , bench "encode basic" (nf Binary.encode (List [] :: List Boolean)) ] decodeList :: (Binary.Binary a) => BSL.ByteString -> Either (BSL.ByteString, Binary.ByteOffset, String) (BSL.ByteString, Binary.ByteOffset, List a) decodeList = Binary.decodeOrFail decodeBooleanList :: BSL.ByteString -> Either (BSL.ByteString, Binary.ByteOffset, String) (BSL.ByteString, Binary.ByteOffset, List Boolean) decodeBooleanList = decodeList