{-# LANGUAGE CPP #-}
#if MIN_VERSION_base(4,8,0)
{-# LANGUAGE MagicHash #-}
#endif
{-# OPTIONS_GHC -fno-warn-orphans #-}
module TextShow.Numeric.Natural () where
#if MIN_VERSION_base(4,15,0)
import GHC.Exts (Word(..))
import GHC.Num (integerFromNatural)
import GHC.Num.Natural (Natural(..))
#elif MIN_VERSION_base(4,8,0) && defined(MIN_VERSION_integer_gmp)
import GHC.Exts (Word(..))
import GHC.Integer.GMP.Internals (Integer(..))
import GHC.Natural (Natural(..))
#else
import Numeric.Natural.Compat (Natural)
#endif
import TextShow.Classes (TextShow(..))
import TextShow.Data.Integral ()
instance TextShow Natural where
#if MIN_VERSION_base(4,15,0)
showbPrec :: Int -> Natural -> Builder
showbPrec Int
p (NS Word#
w) = Int -> Word -> Builder
forall a. TextShow a => Int -> a -> Builder
showbPrec Int
p (Word# -> Word
W# Word#
w)
showbPrec Int
p Natural
n = Int -> Integer -> Builder
forall a. TextShow a => Int -> a -> Builder
showbPrec Int
p (Natural -> Integer
integerFromNatural Natural
n)
#elif MIN_VERSION_base(4,8,0) && defined(MIN_VERSION_integer_gmp)
showbPrec _ (NatS# w#) = showb $ W# w#
showbPrec p (NatJ# bn) = showbPrec p $ Jp# bn
#else
showbPrec p = showbPrec p . toInteger
{-# INLINE showbPrec #-}
#endif