module Spec.Bits (testBits) where

import Hedgehog.Classes

import qualified Hedgehog.Gen as Gen
import qualified Hedgehog.Range as Range

ranged :: (Bounded a, Num a) => (Range.Range a -> b) -> b
ranged f = f (Range.constantBounded)

testBits :: [(String, [Laws])]
testBits =
  [ ("Int", listInt)
  , ("Int8", listInt8)
  , ("Int16", listInt16)
  , ("Int32", listInt32)
  , ("Int64", listInt64)
  , ("Word", listWord)
  , ("Word8", listWord8)
  , ("Word16", listWord16)
  , ("Word32", listWord32)
  , ("Word64", listWord64) 
  ]

listInt, listInt8, listInt16, listInt32, listInt64 :: [Laws]
listInt = [bitsLaws (ranged Gen.int)]
listInt8 = [bitsLaws (ranged Gen.int8)]
listInt16 = [bitsLaws (ranged Gen.int16)]
listInt32 = [bitsLaws (ranged Gen.int32)]
listInt64 = [bitsLaws (ranged Gen.int64)]

listWord, listWord8, listWord16, listWord32, listWord64 :: [Laws]
listWord = [bitsLaws (ranged Gen.word)]
listWord8 = [bitsLaws (ranged Gen.word8)]
listWord16 = [bitsLaws (ranged Gen.word16)]
listWord32 = [bitsLaws (ranged Gen.word32)]
listWord64 = [bitsLaws (ranged Gen.word64)]