ref: f292a26d47527ae5dd9de040754c6d0a64a162da
dir: /tests/TypeLits.hs/
module TypeLits(main) where import Prelude import Data.TypeLits data PS (s :: Symbol) = PS data PN (s :: Nat) = PN natValInt :: forall (n :: Nat) . KnownNat n => PN n -> Int natValInt p = fromInteger (natVal p) main :: IO () main = do print $ symbolVal (PS :: PS "hello") print $ natVal (PN :: PN 42) print $ natValInt (PN :: PN 42)