{-# 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 :: (String -> Q Exp)
-> (String -> Q Pat)
-> (String -> Q Type)
-> (String -> Q [Dec])
-> QuasiQuoter
QuasiQuoter
{ quoteExp :: String -> Q Exp
quoteExp = String -> Q D10
forall (m :: * -> *). MonadFail m => String -> m D10
strD10Fail (String -> Q D10) -> (D10 -> Q Exp) -> String -> Q Exp
forall (m :: * -> *) a b c.
Monad m =>
(a -> m b) -> (b -> m c) -> a -> m c
>=> (Integer -> Q Exp
d10Exp (Integer -> Q Exp) -> (D10 -> Integer) -> D10 -> Q Exp
forall b c a. (b -> c) -> (a -> b) -> a -> c
. D10 -> Integer
d10Integer)
, quotePat :: String -> Q Pat
quotePat = String -> Q D10
forall (m :: * -> *). MonadFail m => String -> m D10
strD10Fail (String -> Q D10) -> (D10 -> Q Pat) -> String -> Q Pat
forall (m :: * -> *) a b c.
Monad m =>
(a -> m b) -> (b -> m c) -> a -> m c
>=> (Integer -> Q Pat
d10Pat (Integer -> Q Pat) -> (D10 -> Integer) -> D10 -> Q Pat
forall b c a. (b -> c) -> (a -> b) -> a -> c
. D10 -> Integer
d10Integer)
, quoteType :: String -> Q Type
quoteType = \String
_ -> String -> Q Type
forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"d10 cannot be used in a type context"
, quoteDec :: String -> Q [Dec]
quoteDec = \String
_ -> String -> Q [Dec]
forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"d10 cannot be used in a declaration context"
}
d10list :: QuasiQuoter
d10list :: QuasiQuoter
d10list = QuasiQuoter :: (String -> Q Exp)
-> (String -> Q Pat)
-> (String -> Q Type)
-> (String -> Q [Dec])
-> QuasiQuoter
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
_ -> String -> Q Type
forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"d10list cannot be used in a type context"
, quoteDec :: String -> Q [Dec]
quoteDec = \String
_ -> String -> Q [Dec]
forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"d10list cannot be used in a declaration context"
}