{-# language Safe #-}
module D10.Char.Quotes where
import D10.Char.Conversions
import D10.Char.Splices
import Control.Monad ((>=>))
import Control.Monad.Fail (MonadFail (fail))
import Language.Haskell.TH.Quote (QuasiQuoter (..))
import Prelude hiding (fail)
d10 :: QuasiQuoter
d10 :: QuasiQuoter
d10 = QuasiQuoter
{ quoteExp :: String -> Q Exp
quoteExp = forall (m :: * -> *). MonadFail m => String -> m D10
strD10Fail forall (m :: * -> *) a b c.
Monad m =>
(a -> m b) -> (b -> m c) -> a -> m c
>=> (Integer -> Q Exp
d10Exp forall b c a. (b -> c) -> (a -> b) -> a -> c
. D10 -> Integer
d10Integer)
, quotePat :: String -> Q Pat
quotePat = forall (m :: * -> *). MonadFail m => String -> m D10
strD10Fail forall (m :: * -> *) a b c.
Monad m =>
(a -> m b) -> (b -> m c) -> a -> m c
>=> (Integer -> Q Pat
d10Pat forall b c a. (b -> c) -> (a -> b) -> a -> c
. D10 -> Integer
d10Integer)
, quoteType :: String -> Q Type
quoteType = \String
_ -> forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"d10 cannot be used in a type context"
, quoteDec :: String -> Q [Dec]
quoteDec = \String
_ -> forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"d10 cannot be used in a declaration context"
}
d10list :: QuasiQuoter
d10list :: QuasiQuoter
d10list = QuasiQuoter
{ quoteExp :: String -> Q Exp
quoteExp = String -> Q Exp
d10ListExp
, quotePat :: String -> Q Pat
quotePat = String -> Q Pat
d10ListPat
, quoteType :: String -> Q Type
quoteType = \String
_ -> forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"d10list cannot be used in a type context"
, quoteDec :: String -> Q [Dec]
quoteDec = \String
_ -> forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"d10list cannot be used in a declaration context"
}