module Main where

import Prelude
import Criterion
import Criterion.Main
import qualified PostgreSQL.Binary.Encoder as E


main =
  defaultMain
    [
      b "bool" E.bool True
      ,
      b "int2" E.int2_int16 1000
      ,
      b "int4" E.int4_int32 1000
      ,
      b "int8" E.int8_int64 1000
      ,
      b "float4" E.float4 12.65468468
      ,
      b "float8" E.float8 12.65468468
      ,
      b "numeric" E.numeric (read "20.213290183")
      ,
      b "char" E.char 'Я'
      ,
      b "text" E.text_strict "alsdjflskjдывлоаы оады"
      ,
      b "bytea" E.bytea_strict "alskdfj;dasjfl;dasjflksdj"
      ,
      b "date" E.date (read "2000-01-19")
      ,
      b "time" E.time_int (read "10:41:06")
      ,
      b "timetz" E.timetz_int (read "(10:41:06, +0300)")
      ,
      b "timestamp" E.timestamp_int (read "2000-01-19 10:41:06")
      ,
      b "timestamptz" E.timestamptz_int (read "2000-01-19 10:41:06")
      ,
      b "interval" E.interval_int (secondsToDiffTime 23472391128374)
      ,
      b "uuid" E.uuid (read "550e8400-e29b-41d4-a716-446655440000")
      ,
      let
        encoder =
          E.array 23 $
          E.arrayDimension foldl' $
          E.arrayValue $
          E.int4_int32
        in
          b "array" encoder [1,2,3,4]
    ]
  where
    b name encoder value = 
      bench name $ nf (E.run encoder) value