{-# LANGUAGE GADTs #-}
{-# LANGUAGE TemplateHaskellQuotes #-}
{-# LANGUAGE Safe #-}
{-# OPTIONS_HADDOCK show-extensions #-}
module Clash.Promoted.Symbol
(SSymbol (..), ssymbolProxy, ssymbolToString)
where
import Language.Haskell.TH.Syntax
import GHC.Show (appPrec)
import GHC.TypeLits (KnownSymbol, Symbol, symbolVal)
data SSymbol (s :: Symbol) where
SSymbol :: KnownSymbol s => SSymbol s
instance KnownSymbol s => Lift (SSymbol (s :: Symbol)) where
lift t = pure (AppTypeE (ConE 'SSymbol) tt)
where
tt = LitT (StrTyLit (ssymbolToString t))
instance Show (SSymbol s) where
showsPrec d s@SSymbol = showParen (d > appPrec) $
showString "SSymbol @" . shows (ssymbolToString s)
{-# INLINE ssymbolProxy #-}
ssymbolProxy :: KnownSymbol s => proxy s -> SSymbol s
ssymbolProxy _ = SSymbol
{-# INLINE ssymbolToString #-}
ssymbolToString :: SSymbol s -> String
ssymbolToString s@SSymbol = symbolVal s