module HaskellWorks.Data.Bits.FromBools
    ( FromBools(..)
    ) where
import           Data.Word
import           HaskellWorks.Data.Bits.BitWise
import           HaskellWorks.Data.Bits.FixedBitSize
class FromBools a where
  fromBools :: [Bool] -> Maybe (a, [Bool])
instance FromBools Word8 where
  fromBools [] = Nothing
  fromBools xs = go 0 0 xs
    where go _ w []        = Just (w, [])
          go n w (y:ys)
            | n < fixedBitSize w  = go (n + 1) (if y then w .|. (1 .<. n) else w) ys
            | n < 0               = error "Invalid index"
            | otherwise           = Just (w, y:ys)
instance FromBools Word16 where
  fromBools [] = Nothing
  fromBools xs = go 0 0 xs
    where go _ w []        = Just (w, [])
          go n w (y:ys)
            | n < fixedBitSize w  = go (n + 1) (if y then w .|. (1 .<. n) else w) ys
            | n < 0               = error "Invalid index"
            | otherwise           = Just (w, y:ys)
instance FromBools Word32 where
  fromBools [] = Nothing
  fromBools xs = go 0 0 xs
    where go _ w []        = Just (w, [])
          go n w (y:ys)
            | n < fixedBitSize w  = go (n + 1) (if y then w .|. (1 .<. n) else w) ys
            | n < 0               = error "Invalid index"
            | otherwise           = Just (w, y:ys)
instance FromBools Word64 where
  fromBools [] = Nothing
  fromBools xs = go 0 0 xs
    where go _ w []        = Just (w, [])
          go n w (y:ys)
            | n < fixedBitSize w  = go (n + 1) (if y then w .|. (1 .<. n) else w) ys
            | n < 0               = error "Invalid index"
            | otherwise           = Just (w, y:ys)