{-# language DataKinds #-}
{-# language TypeFamilies #-}
module Data.Bytes.Builder.Bounded.Class
( ToBoundedBuilder(..)
) where
import Data.Int
import Data.Word
import qualified Data.Bytes.Builder.Bounded as Bounded
import qualified GHC.TypeNats as GHC
class ToBoundedBuilder a where
type BoundedBuilderLength a :: GHC.Nat
toBuilder :: a -> Bounded.Builder (BoundedBuilderLength a)
instance ToBoundedBuilder (Bounded.Builder n) where
type BoundedBuilderLength (Bounded.Builder n) = n
toBuilder :: Builder n -> Builder (BoundedBuilderLength (Builder n))
toBuilder = forall a. a -> a
id
instance ToBoundedBuilder Int64 where
type BoundedBuilderLength Int64 = 20
toBuilder :: Int64 -> Builder (BoundedBuilderLength Int64)
toBuilder = Int64 -> Builder 20
Bounded.int64Dec
instance ToBoundedBuilder Int32 where
type BoundedBuilderLength Int32 = 11
toBuilder :: Int32 -> Builder (BoundedBuilderLength Int32)
toBuilder = Int32 -> Builder 11
Bounded.int32Dec
instance ToBoundedBuilder Int16 where
type BoundedBuilderLength Int16 = 6
toBuilder :: Int16 -> Builder (BoundedBuilderLength Int16)
toBuilder = Int16 -> Builder 6
Bounded.int16Dec
instance ToBoundedBuilder Int8 where
type BoundedBuilderLength Int8 = 4
toBuilder :: Int8 -> Builder (BoundedBuilderLength Int8)
toBuilder = Int8 -> Builder 4
Bounded.int8Dec
instance ToBoundedBuilder Int where
type BoundedBuilderLength Int = 20
toBuilder :: Int -> Builder (BoundedBuilderLength Int)
toBuilder = Int -> Builder 20
Bounded.intDec
instance ToBoundedBuilder Word64 where
type BoundedBuilderLength Word64 = 19
toBuilder :: Word64 -> Builder (BoundedBuilderLength Word64)
toBuilder = Word64 -> Builder 19
Bounded.word64Dec
instance ToBoundedBuilder Word32 where
type BoundedBuilderLength Word32 = 10
toBuilder :: Word32 -> Builder (BoundedBuilderLength Word32)
toBuilder = Word32 -> Builder 10
Bounded.word32Dec
instance ToBoundedBuilder Word16 where
type BoundedBuilderLength Word16 = 5
toBuilder :: Word16 -> Builder (BoundedBuilderLength Word16)
toBuilder = Word16 -> Builder 5
Bounded.word16Dec
instance ToBoundedBuilder Word8 where
type BoundedBuilderLength Word8 = 3
toBuilder :: Word8 -> Builder (BoundedBuilderLength Word8)
toBuilder = Word8 -> Builder 3
Bounded.word8Dec
instance ToBoundedBuilder Word where
type BoundedBuilderLength Word = 19
toBuilder :: Word -> Builder (BoundedBuilderLength Word)
toBuilder = Word -> Builder 19
Bounded.wordDec