template-haskell-2.16.0.0: Support library for Template Haskell
Copyright(c) The University of Glasgow 2003
LicenseBSD-style (see the file libraries/base/LICENSE)
Maintainerlibraries@haskell.org
Stabilityexperimental
Portabilityportable
Safe HaskellTrustworthy
LanguageHaskell2010

Language.Haskell.TH.Syntax

Description

Abstract syntax definitions for Template Haskell.

Synopsis

Documentation

returnQ :: a -> Q a Source#

bindQ :: Q a -> (a -> Q b) -> Q b Source#

sequenceQ :: [Q a] -> Q [a] Source#

newName :: String -> QNameSource#

Generate a fresh name, which cannot be captured.

For example, this:

f = $(do nm1 <- newName "x" let nm2 = mkName "x" return (LamE [VarP nm1] (LamE [VarP nm2] (VarE nm1))) )

will produce the splice

f = \x0 -> \x -> x0

In particular, the occurrence VarE nm1 refers to the binding VarP nm1, and is not captured by the binding VarP nm2.

Although names generated by newName cannot be captured, they can capture other names. For example, this:

g = $(do nm1 <- newName "x" let nm2 = mkName "x" return (LamE [VarP nm2] (LamE [VarP nm1] (VarE nm2))) )

will produce the splice

g = \x -> \x0 -> x0

since the occurrence VarE nm2 is captured by the innermost binding of x, namely VarP nm1.

mkName :: String -> NameSource#

Generate a capturable name. Occurrences of such names will be resolved according to the Haskell scoping rules at the occurrence site.

For example:

f = [| pi + $(varE (mkName "pi")) |] ... g = let pi = 3 in $f

In this case, g is desugared to

g = Prelude.pi + 3

Note that mkName may be used with qualified names:

mkName "Prelude.pi"

See also dyn for a useful combinator. The above example could be rewritten using dyn as

f = [| pi + $(dyn "pi") |]

mkNameL :: String -> Uniq -> NameSource#

Only used internally

unTypeQ :: forall (r :: RuntimeRep) (a :: TYPE r). Q (TExp a) -> QExpSource#

Discard the type annotation and produce a plain Template Haskell expression

Levity-polymorphic since template-haskell-2.16.0.0.

unsafeTExpCoerce :: forall (r :: RuntimeRep) (a :: TYPE r). QExp -> Q (TExp a) Source#

Annotate the Template Haskell expression with a type

This is unsafe because GHC cannot check for you that the expression really does have the type you claim it has.

Levity-polymorphic since template-haskell-2.16.0.0.

classLift (t :: TYPE r) whereSource#

A Lift instance can have any of its values turned into a Template Haskell expression. This is needed when a value used within a Template Haskell quotation is bound outside the Oxford brackets ([| ... |] or [|| ... ||]) but not at the top level. As an example:

add1 :: Int -> Q (TExp Int) add1 x = [|| x + 1 ||]

Template Haskell has no way of knowing what value x will take on at splice-time, so it requires the type of x to be an instance of Lift.

A Lift instance must satisfy $(lift x) ≡ x and $$(liftTyped x) ≡ x for all x, where $(...) and $$(...) are Template Haskell splices. It is additionally expected that lift x ≡ unTypeQ (liftTyped x).

Lift instances can be derived automatically by use of the -XDeriveLift GHC language extension:

{-# LANGUAGE DeriveLift #-} module Foo where import Language.Haskell.TH.Syntax data Bar a = Bar1 a (Bar a) | Bar2 String deriving Lift

Levity-polymorphic since template-haskell-2.16.0.0.

Minimal complete definition

liftTyped

Methods

lift :: t -> QExpSource#

Turn a value into a Template Haskell expression, suitable for use in a splice.

defaultlift :: r ~ 'LiftedRep => t -> QExpSource#

liftTyped :: t -> Q (TExp t) Source#

Turn a value into a Template Haskell typed expression, suitable for use in a typed splice.

Since: 2.16.0.0

Instances

Instances details
LiftBoolSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftCharSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftDoubleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftFloatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftIntSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftInt8Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftInt16Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftInt32Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftInt64Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftIntegerSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftNaturalSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftWordSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftWord8Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftWord16Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftWord32Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

LiftWord64Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Lift ()Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: () -> QExpSource#

liftTyped :: () -> Q (TExp ()) Source#

LiftVoidSource#

Since: 2.15.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

LiftInt#Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

LiftChar#Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

LiftWord#Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

LiftAddr#Source#

Produces an Addr# literal from the NUL-terminated C-string starting at the given memory address.

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

LiftFloat#Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

LiftDouble#Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Lift a => Lift ([a] :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: [a] -> QExpSource#

liftTyped :: [a] -> Q (TExp [a]) Source#

Lift a => Lift (Maybe a :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Maybe a -> QExpSource#

liftTyped :: Maybe a -> Q (TExp (Maybe a)) Source#

Integral a => Lift (Ratio a :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Ratio a -> QExpSource#

liftTyped :: Ratio a -> Q (TExp (Ratio a)) Source#

Lift a => Lift (NonEmpty a :: Type)Source#

Since: 2.15.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

(Lift a, Lift b) => Lift (Either a b :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Either a b -> QExpSource#

liftTyped :: Either a b -> Q (TExp (Either a b)) Source#

(Lift a, Lift b) => Lift ((a, b) :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (a, b) -> QExpSource#

liftTyped :: (a, b) -> Q (TExp (a, b)) Source#

(Lift a, Lift b, Lift c) => Lift ((a, b, c) :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (a, b, c) -> QExpSource#

liftTyped :: (a, b, c) -> Q (TExp (a, b, c)) Source#

(Lift a, Lift b, Lift c, Lift d) => Lift ((a, b, c, d) :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (a, b, c, d) -> QExpSource#

liftTyped :: (a, b, c, d) -> Q (TExp (a, b, c, d)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e) => Lift ((a, b, c, d, e) :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (a, b, c, d, e) -> QExpSource#

liftTyped :: (a, b, c, d, e) -> Q (TExp (a, b, c, d, e)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e, Lift f) => Lift ((a, b, c, d, e, f) :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (a, b, c, d, e, f) -> QExpSource#

liftTyped :: (a, b, c, d, e, f) -> Q (TExp (a, b, c, d, e, f)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e, Lift f, Lift g) => Lift ((a, b, c, d, e, f, g) :: Type)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (a, b, c, d, e, f, g) -> QExpSource#

liftTyped :: (a, b, c, d, e, f, g) -> Q (TExp (a, b, c, d, e, f, g)) Source#

Lift (# #)Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# #) -> QExpSource#

liftTyped :: (# #) -> Q (TExp (# #)) Source#

Lift a => Lift ((# a #) :: TYPE ('TupleRep '['LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a #) -> QExpSource#

liftTyped :: (# a #) -> Q (TExp (# a #)) Source#

(Lift a, Lift b) => Lift ((# a, b #) :: TYPE ('TupleRep '['LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a, b #) -> QExpSource#

liftTyped :: (# a, b #) -> Q (TExp (# a, b #)) Source#

(Lift a, Lift b) => Lift ((# a | b #) :: TYPE ('SumRep '['LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a | b #) -> QExpSource#

liftTyped :: (# a | b #) -> Q (TExp (# a | b #)) Source#

(Lift a, Lift b, Lift c) => Lift ((# a, b, c #) :: TYPE ('TupleRep '['LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a, b, c #) -> QExpSource#

liftTyped :: (# a, b, c #) -> Q (TExp (# a, b, c #)) Source#

(Lift a, Lift b, Lift c) => Lift ((# a | b | c #) :: TYPE ('SumRep '['LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a | b | c #) -> QExpSource#

liftTyped :: (# a | b | c #) -> Q (TExp (# a | b | c #)) Source#

(Lift a, Lift b, Lift c, Lift d) => Lift ((# a, b, c, d #) :: TYPE ('TupleRep '['LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a, b, c, d #) -> QExpSource#

liftTyped :: (# a, b, c, d #) -> Q (TExp (# a, b, c, d #)) Source#

(Lift a, Lift b, Lift c, Lift d) => Lift ((# a | b | c | d #) :: TYPE ('SumRep '['LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a | b | c | d #) -> QExpSource#

liftTyped :: (# a | b | c | d #) -> Q (TExp (# a | b | c | d #)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e) => Lift ((# a, b, c, d, e #) :: TYPE ('TupleRep '['LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a, b, c, d, e #) -> QExpSource#

liftTyped :: (# a, b, c, d, e #) -> Q (TExp (# a, b, c, d, e #)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e) => Lift ((# a | b | c | d | e #) :: TYPE ('SumRep '['LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a | b | c | d | e #) -> QExpSource#

liftTyped :: (# a | b | c | d | e #) -> Q (TExp (# a | b | c | d | e #)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e, Lift f) => Lift ((# a, b, c, d, e, f #) :: TYPE ('TupleRep '['LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a, b, c, d, e, f #) -> QExpSource#

liftTyped :: (# a, b, c, d, e, f #) -> Q (TExp (# a, b, c, d, e, f #)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e, Lift f) => Lift ((# a | b | c | d | e | f #) :: TYPE ('SumRep '['LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a | b | c | d | e | f #) -> QExpSource#

liftTyped :: (# a | b | c | d | e | f #) -> Q (TExp (# a | b | c | d | e | f #)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e, Lift f, Lift g) => Lift ((# a, b, c, d, e, f, g #) :: TYPE ('TupleRep '['LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a, b, c, d, e, f, g #) -> QExpSource#

liftTyped :: (# a, b, c, d, e, f, g #) -> Q (TExp (# a, b, c, d, e, f, g #)) Source#

(Lift a, Lift b, Lift c, Lift d, Lift e, Lift f, Lift g) => Lift ((# a | b | c | d | e | f | g #) :: TYPE ('SumRep '['LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep, 'LiftedRep]))Source#

Since: 2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: (# a | b | c | d | e | f | g #) -> QExpSource#

liftTyped :: (# a | b | c | d | e | f | g #) -> Q (TExp (# a | b | c | d | e | f | g #)) Source#

dataExpSource#

Constructors

VarEName
{ x }
ConEName
data T1 = C1 t1 t2; p = {C1} e1 e2
LitELit
{ 5 or 'c'}
AppEExpExp
{ f x }
AppTypeEExpType
{ f @Int }
InfixE (MaybeExp) Exp (MaybeExp)
{x + y} or {(x+)} or {(+ x)} or {(+)}
UInfixEExpExpExp
{x + y}

See Language.Haskell.TH.Syntax

ParensEExp
{ (e) }

See Language.Haskell.TH.Syntax

LamE [Pat] Exp
{ \ p1 p2 -> e }
LamCaseE [Match]
{ \case m1; m2 }
TupE [MaybeExp]
{ (e1,e2) }

The Maybe is necessary for handling tuple sections.

(1,)

translates to

TupE [Just (LitE (IntegerL 1)),Nothing]
UnboxedTupE [MaybeExp]
{ (# e1,e2 #) }

The Maybe is necessary for handling tuple sections.

(# 'c', #)

translates to

UnboxedTupE [Just (LitE (CharL 'c')),Nothing]
UnboxedSumEExpSumAltSumArity
{ (#|e|#) }
CondEExpExpExp
{ if e1 then e2 else e3 }
MultiIfE [(Guard, Exp)]
{ if | g1 -> e1 | g2 -> e2 }
LetE [Dec] Exp
{ let { x=e1; y=e2 } in e3 }
CaseEExp [Match]
{ case e of m1; m2 }
DoE [Stmt]
{ do { p <- e1; e2 } }
MDoE [Stmt]
{ mdo { x <- e1 y; y <- e2 x; } }
CompE [Stmt]
{ [ (x,y) | x <- xs, y <- ys ] }

The result expression of the comprehension is the last of the Stmts, and should be a NoBindS.

E.g. translation:

[ f x | x <- xs ]
CompE [BindS (VarP x) (VarE xs), NoBindS (AppE (VarE f) (VarE x))]
ArithSeqERange
{ [ 1 ,2 .. 10 ] }
ListE [Exp]
{ [1,2,3] }
SigEExpType
{ e :: t }
RecConEName [FieldExp]
{ T { x = y, z = w } }
RecUpdEExp [FieldExp]
{ (f x) { z = w } }
StaticEExp
{ static e }
UnboundVarEName
{ _x }

This is used for holes or unresolved identifiers in AST quotes. Note that it could either have a variable name or constructor name.

LabelEString

{ #x } ( Overloaded label )

ImplicitParamVarEString

{ ?x } ( Implicit parameter )

Instances

Instances details
EqExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Exp -> Exp -> Bool#

(/=) :: Exp -> Exp -> Bool#

DataExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Exp -> c Exp#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Exp#

toConstr :: Exp -> Constr#

dataTypeOf :: Exp -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Exp) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Exp) #

gmapT :: (forall b. Data b => b -> b) -> Exp -> Exp#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Exp -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Exp -> r #

gmapQ :: (forall d. Data d => d -> u) -> Exp -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Exp -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Exp -> m Exp#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Exp -> m Exp#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Exp -> m Exp#

OrdExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Exp -> Exp -> Ordering#

(<) :: Exp -> Exp -> Bool#

(<=) :: Exp -> Exp -> Bool#

(>) :: Exp -> Exp -> Bool#

(>=) :: Exp -> Exp -> Bool#

max :: Exp -> Exp -> Exp#

min :: Exp -> Exp -> Exp#

ShowExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Exp -> ShowS#

show :: Exp -> String#

showList :: [Exp] -> ShowS#

GenericExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepExp :: Type -> Type#

Methods

from :: Exp -> RepExp x #

to :: RepExp x -> Exp#

PprExpSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

Methods

ppr :: Exp -> DocSource#

ppr_list :: [Exp] -> DocSource#

typeRepExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepExp = D1 ('MetaData "Exp" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((((C1 ('MetaCons "VarE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name)) :+: (C1 ('MetaCons "ConE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name)) :+:C1 ('MetaCons "LitE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Lit)))) :+: ((C1 ('MetaCons "AppE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp)) :+:C1 ('MetaCons "AppTypeE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :+: (C1 ('MetaCons "InfixE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeExp)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeExp)))) :+:C1 ('MetaCons "UInfixE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp)))))) :+: ((C1 ('MetaCons "ParensE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp)) :+: (C1 ('MetaCons "LamE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Pat]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp)) :+:C1 ('MetaCons "LamCaseE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Match])))) :+: ((C1 ('MetaCons "TupE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [MaybeExp])) :+:C1 ('MetaCons "UnboxedTupE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [MaybeExp]))) :+: (C1 ('MetaCons "UnboxedSumE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0SumAlt) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0SumArity))) :+:C1 ('MetaCons "CondE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp))))))) :+: (((C1 ('MetaCons "MultiIfE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [(Guard, Exp)])) :+: (C1 ('MetaCons "LetE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Dec]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp)) :+:C1 ('MetaCons "CaseE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Match])))) :+: ((C1 ('MetaCons "DoE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Stmt])) :+:C1 ('MetaCons "MDoE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Stmt]))) :+: (C1 ('MetaCons "CompE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Stmt])) :+:C1 ('MetaCons "ArithSeqE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Range))))) :+: (((C1 ('MetaCons "ListE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Exp])) :+:C1 ('MetaCons "SigE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :+: (C1 ('MetaCons "RecConE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [FieldExp])) :+:C1 ('MetaCons "RecUpdE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [FieldExp])))) :+: ((C1 ('MetaCons "StaticE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp)) :+:C1 ('MetaCons "UnboundVarE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name))) :+: (C1 ('MetaCons "LabelE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String)) :+:C1 ('MetaCons "ImplicitParamVarE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String)))))))

dataMatchSource#

Constructors

MatchPatBody [Dec]
case e of { pat -> body where decs }

Instances

Instances details
EqMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Match -> Match -> Bool#

(/=) :: Match -> Match -> Bool#

DataMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Match -> c Match#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Match#

toConstr :: Match -> Constr#

dataTypeOf :: Match -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Match) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Match) #

gmapT :: (forall b. Data b => b -> b) -> Match -> Match#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Match -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Match -> r #

gmapQ :: (forall d. Data d => d -> u) -> Match -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Match -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Match -> m Match#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Match -> m Match#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Match -> m Match#

OrdMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepMatch :: Type -> Type#

Methods

from :: Match -> RepMatch x #

to :: RepMatch x -> Match#

PprMatchSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataClauseSource#

Constructors

Clause [Pat] Body [Dec]
f { p1 p2 = body where decs }

Instances

Instances details
EqClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Clause -> Clause -> Bool#

(/=) :: Clause -> Clause -> Bool#

DataClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Clause -> c Clause#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Clause#

toConstr :: Clause -> Constr#

dataTypeOf :: Clause -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Clause) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Clause) #

gmapT :: (forall b. Data b => b -> b) -> Clause -> Clause#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Clause -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Clause -> r #

gmapQ :: (forall d. Data d => d -> u) -> Clause -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Clause -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Clause -> m Clause#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Clause -> m Clause#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Clause -> m Clause#

OrdClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepClause :: Type -> Type#

Methods

from :: Clause -> RepClause x #

to :: RepClause x -> Clause#

PprClauseSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

newtypeQ a Source#

Constructors

Q 

Fields

Instances

Instances details
MonadQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(>>=) :: Q a -> (a -> Q b) -> Q b #

(>>) :: Q a -> Q b -> Q b #

return :: a -> Q a #

FunctorQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

fmap :: (a -> b) -> Q a -> Q b #

(<$) :: a -> Q b -> Q a #

MonadFailQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

fail :: String -> Q a #

ApplicativeQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

pure :: a -> Q a #

(<*>) :: Q (a -> b) -> Q a -> Q b #

liftA2 :: (a -> b -> c) -> Q a -> Q b -> Q c #

(*>) :: Q a -> Q b -> Q b #

(<*) :: Q a -> Q b -> Q a #

MonadIOQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

liftIO :: IO a -> Q a #

QuasiQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataPatSource#

Pattern in Haskell given in {}

Constructors

LitPLit
{ 5 or 'c' }
VarPName
{ x }
TupP [Pat]
{ (p1,p2) }
UnboxedTupP [Pat]
{ (# p1,p2 #) }
UnboxedSumPPatSumAltSumArity
{ (#|p|#) }
ConPName [Pat]
data T1 = C1 t1 t2; {C1 p1 p1} = e
InfixPPatNamePat
foo ({x :+ y}) = e
UInfixPPatNamePat
foo ({x :+ y}) = e

See Language.Haskell.TH.Syntax

ParensPPat
{(p)}

See Language.Haskell.TH.Syntax

TildePPat
{ ~p }
BangPPat
{ !p }
AsPNamePat
{ x @ p }
WildP
{ _ }
RecPName [FieldPat]
f (Pt { pointx = x }) = g x
ListP [Pat]
{ [1,2,3] }
SigPPatType
{ p :: t }
ViewPExpPat
{ e -> p }

Instances

Instances details
EqPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Pat -> Pat -> Bool#

(/=) :: Pat -> Pat -> Bool#

DataPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Pat -> c Pat#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Pat#

toConstr :: Pat -> Constr#

dataTypeOf :: Pat -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Pat) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Pat) #

gmapT :: (forall b. Data b => b -> b) -> Pat -> Pat#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Pat -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Pat -> r #

gmapQ :: (forall d. Data d => d -> u) -> Pat -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Pat -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Pat -> m Pat#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Pat -> m Pat#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Pat -> m Pat#

OrdPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Pat -> Pat -> Ordering#

(<) :: Pat -> Pat -> Bool#

(<=) :: Pat -> Pat -> Bool#

(>) :: Pat -> Pat -> Bool#

(>=) :: Pat -> Pat -> Bool#

max :: Pat -> Pat -> Pat#

min :: Pat -> Pat -> Pat#

ShowPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Pat -> ShowS#

show :: Pat -> String#

showList :: [Pat] -> ShowS#

GenericPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPat :: Type -> Type#

Methods

from :: Pat -> RepPat x #

to :: RepPat x -> Pat#

PprPatSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

Methods

ppr :: Pat -> DocSource#

ppr_list :: [Pat] -> DocSource#

typeRepPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepPat = D1 ('MetaData "Pat" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((((C1 ('MetaCons "LitP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Lit)) :+:C1 ('MetaCons "VarP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name))) :+: (C1 ('MetaCons "TupP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Pat])) :+:C1 ('MetaCons "UnboxedTupP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Pat])))) :+: ((C1 ('MetaCons "UnboxedSumP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0SumAlt) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0SumArity))) :+:C1 ('MetaCons "ConP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Pat]))) :+: (C1 ('MetaCons "InfixP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat))) :+:C1 ('MetaCons "UInfixP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat)))))) :+: (((C1 ('MetaCons "ParensP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat)) :+:C1 ('MetaCons "TildeP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat))) :+: (C1 ('MetaCons "BangP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat)) :+:C1 ('MetaCons "AsP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat)))) :+: ((C1 ('MetaCons "WildP" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "RecP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [FieldPat]))) :+: (C1 ('MetaCons "ListP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Pat])) :+: (C1 ('MetaCons "SigP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)) :+:C1 ('MetaCons "ViewP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat)))))))

dataTypeSource#

Instances

Instances details
EqTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Type -> Type -> Bool#

(/=) :: Type -> Type -> Bool#

DataTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Type -> c Type#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Type#

toConstr :: Type -> Constr#

dataTypeOf :: Type -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Type) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Type) #

gmapT :: (forall b. Data b => b -> b) -> Type -> Type#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Type -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Type -> r #

gmapQ :: (forall d. Data d => d -> u) -> Type -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Type -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Type -> m Type#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Type -> m Type#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Type -> m Type#

OrdTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Type -> Type -> Ordering#

(<) :: Type -> Type -> Bool#

(<=) :: Type -> Type -> Bool#

(>) :: Type -> Type -> Bool#

(>=) :: Type -> Type -> Bool#

max :: Type -> Type -> Type#

min :: Type -> Type -> Type#

ShowTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Type -> ShowS#

show :: Type -> String#

showList :: [Type] -> ShowS#

GenericTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepType :: Type -> Type#

Methods

from :: Type -> RepType x #

to :: RepType x -> Type#

PprTypeSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepType = D1 ('MetaData "Type" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((((C1 ('MetaCons "ForallT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TyVarBndr]) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :+: (C1 ('MetaCons "ForallVisT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TyVarBndr]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)) :+:C1 ('MetaCons "AppT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)))) :+: (C1 ('MetaCons "AppKindT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Kind)) :+: (C1 ('MetaCons "SigT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Kind)) :+:C1 ('MetaCons "VarT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name))))) :+: ((C1 ('MetaCons "ConT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name)) :+: (C1 ('MetaCons "PromotedT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name)) :+:C1 ('MetaCons "InfixT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))))) :+: (C1 ('MetaCons "UInfixT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :+: (C1 ('MetaCons "ParensT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)) :+:C1 ('MetaCons "TupleT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Int)))))) :+: (((C1 ('MetaCons "UnboxedTupleT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Int)) :+: (C1 ('MetaCons "UnboxedSumT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0SumArity)) :+:C1 ('MetaCons "ArrowT" 'PrefixI 'False) (U1 :: Type -> Type))) :+: (C1 ('MetaCons "EqualityT" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "ListT" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "PromotedTupleT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Int))))) :+: ((C1 ('MetaCons "PromotedNilT" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "PromotedConsT" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "StarT" 'PrefixI 'False) (U1 :: Type -> Type))) :+: ((C1 ('MetaCons "ConstraintT" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "LitT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0TyLit))) :+: (C1 ('MetaCons "WildCardT" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "ImplicitParamT" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)))))))

dataDecSource#

Constructors

FunDName [Clause]
{ f p1 p2 = b where decs }
ValDPatBody [Dec]
{ p = b where decs }
DataDCxtName [TyVarBndr] (MaybeKind) [Con] [DerivClause]
{ data Cxt x => T x = A x | B (T x) deriving (Z,W) deriving stock Eq }
NewtypeDCxtName [TyVarBndr] (MaybeKind) Con [DerivClause]
{ newtype Cxt x => T x = A (B x) deriving (Z,W Q) deriving stock Eq }
TySynDName [TyVarBndr] Type
{ type T x = (x,x) }
ClassDCxtName [TyVarBndr] [FunDep] [Dec]
{ class Eq a => Ord a where ds }
InstanceD (MaybeOverlap) CxtType [Dec]
{ instance {-# OVERLAPS #-} Show w => Show [w] where ds }
SigDNameType
{ length :: [a] -> Int }
KiSigDNameKind
{ type TypeRep :: k -> Type }
ForeignDForeign
{ foreign import ... } { foreign export ... }
InfixDFixityName
{ infix 3 foo }
PragmaDPragma
{ {-# INLINE [1] foo #-} }
DataFamilyDName [TyVarBndr] (MaybeKind)
{ data family T a b c :: * }
DataInstDCxt (Maybe [TyVarBndr]) Type (MaybeKind) [Con] [DerivClause]
{ data instance Cxt x => T [x] = A x | B (T x) deriving (Z,W) deriving stock Eq }
NewtypeInstDCxt (Maybe [TyVarBndr]) Type (MaybeKind) Con [DerivClause]
{ newtype instance Cxt x => T [x] = A (B x) deriving (Z,W) deriving stock Eq }
TySynInstDTySynEqn
{ type instance ... }
OpenTypeFamilyDTypeFamilyHead
{ type family T a b c = (r :: *) | r -> a b }
ClosedTypeFamilyDTypeFamilyHead [TySynEqn]
{ type family F a b = (r :: *) | r -> a where ... }
RoleAnnotDName [Role]
{ type role T nominal representational }
StandaloneDerivD (MaybeDerivStrategy) CxtType
{ deriving stock instance Ord a => Ord (Foo a) }
DefaultSigDNameType
{ default size :: Data a => a -> Int }
PatSynDNamePatSynArgsPatSynDirPat

{ pattern P v1 v2 .. vn <- p } unidirectional or { pattern P v1 v2 .. vn = p } implicit bidirectional or { pattern P v1 v2 .. vn <- p where P v1 v2 .. vn = e } explicit bidirectional

also, besides prefix pattern synonyms, both infix and record pattern synonyms are supported. See PatSynArgs for details

PatSynSigDNamePatSynType

A pattern synonym's type signature.

ImplicitParamBindDStringExp
{ ?x = expr }

Implicit parameter binding declaration. Can only be used in let and where clauses which consist entirely of implicit bindings.

Instances

Instances details
EqDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Dec -> Dec -> Bool#

(/=) :: Dec -> Dec -> Bool#

DataDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Dec -> c Dec#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Dec#

toConstr :: Dec -> Constr#

dataTypeOf :: Dec -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Dec) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Dec) #

gmapT :: (forall b. Data b => b -> b) -> Dec -> Dec#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Dec -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Dec -> r #

gmapQ :: (forall d. Data d => d -> u) -> Dec -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Dec -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Dec -> m Dec#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Dec -> m Dec#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Dec -> m Dec#

OrdDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Dec -> Dec -> Ordering#

(<) :: Dec -> Dec -> Bool#

(<=) :: Dec -> Dec -> Bool#

(>) :: Dec -> Dec -> Bool#

(>=) :: Dec -> Dec -> Bool#

max :: Dec -> Dec -> Dec#

min :: Dec -> Dec -> Dec#

ShowDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Dec -> ShowS#

show :: Dec -> String#

showList :: [Dec] -> ShowS#

GenericDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDec :: Type -> Type#

Methods

from :: Dec -> RepDec x #

to :: RepDec x -> Dec#

PprDecSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

Methods

ppr :: Dec -> DocSource#

ppr_list :: [Dec] -> DocSource#

typeRepDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepDec = D1 ('MetaData "Dec" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((((C1 ('MetaCons "FunD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Clause])) :+: (C1 ('MetaCons "ValD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Body) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Dec]))) :+:C1 ('MetaCons "DataD" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TyVarBndr]))) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeKind)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Con]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [DerivClause])))))) :+: (C1 ('MetaCons "NewtypeD" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TyVarBndr]))) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeKind)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Con) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [DerivClause])))) :+: (C1 ('MetaCons "TySynD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TyVarBndr]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :+:C1 ('MetaCons "ClassD" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TyVarBndr]) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [FunDep]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Dec]))))))) :+: ((C1 ('MetaCons "InstanceD" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeOverlap)) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Dec]))) :+: (C1 ('MetaCons "SigD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)) :+:C1 ('MetaCons "KiSigD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Kind)))) :+: (C1 ('MetaCons "ForeignD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Foreign)) :+: (C1 ('MetaCons "InfixD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Fixity) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name)) :+:C1 ('MetaCons "PragmaD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pragma)))))) :+: (((C1 ('MetaCons "DataFamilyD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TyVarBndr]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeKind)))) :+: (C1 ('MetaCons "DataInstD" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (Maybe [TyVarBndr])) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeKind)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Con]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [DerivClause])))) :+:C1 ('MetaCons "NewtypeInstD" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (Maybe [TyVarBndr])) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeKind)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Con) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [DerivClause])))))) :+: (C1 ('MetaCons "TySynInstD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0TySynEqn)) :+: (C1 ('MetaCons "OpenTypeFamilyD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0TypeFamilyHead)) :+:C1 ('MetaCons "ClosedTypeFamilyD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0TypeFamilyHead) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TySynEqn]))))) :+: ((C1 ('MetaCons "RoleAnnotD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Role])) :+: (C1 ('MetaCons "StandaloneDerivD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeDerivStrategy)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :+:C1 ('MetaCons "DefaultSigD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)))) :+: (C1 ('MetaCons "PatSynD" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0PatSynArgs)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0PatSynDir) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Pat))) :+: (C1 ('MetaCons "PatSynSigD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0PatSynType)) :+:C1 ('MetaCons "ImplicitParamBindD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp)))))))

dataNameSource#

An abstract type representing names in the syntax tree.

Names can be constructed in several ways, which come with different name-capture guarantees (see Language.Haskell.TH.Syntax for an explanation of name capture):

  • the built-in syntax 'f and ''T can be used to construct names, The expression 'f gives a Name which refers to the value f currently in scope, and ''T gives a Name which refers to the type T currently in scope. These names can never be captured.
  • lookupValueName and lookupTypeName are similar to 'f and ''T respectively, but the Names are looked up at the point where the current splice is being run. These names can never be captured.
  • newName monadically generates a new name, which can never be captured.
  • mkName generates a capturable name.

Names constructed using newName and mkName may be used in bindings (such as let x = ... or x -> ...), but names constructed using lookupValueName, lookupTypeName, 'f, ''T may not.

Instances

Instances details
EqNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Name -> Name -> Bool#

(/=) :: Name -> Name -> Bool#

DataNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Name -> c Name#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Name#

toConstr :: Name -> Constr#

dataTypeOf :: Name -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Name) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Name) #

gmapT :: (forall b. Data b => b -> b) -> Name -> Name#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Name -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Name -> r #

gmapQ :: (forall d. Data d => d -> u) -> Name -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Name -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Name -> m Name#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Name -> m Name#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Name -> m Name#

OrdNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Name -> Name -> Ordering#

(<) :: Name -> Name -> Bool#

(<=) :: Name -> Name -> Bool#

(>) :: Name -> Name -> Bool#

(>=) :: Name -> Name -> Bool#

max :: Name -> Name -> Name#

min :: Name -> Name -> Name#

ShowNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Name -> ShowS#

show :: Name -> String#

showList :: [Name] -> ShowS#

GenericNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepName :: Type -> Type#

Methods

from :: Name -> RepName x #

to :: RepName x -> Name#

PprNameSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataFunDepSource#

Constructors

FunDep [Name] [Name] 

Instances

Instances details
EqFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: FunDep -> FunDep -> Bool#

(/=) :: FunDep -> FunDep -> Bool#

DataFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> FunDep -> c FunDep#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c FunDep#

toConstr :: FunDep -> Constr#

dataTypeOf :: FunDep -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c FunDep) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c FunDep) #

gmapT :: (forall b. Data b => b -> b) -> FunDep -> FunDep#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> FunDep -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> FunDep -> r #

gmapQ :: (forall d. Data d => d -> u) -> FunDep -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> FunDep -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> FunDep -> m FunDep#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> FunDep -> m FunDep#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> FunDep -> m FunDep#

OrdFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepFunDep :: Type -> Type#

Methods

from :: FunDep -> RepFunDep x #

to :: RepFunDep x -> FunDep#

PprFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typePred = TypeSource#

Since the advent of ConstraintKinds, constraints are really just types. Equality constraints use the EqualityT constructor. Constraints may also be tuples of other constraints.

newtypeTExp (a :: TYPE (r :: RuntimeRep)) Source#

Represents an expression which has type a. Built on top of Exp, typed expressions allow for type-safe splicing via:

  • typed quotes, written as [|| ... ||] where ... is an expression; if that expression has type a, then the quotation has type Q (TExp a)
  • typed splices inside of typed quotes, written as $$(...) where ... is an arbitrary expression of type Q (TExp a)

Traditional expression quotes and splices let us construct ill-typed expressions:

>>> fmap ppr $ runQ [| True == $( [| "foo" |] ) |] GHC.Types.True GHC.Classes.== "foo" >>> GHC.Types.True GHC.Classes.== "foo" <interactive> error: • Couldn't match expected type ‘Bool’ with actual type ‘[Char]’ • In the second argument of ‘(==)’, namely ‘"foo"’ In the expression: True == "foo" In an equation for ‘it’: it = True == "foo" 

With typed expressions, the type error occurs when constructing the Template Haskell expression:

>>> fmap ppr $ runQ [|| True == $$( [|| "foo" ||] ) ||] <interactive> error: • Couldn't match type ‘[Char]’ with ‘Bool’ Expected type: Q (TExp Bool) Actual type: Q (TExp [Char]) • In the Template Haskell quotation [|| "foo" ||] In the expression: [|| "foo" ||] In the Template Haskell splice $$([|| "foo" ||]) 

Constructors

TExp 

Fields

  • unType :: Exp

    Underlying untyped Template Haskell expression

dataInjectivityAnnSource#

Injectivity annotation

Constructors

InjectivityAnnName [Name] 

Instances

Instances details
EqInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> InjectivityAnn -> c InjectivityAnn#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c InjectivityAnn#

toConstr :: InjectivityAnn -> Constr#

dataTypeOf :: InjectivityAnn -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c InjectivityAnn) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c InjectivityAnn) #

gmapT :: (forall b. Data b => b -> b) -> InjectivityAnn -> InjectivityAnn#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> InjectivityAnn -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> InjectivityAnn -> r #

gmapQ :: (forall d. Data d => d -> u) -> InjectivityAnn -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> InjectivityAnn -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> InjectivityAnn -> m InjectivityAnn#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> InjectivityAnn -> m InjectivityAnn#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> InjectivityAnn -> m InjectivityAnn#

OrdInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepInjectivityAnn :: Type -> Type#

PprInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepInjectivityAnn = D1 ('MetaData "InjectivityAnn" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "InjectivityAnn" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Name])))

dataOverlapSource#

Varieties of allowed instance overlap.

Constructors

Overlappable

May be overlapped by more specific instances

Overlapping

May overlap a more general instance

Overlaps

Both Overlapping and Overlappable

Incoherent

Both Overlappable and Overlappable, and pick an arbitrary one if multiple choices are available.

Instances

Instances details
EqOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Overlap -> Overlap -> Bool#

(/=) :: Overlap -> Overlap -> Bool#

DataOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Overlap -> c Overlap#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Overlap#

toConstr :: Overlap -> Constr#

dataTypeOf :: Overlap -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Overlap) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Overlap) #

gmapT :: (forall b. Data b => b -> b) -> Overlap -> Overlap#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Overlap -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Overlap -> r #

gmapQ :: (forall d. Data d => d -> u) -> Overlap -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Overlap -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Overlap -> m Overlap#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Overlap -> m Overlap#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Overlap -> m Overlap#

OrdOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepOverlap :: Type -> Type#

Methods

from :: Overlap -> RepOverlap x #

to :: RepOverlap x -> Overlap#

typeRepOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepOverlap = D1 ('MetaData "Overlap" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((C1 ('MetaCons "Overlappable" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "Overlapping" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "Overlaps" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "Incoherent" 'PrefixI 'False) (U1 :: Type -> Type)))

typeKind = TypeSource#

To avoid duplication between kinds and types, they are defined to be the same. Naturally, you would never have a type be StarT and you would never have a kind be SigT, but many of the other constructors are shared. Note that the kind Bool is denoted with ConT, not PromotedT. Similarly, tuple kinds are made with TupleT, not PromotedTupleT.

dataAnnLookupSource#

Annotation target for reifyAnnotations

Instances

Instances details
EqAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> AnnLookup -> c AnnLookup#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c AnnLookup#

toConstr :: AnnLookup -> Constr#

dataTypeOf :: AnnLookup -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c AnnLookup) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c AnnLookup) #

gmapT :: (forall b. Data b => b -> b) -> AnnLookup -> AnnLookup#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> AnnLookup -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> AnnLookup -> r #

gmapQ :: (forall d. Data d => d -> u) -> AnnLookup -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> AnnLookup -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> AnnLookup -> m AnnLookup#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> AnnLookup -> m AnnLookup#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> AnnLookup -> m AnnLookup#

OrdAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepAnnLookup :: Type -> Type#

typeRepAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepAnnLookup = D1 ('MetaData "AnnLookup" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "AnnLookupModule" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Module)) :+:C1 ('MetaCons "AnnLookupName" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name)))

dataRoleSource#

Role annotations

Constructors

NominalR
nominal
RepresentationalR
representational
PhantomR
phantom
InferR
_

Instances

Instances details
EqRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Role -> Role -> Bool#

(/=) :: Role -> Role -> Bool#

DataRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Role -> c Role#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Role#

toConstr :: Role -> Constr#

dataTypeOf :: Role -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Role) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Role) #

gmapT :: (forall b. Data b => b -> b) -> Role -> Role#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Role -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Role -> r #

gmapQ :: (forall d. Data d => d -> u) -> Role -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Role -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Role -> m Role#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Role -> m Role#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Role -> m Role#

OrdRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Role -> Role -> Ordering#

(<) :: Role -> Role -> Bool#

(<=) :: Role -> Role -> Bool#

(>) :: Role -> Role -> Bool#

(>=) :: Role -> Role -> Bool#

max :: Role -> Role -> Role#

min :: Role -> Role -> Role#

ShowRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Role -> ShowS#

show :: Role -> String#

showList :: [Role] -> ShowS#

GenericRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepRole :: Type -> Type#

Methods

from :: Role -> RepRole x #

to :: RepRole x -> Role#

PprRoleSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepRole = D1 ('MetaData "Role" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((C1 ('MetaCons "NominalR" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "RepresentationalR" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "PhantomR" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "InferR" 'PrefixI 'False) (U1 :: Type -> Type)))

dataTyLitSource#

Constructors

NumTyLitInteger
2
StrTyLitString
"Hello"

Instances

Instances details
EqTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: TyLit -> TyLit -> Bool#

(/=) :: TyLit -> TyLit -> Bool#

DataTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> TyLit -> c TyLit#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c TyLit#

toConstr :: TyLit -> Constr#

dataTypeOf :: TyLit -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c TyLit) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c TyLit) #

gmapT :: (forall b. Data b => b -> b) -> TyLit -> TyLit#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> TyLit -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> TyLit -> r #

gmapQ :: (forall d. Data d => d -> u) -> TyLit -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> TyLit -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> TyLit -> m TyLit#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> TyLit -> m TyLit#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> TyLit -> m TyLit#

OrdTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepTyLit :: Type -> Type#

Methods

from :: TyLit -> RepTyLit x #

to :: RepTyLit x -> TyLit#

PprTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataFamilyResultSigSource#

Type family result signature

Constructors

NoSig

no signature

KindSigKind
k
TyVarSigTyVarBndr
= r, = (r :: k)

Instances

Instances details
EqFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> FamilyResultSig -> c FamilyResultSig#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c FamilyResultSig#

toConstr :: FamilyResultSig -> Constr#

dataTypeOf :: FamilyResultSig -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c FamilyResultSig) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c FamilyResultSig) #

gmapT :: (forall b. Data b => b -> b) -> FamilyResultSig -> FamilyResultSig#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> FamilyResultSig -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> FamilyResultSig -> r #

gmapQ :: (forall d. Data d => d -> u) -> FamilyResultSig -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> FamilyResultSig -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> FamilyResultSig -> m FamilyResultSig#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> FamilyResultSig -> m FamilyResultSig#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> FamilyResultSig -> m FamilyResultSig#

OrdFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepFamilyResultSig :: Type -> Type#

PprFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepFamilyResultSig = D1 ('MetaData "FamilyResultSig" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "NoSig" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "KindSig" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Kind)) :+:C1 ('MetaCons "TyVarSig" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0TyVarBndr))))

dataTyVarBndrSource#

Constructors

PlainTVName
a
KindedTVNameKind
(a :: k)

Instances

Instances details
EqTyVarBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataTyVarBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> TyVarBndr -> c TyVarBndr#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c TyVarBndr#

toConstr :: TyVarBndr -> Constr#

dataTypeOf :: TyVarBndr -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c TyVarBndr) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c TyVarBndr) #

gmapT :: (forall b. Data b => b -> b) -> TyVarBndr -> TyVarBndr#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> TyVarBndr -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> TyVarBndr -> r #

gmapQ :: (forall d. Data d => d -> u) -> TyVarBndr -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> TyVarBndr -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> TyVarBndr -> m TyVarBndr#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> TyVarBndr -> m TyVarBndr#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> TyVarBndr -> m TyVarBndr#

OrdTyVarBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowTyVarBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericTyVarBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepTyVarBndr :: Type -> Type#

PprTyVarBndrSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepTyVarBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataPatSynArgsSource#

A pattern synonym's argument type.

Constructors

PrefixPatSyn [Name]
pattern P {x y z} = p
InfixPatSynNameName
pattern {x P y} = p
RecordPatSyn [Name]
pattern P { {x,y,z} } = p

Instances

Instances details
EqPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> PatSynArgs -> c PatSynArgs#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c PatSynArgs#

toConstr :: PatSynArgs -> Constr#

dataTypeOf :: PatSynArgs -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c PatSynArgs) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c PatSynArgs) #

gmapT :: (forall b. Data b => b -> b) -> PatSynArgs -> PatSynArgs#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> PatSynArgs -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> PatSynArgs -> r #

gmapQ :: (forall d. Data d => d -> u) -> PatSynArgs -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> PatSynArgs -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> PatSynArgs -> m PatSynArgs#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> PatSynArgs -> m PatSynArgs#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> PatSynArgs -> m PatSynArgs#

OrdPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPatSynArgs :: Type -> Type#

PprPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataPatSynDirSource#

A pattern synonym's directionality.

Constructors

Unidir
pattern P x {<-} p
ImplBidir
pattern P x {=} p
ExplBidir [Clause]
pattern P x {<-} p where P x = e

Instances

Instances details
EqPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> PatSynDir -> c PatSynDir#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c PatSynDir#

toConstr :: PatSynDir -> Constr#

dataTypeOf :: PatSynDir -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c PatSynDir) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c PatSynDir) #

gmapT :: (forall b. Data b => b -> b) -> PatSynDir -> PatSynDir#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> PatSynDir -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> PatSynDir -> r #

gmapQ :: (forall d. Data d => d -> u) -> PatSynDir -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> PatSynDir -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> PatSynDir -> m PatSynDir#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> PatSynDir -> m PatSynDir#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> PatSynDir -> m PatSynDir#

OrdPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPatSynDir :: Type -> Type#

PprPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepPatSynDir = D1 ('MetaData "PatSynDir" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "Unidir" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "ImplBidir" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "ExplBidir" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Clause]))))

typeVarStrictType = VarBangTypeSource#

As of template-haskell-2.11.0.0, VarStrictType has been replaced by VarBangType.

typeStrictType = BangTypeSource#

As of template-haskell-2.11.0.0, StrictType has been replaced by BangType.

typeStrict = BangSource#

As of template-haskell-2.11.0.0, Strict has been replaced by Bang.

dataBangSource#

Constructors

BangSourceUnpackednessSourceStrictness
C { {-# UNPACK #-} !}a

Instances

Instances details
EqBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Bang -> Bang -> Bool#

(/=) :: Bang -> Bang -> Bool#

DataBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Bang -> c Bang#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Bang#

toConstr :: Bang -> Constr#

dataTypeOf :: Bang -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Bang) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Bang) #

gmapT :: (forall b. Data b => b -> b) -> Bang -> Bang#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Bang -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Bang -> r #

gmapQ :: (forall d. Data d => d -> u) -> Bang -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Bang -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Bang -> m Bang#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Bang -> m Bang#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Bang -> m Bang#

OrdBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Bang -> Bang -> Ordering#

(<) :: Bang -> Bang -> Bool#

(<=) :: Bang -> Bang -> Bool#

(>) :: Bang -> Bang -> Bool#

(>=) :: Bang -> Bang -> Bool#

max :: Bang -> Bang -> Bang#

min :: Bang -> Bang -> Bang#

ShowBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Bang -> ShowS#

show :: Bang -> String#

showList :: [Bang] -> ShowS#

GenericBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepBang :: Type -> Type#

Methods

from :: Bang -> RepBang x #

to :: RepBang x -> Bang#

PprBangSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataConSource#

A single data constructor.

The constructors for Con can roughly be divided up into two categories: those for constructors with "vanilla" syntax (NormalC, RecC, and InfixC), and those for constructors with GADT syntax (GadtC and RecGadtC). The ForallC constructor, which quantifies additional type variables and class contexts, can surround either variety of constructor. However, the type variables that it quantifies are different depending on what constructor syntax is used:

  • If a ForallC surrounds a constructor with vanilla syntax, then the ForallC will only quantify existential type variables. For example:
 data Foo a = forall b. MkFoo a b 

In MkFoo, ForallC will quantify b, but not a.

  • If a ForallC surrounds a constructor with GADT syntax, then the ForallC will quantify all type variables used in the constructor. For example:
 data Bar a b where MkBar :: (a ~ b) => c -> MkBar a b 

In MkBar, ForallC will quantify a, b, and c.

Constructors

NormalCName [BangType]
C Int a
RecCName [VarBangType]
C { v :: Int, w :: a }
InfixCBangTypeNameBangType
Int :+ a
ForallC [TyVarBndr] CxtCon
forall a. Eq a => C [a]
GadtC [Name] [BangType] Type
C :: a -> b -> T b Int
RecGadtC [Name] [VarBangType] Type
C :: { v :: Int } -> T b Int

Instances

Instances details
EqConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Con -> Con -> Bool#

(/=) :: Con -> Con -> Bool#

DataConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Con -> c Con#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Con#

toConstr :: Con -> Constr#

dataTypeOf :: Con -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Con) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Con) #

gmapT :: (forall b. Data b => b -> b) -> Con -> Con#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Con -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Con -> r #

gmapQ :: (forall d. Data d => d -> u) -> Con -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Con -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Con -> m Con#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Con -> m Con#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Con -> m Con#

OrdConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Con -> Con -> Ordering#

(<) :: Con -> Con -> Bool#

(<=) :: Con -> Con -> Bool#

(>) :: Con -> Con -> Bool#

(>=) :: Con -> Con -> Bool#

max :: Con -> Con -> Con#

min :: Con -> Con -> Con#

ShowConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Con -> ShowS#

show :: Con -> String#

showList :: [Con] -> ShowS#

GenericConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepCon :: Type -> Type#

Methods

from :: Con -> RepCon x #

to :: RepCon x -> Con#

PprConSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

Methods

ppr :: Con -> DocSource#

ppr_list :: [Con] -> DocSource#

typeRepConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepCon = D1 ('MetaData "Con" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((C1 ('MetaCons "NormalC" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [BangType])) :+: (C1 ('MetaCons "RecC" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [VarBangType])) :+:C1 ('MetaCons "InfixC" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0BangType) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0BangType))))) :+: (C1 ('MetaCons "ForallC" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [TyVarBndr]) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Cxt) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Con))) :+: (C1 ('MetaCons "GadtC" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Name]) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [BangType]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))) :+:C1 ('MetaCons "RecGadtC" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Name]) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [VarBangType]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))))))

dataDecidedStrictnessSource#

Unlike SourceStrictness and SourceUnpackedness, DecidedStrictness refers to the strictness that the compiler chooses for a data constructor field, which may be different from what is written in source code. See reifyConStrictness for more information.

Instances

Instances details
EqDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> DecidedStrictness -> c DecidedStrictness#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c DecidedStrictness#

toConstr :: DecidedStrictness -> Constr#

dataTypeOf :: DecidedStrictness -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c DecidedStrictness) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c DecidedStrictness) #

gmapT :: (forall b. Data b => b -> b) -> DecidedStrictness -> DecidedStrictness#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> DecidedStrictness -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> DecidedStrictness -> r #

gmapQ :: (forall d. Data d => d -> u) -> DecidedStrictness -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> DecidedStrictness -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> DecidedStrictness -> m DecidedStrictness#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> DecidedStrictness -> m DecidedStrictness#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> DecidedStrictness -> m DecidedStrictness#

OrdDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDecidedStrictness :: Type -> Type#

PprDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepDecidedStrictness = D1 ('MetaData "DecidedStrictness" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "DecidedLazy" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "DecidedStrict" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "DecidedUnpack" 'PrefixI 'False) (U1 :: Type -> Type)))

dataSourceStrictnessSource#

Constructors

NoSourceStrictness
C a
SourceLazy
C {~}a
SourceStrict
C {!}a

Instances

Instances details
EqSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> SourceStrictness -> c SourceStrictness#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c SourceStrictness#

toConstr :: SourceStrictness -> Constr#

dataTypeOf :: SourceStrictness -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c SourceStrictness) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c SourceStrictness) #

gmapT :: (forall b. Data b => b -> b) -> SourceStrictness -> SourceStrictness#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> SourceStrictness -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> SourceStrictness -> r #

gmapQ :: (forall d. Data d => d -> u) -> SourceStrictness -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> SourceStrictness -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> SourceStrictness -> m SourceStrictness#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> SourceStrictness -> m SourceStrictness#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> SourceStrictness -> m SourceStrictness#

OrdSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepSourceStrictness :: Type -> Type#

PprSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepSourceStrictness = D1 ('MetaData "SourceStrictness" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "NoSourceStrictness" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "SourceLazy" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "SourceStrict" 'PrefixI 'False) (U1 :: Type -> Type)))

dataSourceUnpackednessSource#

Constructors

NoSourceUnpackedness
C a
SourceNoUnpack
C { {-# NOUNPACK #-} } a
SourceUnpack
C { {-# UNPACK #-} } a

Instances

Instances details
EqSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> SourceUnpackedness -> c SourceUnpackedness#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c SourceUnpackedness#

toConstr :: SourceUnpackedness -> Constr#

dataTypeOf :: SourceUnpackedness -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c SourceUnpackedness) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c SourceUnpackedness) #

gmapT :: (forall b. Data b => b -> b) -> SourceUnpackedness -> SourceUnpackedness#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> SourceUnpackedness -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> SourceUnpackedness -> r #

gmapQ :: (forall d. Data d => d -> u) -> SourceUnpackedness -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> SourceUnpackedness -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> SourceUnpackedness -> m SourceUnpackedness#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> SourceUnpackedness -> m SourceUnpackedness#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> SourceUnpackedness -> m SourceUnpackedness#

OrdSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepSourceUnpackedness :: Type -> Type#

PprSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepSourceUnpackedness = D1 ('MetaData "SourceUnpackedness" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "NoSourceUnpackedness" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "SourceNoUnpack" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "SourceUnpack" 'PrefixI 'False) (U1 :: Type -> Type)))

typeCxtSource#

Arguments

 = [Pred]
(Eq a, Ord b)

dataAnnTargetSource#

Instances

Instances details
EqAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> AnnTarget -> c AnnTarget#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c AnnTarget#

toConstr :: AnnTarget -> Constr#

dataTypeOf :: AnnTarget -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c AnnTarget) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c AnnTarget) #

gmapT :: (forall b. Data b => b -> b) -> AnnTarget -> AnnTarget#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> AnnTarget -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> AnnTarget -> r #

gmapQ :: (forall d. Data d => d -> u) -> AnnTarget -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> AnnTarget -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> AnnTarget -> m AnnTarget#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> AnnTarget -> m AnnTarget#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> AnnTarget -> m AnnTarget#

OrdAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepAnnTarget :: Type -> Type#

typeRepAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepAnnTarget = D1 ('MetaData "AnnTarget" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "ModuleAnnotation" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "TypeAnnotation" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name)) :+:C1 ('MetaCons "ValueAnnotation" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name))))

dataRuleBndrSource#

Instances

Instances details
EqRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> RuleBndr -> c RuleBndr#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c RuleBndr#

toConstr :: RuleBndr -> Constr#

dataTypeOf :: RuleBndr -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c RuleBndr) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c RuleBndr) #

gmapT :: (forall b. Data b => b -> b) -> RuleBndr -> RuleBndr#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> RuleBndr -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> RuleBndr -> r #

gmapQ :: (forall d. Data d => d -> u) -> RuleBndr -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> RuleBndr -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> RuleBndr -> m RuleBndr#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> RuleBndr -> m RuleBndr#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> RuleBndr -> m RuleBndr#

OrdRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepRuleBndr :: Type -> Type#

PprRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataPhasesSource#

Instances

Instances details
EqPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Phases -> Phases -> Bool#

(/=) :: Phases -> Phases -> Bool#

DataPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Phases -> c Phases#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Phases#

toConstr :: Phases -> Constr#

dataTypeOf :: Phases -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Phases) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Phases) #

gmapT :: (forall b. Data b => b -> b) -> Phases -> Phases#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Phases -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Phases -> r #

gmapQ :: (forall d. Data d => d -> u) -> Phases -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Phases -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Phases -> m Phases#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Phases -> m Phases#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Phases -> m Phases#

OrdPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPhases :: Type -> Type#

Methods

from :: Phases -> RepPhases x #

to :: RepPhases x -> Phases#

PprPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepPhases = D1 ('MetaData "Phases" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "AllPhases" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "FromPhase" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Int)) :+:C1 ('MetaCons "BeforePhase" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Int))))

dataRuleMatchSource#

Constructors

ConLike 
FunLike 

Instances

Instances details
EqRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> RuleMatch -> c RuleMatch#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c RuleMatch#

toConstr :: RuleMatch -> Constr#

dataTypeOf :: RuleMatch -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c RuleMatch) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c RuleMatch) #

gmapT :: (forall b. Data b => b -> b) -> RuleMatch -> RuleMatch#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> RuleMatch -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> RuleMatch -> r #

gmapQ :: (forall d. Data d => d -> u) -> RuleMatch -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> RuleMatch -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> RuleMatch -> m RuleMatch#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> RuleMatch -> m RuleMatch#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> RuleMatch -> m RuleMatch#

OrdRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepRuleMatch :: Type -> Type#

PprRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepRuleMatch = D1 ('MetaData "RuleMatch" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "ConLike" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "FunLike" 'PrefixI 'False) (U1 :: Type -> Type))

dataInlineSource#

Constructors

NoInline 
Inline 
Inlinable 

Instances

Instances details
EqInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Inline -> Inline -> Bool#

(/=) :: Inline -> Inline -> Bool#

DataInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Inline -> c Inline#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Inline#

toConstr :: Inline -> Constr#

dataTypeOf :: Inline -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Inline) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Inline) #

gmapT :: (forall b. Data b => b -> b) -> Inline -> Inline#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Inline -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Inline -> r #

gmapQ :: (forall d. Data d => d -> u) -> Inline -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Inline -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Inline -> m Inline#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Inline -> m Inline#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Inline -> m Inline#

OrdInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepInline :: Type -> Type#

Methods

from :: Inline -> RepInline x #

to :: RepInline x -> Inline#

PprInlineSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepInline = D1 ('MetaData "Inline" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "NoInline" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "Inline" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "Inlinable" 'PrefixI 'False) (U1 :: Type -> Type)))

dataPragmaSource#

Instances

Instances details
EqPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Pragma -> Pragma -> Bool#

(/=) :: Pragma -> Pragma -> Bool#

DataPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Pragma -> c Pragma#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Pragma#

toConstr :: Pragma -> Constr#

dataTypeOf :: Pragma -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Pragma) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Pragma) #

gmapT :: (forall b. Data b => b -> b) -> Pragma -> Pragma#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Pragma -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Pragma -> r #

gmapQ :: (forall d. Data d => d -> u) -> Pragma -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Pragma -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Pragma -> m Pragma#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Pragma -> m Pragma#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Pragma -> m Pragma#

OrdPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPragma :: Type -> Type#

Methods

from :: Pragma -> RepPragma x #

to :: RepPragma x -> Pragma#

PprPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepPragma = D1 ('MetaData "Pragma" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((C1 ('MetaCons "InlineP" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Inline)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0RuleMatch) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Phases))) :+: (C1 ('MetaCons "SpecialiseP" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeInline)) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Phases))) :+:C1 ('MetaCons "SpecialiseInstP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type)))) :+: ((C1 ('MetaCons "RuleP" 'PrefixI 'False) ((S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (Maybe [TyVarBndr])) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [RuleBndr]))) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Phases)))) :+:C1 ('MetaCons "AnnP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0AnnTarget) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp))) :+: (C1 ('MetaCons "LineP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Int) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String)) :+:C1 ('MetaCons "CompleteP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Name]) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeName))))))

dataSafetySource#

Constructors

Unsafe 
Safe 
Interruptible 

Instances

Instances details
EqSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Safety -> Safety -> Bool#

(/=) :: Safety -> Safety -> Bool#

DataSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Safety -> c Safety#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Safety#

toConstr :: Safety -> Constr#

dataTypeOf :: Safety -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Safety) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Safety) #

gmapT :: (forall b. Data b => b -> b) -> Safety -> Safety#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Safety -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Safety -> r #

gmapQ :: (forall d. Data d => d -> u) -> Safety -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Safety -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Safety -> m Safety#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Safety -> m Safety#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Safety -> m Safety#

OrdSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepSafety :: Type -> Type#

Methods

from :: Safety -> RepSafety x #

to :: RepSafety x -> Safety#

typeRepSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepSafety = D1 ('MetaData "Safety" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "Unsafe" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "Safe" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "Interruptible" 'PrefixI 'False) (U1 :: Type -> Type)))

dataCallconvSource#

Constructors

CCall 
StdCall 
CApi 
Prim 
JavaScript 

Instances

Instances details
EqCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Callconv -> c Callconv#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Callconv#

toConstr :: Callconv -> Constr#

dataTypeOf :: Callconv -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Callconv) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Callconv) #

gmapT :: (forall b. Data b => b -> b) -> Callconv -> Callconv#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Callconv -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Callconv -> r #

gmapQ :: (forall d. Data d => d -> u) -> Callconv -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Callconv -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Callconv -> m Callconv#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Callconv -> m Callconv#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Callconv -> m Callconv#

OrdCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepCallconv :: Type -> Type#

typeRepCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepCallconv = D1 ('MetaData "Callconv" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((C1 ('MetaCons "CCall" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "StdCall" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "CApi" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "Prim" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "JavaScript" 'PrefixI 'False) (U1 :: Type -> Type))))

dataForeignSource#

Instances

Instances details
EqForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Foreign -> Foreign -> Bool#

(/=) :: Foreign -> Foreign -> Bool#

DataForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Foreign -> c Foreign#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Foreign#

toConstr :: Foreign -> Constr#

dataTypeOf :: Foreign -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Foreign) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Foreign) #

gmapT :: (forall b. Data b => b -> b) -> Foreign -> Foreign#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Foreign -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Foreign -> r #

gmapQ :: (forall d. Data d => d -> u) -> Foreign -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Foreign -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Foreign -> m Foreign#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Foreign -> m Foreign#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Foreign -> m Foreign#

OrdForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepForeign :: Type -> Type#

Methods

from :: Foreign -> RepForeign x #

to :: RepForeign x -> Foreign#

PprForeignSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataTySynEqnSource#

One equation of a type family instance or closed type family. The arguments are the left-hand-side type and the right-hand-side result.

For instance, if you had the following type family:

type family Foo (a :: k) :: k where forall k (a :: k). Foo @k a = a 

The Foo @k a = a equation would be represented as follows:

TySynEqn (Just [PlainTV k, KindedTV a (VarT k)]) (AppT (AppKindT (ConT ''Foo) (VarT k)) (VarT a)) (VarT a) 

Constructors

TySynEqn (Maybe [TyVarBndr]) TypeType 

Instances

Instances details
EqTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> TySynEqn -> c TySynEqn#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c TySynEqn#

toConstr :: TySynEqn -> Constr#

dataTypeOf :: TySynEqn -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c TySynEqn) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c TySynEqn) #

gmapT :: (forall b. Data b => b -> b) -> TySynEqn -> TySynEqn#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> TySynEqn -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> TySynEqn -> r #

gmapQ :: (forall d. Data d => d -> u) -> TySynEqn -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> TySynEqn -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> TySynEqn -> m TySynEqn#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> TySynEqn -> m TySynEqn#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> TySynEqn -> m TySynEqn#

OrdTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepTySynEqn :: Type -> Type#

typeRepTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataTypeFamilyHeadSource#

Common elements of OpenTypeFamilyD and ClosedTypeFamilyD. By analogy with "head" for type classes and type class instances as defined in Type classes: an exploration of the design space, the TypeFamilyHead is defined to be the elements of the declaration between type family and where.

Instances

Instances details
EqTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> TypeFamilyHead -> c TypeFamilyHead#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c TypeFamilyHead#

toConstr :: TypeFamilyHead -> Constr#

dataTypeOf :: TypeFamilyHead -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c TypeFamilyHead) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c TypeFamilyHead) #

gmapT :: (forall b. Data b => b -> b) -> TypeFamilyHead -> TypeFamilyHead#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> TypeFamilyHead -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> TypeFamilyHead -> r #

gmapQ :: (forall d. Data d => d -> u) -> TypeFamilyHead -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> TypeFamilyHead -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> TypeFamilyHead -> m TypeFamilyHead#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> TypeFamilyHead -> m TypeFamilyHead#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> TypeFamilyHead -> m TypeFamilyHead#

OrdTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepTypeFamilyHead :: Type -> Type#

typeRepTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typePatSynType = TypeSource#

A pattern synonym's type. Note that a pattern synonym's fully specified type has a peculiar shape coming with two forall quantifiers and two constraint contexts. For example, consider the pattern synonym

pattern P x1 x2 ... xn = <some-pattern>

P's complete type is of the following form

pattern P :: forall universals. required constraints => forall existentials. provided constraints => t1 -> t2 -> ... -> tn -> t

consisting of four parts:

  1. the (possibly empty lists of) universally quantified type variables and required constraints on them.
  2. the (possibly empty lists of) existentially quantified type variables and the provided constraints on them.
  3. the types t1, t2, .., tn of x1, x2, .., xn, respectively
  4. the type t of <some-pattern>, mentioning only universals.

Pattern synonym types interact with TH when (a) reifying a pattern synonym, (b) pretty printing, or (c) specifying a pattern synonym's type signature explicitly:

  • Reification always returns a pattern synonym's fully specified type in abstract syntax.
  • Pretty printing via pprPatSynType abbreviates a pattern synonym's type unambiguously in concrete syntax: The rule of thumb is to print initial empty universals and the required context as () =>, if existentials and a provided context follow. If only universals and their required context, but no existentials are specified, only the universals and their required context are printed. If both or none are specified, so both (or none) are printed.
  • When specifying a pattern synonym's type explicitly with PatSynSigD either one of the universals, the existentials, or their contexts may be left empty.

See the GHC user's guide for more information on pattern synonyms and their types: https://downloads.haskell.org/~ghc/latest/docs/html/users_guide/glasgow_exts.html#pattern-synonyms.

dataDerivStrategySource#

What the user explicitly requests when deriving an instance.

Constructors

StockStrategy

A "standard" derived instance

AnyclassStrategy
-XDeriveAnyClass
NewtypeStrategy
-XGeneralizedNewtypeDeriving
ViaStrategyType
-XDerivingVia

Instances

Instances details
EqDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> DerivStrategy -> c DerivStrategy#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c DerivStrategy#

toConstr :: DerivStrategy -> Constr#

dataTypeOf :: DerivStrategy -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c DerivStrategy) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c DerivStrategy) #

gmapT :: (forall b. Data b => b -> b) -> DerivStrategy -> DerivStrategy#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> DerivStrategy -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> DerivStrategy -> r #

gmapQ :: (forall d. Data d => d -> u) -> DerivStrategy -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> DerivStrategy -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> DerivStrategy -> m DerivStrategy#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> DerivStrategy -> m DerivStrategy#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> DerivStrategy -> m DerivStrategy#

OrdDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDerivStrategy :: Type -> Type#

typeRepDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepDerivStrategy = D1 ('MetaData "DerivStrategy" "Language.Haskell.TH.Syntax" "template-haskell" 'False) ((C1 ('MetaCons "StockStrategy" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "AnyclassStrategy" 'PrefixI 'False) (U1 :: Type -> Type)) :+: (C1 ('MetaCons "NewtypeStrategy" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "ViaStrategy" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))))

dataDerivClauseSource#

A single deriving clause at the end of a datatype.

Constructors

DerivClause (MaybeDerivStrategy) Cxt
{ deriving stock (Eq, Ord) }

Instances

Instances details
EqDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> DerivClause -> c DerivClause#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c DerivClause#

toConstr :: DerivClause -> Constr#

dataTypeOf :: DerivClause -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c DerivClause) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c DerivClause) #

gmapT :: (forall b. Data b => b -> b) -> DerivClause -> DerivClause#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> DerivClause -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> DerivClause -> r #

gmapQ :: (forall d. Data d => d -> u) -> DerivClause -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> DerivClause -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> DerivClause -> m DerivClause#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> DerivClause -> m DerivClause#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> DerivClause -> m DerivClause#

OrdDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDerivClause :: Type -> Type#

typeRepDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataRangeSource#

Instances

Instances details
EqRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Range -> Range -> Bool#

(/=) :: Range -> Range -> Bool#

DataRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Range -> c Range#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Range#

toConstr :: Range -> Constr#

dataTypeOf :: Range -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Range) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Range) #

gmapT :: (forall b. Data b => b -> b) -> Range -> Range#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Range -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Range -> r #

gmapQ :: (forall d. Data d => d -> u) -> Range -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Range -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Range -> m Range#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Range -> m Range#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Range -> m Range#

OrdRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepRange :: Type -> Type#

Methods

from :: Range -> RepRange x #

to :: RepRange x -> Range#

PprRangeSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataStmtSource#

Constructors

BindSPatExp
p <- e
LetS [Dec]
{ let { x=e1; y=e2 } }
NoBindSExp
e
ParS [[Stmt]]

x <- e1 | s2, s3 | s4 (in CompE)

RecS [Stmt]
rec { s1; s2 }

Instances

Instances details
EqStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Stmt -> Stmt -> Bool#

(/=) :: Stmt -> Stmt -> Bool#

DataStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Stmt -> c Stmt#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Stmt#

toConstr :: Stmt -> Constr#

dataTypeOf :: Stmt -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Stmt) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Stmt) #

gmapT :: (forall b. Data b => b -> b) -> Stmt -> Stmt#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Stmt -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Stmt -> r #

gmapQ :: (forall d. Data d => d -> u) -> Stmt -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Stmt -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Stmt -> m Stmt#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Stmt -> m Stmt#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Stmt -> m Stmt#

OrdStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Stmt -> Stmt -> Ordering#

(<) :: Stmt -> Stmt -> Bool#

(<=) :: Stmt -> Stmt -> Bool#

(>) :: Stmt -> Stmt -> Bool#

(>=) :: Stmt -> Stmt -> Bool#

max :: Stmt -> Stmt -> Stmt#

min :: Stmt -> Stmt -> Stmt#

ShowStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Stmt -> ShowS#

show :: Stmt -> String#

showList :: [Stmt] -> ShowS#

GenericStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepStmt :: Type -> Type#

Methods

from :: Stmt -> RepStmt x #

to :: RepStmt x -> Stmt#

PprStmtSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataGuardSource#

Constructors

NormalGExp
f x { | odd x } = x
PatG [Stmt]
f x { | Just y <- x, Just z <- y } = z

Instances

Instances details
EqGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Guard -> Guard -> Bool#

(/=) :: Guard -> Guard -> Bool#

DataGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Guard -> c Guard#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Guard#

toConstr :: Guard -> Constr#

dataTypeOf :: Guard -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Guard) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Guard) #

gmapT :: (forall b. Data b => b -> b) -> Guard -> Guard#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Guard -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Guard -> r #

gmapQ :: (forall d. Data d => d -> u) -> Guard -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Guard -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Guard -> m Guard#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Guard -> m Guard#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Guard -> m Guard#

OrdGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepGuard :: Type -> Type#

Methods

from :: Guard -> RepGuard x #

to :: RepGuard x -> Guard#

typeRepGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataBodySource#

Constructors

GuardedB [(Guard, Exp)]
f p { | e1 = e2 | e3 = e4 } where ds
NormalBExp
f p { = e } where ds

Instances

Instances details
EqBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Body -> Body -> Bool#

(/=) :: Body -> Body -> Bool#

DataBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Body -> c Body#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Body#

toConstr :: Body -> Constr#

dataTypeOf :: Body -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Body) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Body) #

gmapT :: (forall b. Data b => b -> b) -> Body -> Body#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Body -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Body -> r #

gmapQ :: (forall d. Data d => d -> u) -> Body -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Body -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Body -> m Body#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Body -> m Body#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Body -> m Body#

OrdBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Body -> Body -> Ordering#

(<) :: Body -> Body -> Bool#

(<=) :: Body -> Body -> Bool#

(>) :: Body -> Body -> Bool#

(>=) :: Body -> Body -> Bool#

max :: Body -> Body -> Body#

min :: Body -> Body -> Body#

ShowBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Body -> ShowS#

show :: Body -> String#

showList :: [Body] -> ShowS#

GenericBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepBody :: Type -> Type#

Methods

from :: Body -> RepBody x #

to :: RepBody x -> Body#

typeRepBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepBody = D1 ('MetaData "Body" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "GuardedB" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [(Guard, Exp)])) :+:C1 ('MetaCons "NormalB" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp)))

dataBytesSource#

Raw bytes embedded into the binary.

Avoid using Bytes constructor directly as it is likely to change in the future. Use helpers such as mkBytes in Language.Haskell.TH.Lib instead.

Constructors

Bytes 

Fields

  • bytesPtr :: ForeignPtrWord8

    Pointer to the data

  • bytesOffset :: Word

    Offset from the pointer

  • bytesSize :: Word

    Number of bytes Maybe someday: , bytesAlignement :: Word -- ^ Alignement constraint , bytesReadOnly :: Bool -- ^ Shall we embed into a read-only -- section or not , bytesInitialized :: Bool -- ^ False: only use bytesSize to allocate -- an uninitialized region

Instances

Instances details
EqBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Bytes -> Bytes -> Bool#

(/=) :: Bytes -> Bytes -> Bool#

DataBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Bytes -> c Bytes#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Bytes#

toConstr :: Bytes -> Constr#

dataTypeOf :: Bytes -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Bytes) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Bytes) #

gmapT :: (forall b. Data b => b -> b) -> Bytes -> Bytes#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Bytes -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Bytes -> r #

gmapQ :: (forall d. Data d => d -> u) -> Bytes -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Bytes -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Bytes -> m Bytes#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Bytes -> m Bytes#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Bytes -> m Bytes#

OrdBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepBytes :: Type -> Type#

Methods

from :: Bytes -> RepBytes x #

to :: RepBytes x -> Bytes#

typeRepBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepBytes = D1 ('MetaData "Bytes" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "Bytes" 'PrefixI 'True) (S1 ('MetaSel ('Just "bytesPtr") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (ForeignPtrWord8)) :*: (S1 ('MetaSel ('Just "bytesOffset") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Word) :*:S1 ('MetaSel ('Just "bytesSize") 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Word))))

dataLitSource#

Constructors

CharLChar 
StringLString 
IntegerLInteger

Used for overloaded and non-overloaded literals. We don't have a good way to represent non-overloaded literals at the moment. Maybe that doesn't matter?

RationalLRational 
IntPrimLInteger 
WordPrimLInteger 
FloatPrimLRational 
DoublePrimLRational 
StringPrimL [Word8]

A primitive C-style string, type Addr#

BytesPrimLBytes

Some raw bytes, type Addr#:

CharPrimLChar 

Instances

Instances details
EqLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Lit -> Lit -> Bool#

(/=) :: Lit -> Lit -> Bool#

DataLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Lit -> c Lit#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Lit#

toConstr :: Lit -> Constr#

dataTypeOf :: Lit -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Lit) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Lit) #

gmapT :: (forall b. Data b => b -> b) -> Lit -> Lit#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Lit -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Lit -> r #

gmapQ :: (forall d. Data d => d -> u) -> Lit -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Lit -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Lit -> m Lit#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Lit -> m Lit#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Lit -> m Lit#

OrdLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Lit -> Lit -> Ordering#

(<) :: Lit -> Lit -> Bool#

(<=) :: Lit -> Lit -> Bool#

(>) :: Lit -> Lit -> Bool#

(>=) :: Lit -> Lit -> Bool#

max :: Lit -> Lit -> Lit#

min :: Lit -> Lit -> Lit#

ShowLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Lit -> ShowS#

show :: Lit -> String#

showList :: [Lit] -> ShowS#

GenericLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepLit :: Type -> Type#

Methods

from :: Lit -> RepLit x #

to :: RepLit x -> Lit#

PprLitSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

Methods

ppr :: Lit -> DocSource#

ppr_list :: [Lit] -> DocSource#

typeRepLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepLit = D1 ('MetaData "Lit" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (((C1 ('MetaCons "CharL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Char)) :+:C1 ('MetaCons "StringL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String))) :+: (C1 ('MetaCons "IntegerL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Integer)) :+: (C1 ('MetaCons "RationalL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Rational)) :+:C1 ('MetaCons "IntPrimL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Integer))))) :+: ((C1 ('MetaCons "WordPrimL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Integer)) :+: (C1 ('MetaCons "FloatPrimL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Rational)) :+:C1 ('MetaCons "DoublePrimL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Rational)))) :+: (C1 ('MetaCons "StringPrimL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Word8])) :+: (C1 ('MetaCons "BytesPrimL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Bytes)) :+:C1 ('MetaCons "CharPrimL" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Char))))))

dataFixityDirectionSource#

Constructors

InfixL 
InfixR 
InfixN 

Instances

Instances details
EqFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> FixityDirection -> c FixityDirection#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c FixityDirection#

toConstr :: FixityDirection -> Constr#

dataTypeOf :: FixityDirection -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c FixityDirection) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c FixityDirection) #

gmapT :: (forall b. Data b => b -> b) -> FixityDirection -> FixityDirection#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> FixityDirection -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> FixityDirection -> r #

gmapQ :: (forall d. Data d => d -> u) -> FixityDirection -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> FixityDirection -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> FixityDirection -> m FixityDirection#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> FixityDirection -> m FixityDirection#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> FixityDirection -> m FixityDirection#

OrdFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepFixityDirection :: Type -> Type#

typeRepFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepFixityDirection = D1 ('MetaData "FixityDirection" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "InfixL" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "InfixR" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "InfixN" 'PrefixI 'False) (U1 :: Type -> Type)))

dataFixitySource#

Instances

Instances details
EqFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Fixity -> Fixity -> Bool#

(/=) :: Fixity -> Fixity -> Bool#

DataFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Fixity -> c Fixity#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Fixity#

toConstr :: Fixity -> Constr#

dataTypeOf :: Fixity -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Fixity) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Fixity) #

gmapT :: (forall b. Data b => b -> b) -> Fixity -> Fixity#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Fixity -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Fixity -> r #

gmapQ :: (forall d. Data d => d -> u) -> Fixity -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Fixity -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Fixity -> m Fixity#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Fixity -> m Fixity#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Fixity -> m Fixity#

OrdFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepFixity :: Type -> Type#

Methods

from :: Fixity -> RepFixity x #

to :: RepFixity x -> Fixity#

typeRepFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeInstanceDec = DecSource#

InstanceDec desribes a single instance of a class or type function. It is just a Dec, but guaranteed to be one of the following:

typeUnlifted = BoolSource#

In PrimTyConI, is the type constructor unlifted?

typeArity = IntSource#

In PrimTyConI, arity of the type constructor

typeSumArity = IntSource#

In UnboxedSumE, UnboxedSumT, and UnboxedSumP, the total number of SumAlts. For example, (#|#) has a SumArity of 2.

typeSumAlt = IntSource#

In UnboxedSumE and UnboxedSumP, the number associated with a particular data constructor. SumAlts are one-indexed and should never exceed the value of its corresponding SumArity. For example:

typeParentName = NameSource#

In ClassOpI and DataConI, name of the parent class or type

dataModuleInfoSource#

Obtained from reifyModule in the Q Monad.

Constructors

ModuleInfo [Module]

Contains the import list of the module.

Instances

Instances details
EqModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> ModuleInfo -> c ModuleInfo#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c ModuleInfo#

toConstr :: ModuleInfo -> Constr#

dataTypeOf :: ModuleInfo -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c ModuleInfo) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c ModuleInfo) #

gmapT :: (forall b. Data b => b -> b) -> ModuleInfo -> ModuleInfo#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> ModuleInfo -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> ModuleInfo -> r #

gmapQ :: (forall d. Data d => d -> u) -> ModuleInfo -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> ModuleInfo -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> ModuleInfo -> m ModuleInfo#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> ModuleInfo -> m ModuleInfo#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> ModuleInfo -> m ModuleInfo#

OrdModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepModuleInfo :: Type -> Type#

PprModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepModuleInfo = D1 ('MetaData "ModuleInfo" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "ModuleInfo" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Module])))

dataInfoSource#

Obtained from reify in the Q Monad.

Constructors

ClassIDec [InstanceDec]

A class, with a list of its visible instances

ClassOpINameTypeParentName

A class method

TyConIDec

A "plain" type constructor. "Fancier" type constructors are returned using PrimTyConI or FamilyI as appropriate. At present, this reified declaration will never have derived instances attached to it (if you wish to check for an instance, see reifyInstances).

FamilyIDec [InstanceDec]

A type or data family, with a list of its visible instances. A closed type family is returned with 0 instances.

PrimTyConINameArityUnlifted

A "primitive" type constructor, which can't be expressed with a Dec. Examples: (->), Int#.

DataConINameTypeParentName

A data constructor

PatSynINamePatSynType

A pattern synonym

VarINameType (MaybeDec)

A "value" variable (as opposed to a type variable, see TyVarI).

The Maybe Dec field contains Just the declaration which defined the variable - including the RHS of the declaration - or else Nothing, in the case where the RHS is unavailable to the compiler. At present, this value is alwaysNothing: returning the RHS has not yet been implemented because of lack of interest.

TyVarINameType

A type variable.

The Type field contains the type which underlies the variable. At present, this is always VarT theName, but future changes may permit refinement of this.

Instances

Instances details
EqInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Info -> Info -> Bool#

(/=) :: Info -> Info -> Bool#

DataInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Info -> c Info#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Info#

toConstr :: Info -> Constr#

dataTypeOf :: Info -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Info) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Info) #

gmapT :: (forall b. Data b => b -> b) -> Info -> Info#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Info -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Info -> r #

gmapQ :: (forall d. Data d => d -> u) -> Info -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Info -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Info -> m Info#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Info -> m Info#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Info -> m Info#

OrdInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Info -> Info -> Ordering#

(<) :: Info -> Info -> Bool#

(<=) :: Info -> Info -> Bool#

(>) :: Info -> Info -> Bool#

(>=) :: Info -> Info -> Bool#

max :: Info -> Info -> Info#

min :: Info -> Info -> Info#

ShowInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Info -> ShowS#

show :: Info -> String#

showList :: [Info] -> ShowS#

GenericInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepInfo :: Type -> Type#

Methods

from :: Info -> RepInfo x #

to :: RepInfo x -> Info#

PprInfoSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepInfo = D1 ('MetaData "Info" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (((C1 ('MetaCons "ClassI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Dec) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [InstanceDec])) :+:C1 ('MetaCons "ClassOpI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0ParentName)))) :+: (C1 ('MetaCons "TyConI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Dec)) :+:C1 ('MetaCons "FamilyI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Dec) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [InstanceDec])))) :+: ((C1 ('MetaCons "PrimTyConI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Arity) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Unlifted))) :+:C1 ('MetaCons "DataConI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0ParentName)))) :+: (C1 ('MetaCons "PatSynI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0PatSynType)) :+: (C1 ('MetaCons "VarI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*: (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeDec)))) :+:C1 ('MetaCons "TyVarI" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Type))))))

typeCharPosSource#

Arguments

 = (Int, Int)

Line and character position

dataLocSource#

Instances

Instances details
EqLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Loc -> Loc -> Bool#

(/=) :: Loc -> Loc -> Bool#

DataLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Loc -> c Loc#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Loc#

toConstr :: Loc -> Constr#

dataTypeOf :: Loc -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Loc) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Loc) #

gmapT :: (forall b. Data b => b -> b) -> Loc -> Loc#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Loc -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Loc -> r #

gmapQ :: (forall d. Data d => d -> u) -> Loc -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Loc -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Loc -> m Loc#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Loc -> m Loc#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Loc -> m Loc#

OrdLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: Loc -> Loc -> Ordering#

(<) :: Loc -> Loc -> Bool#

(<=) :: Loc -> Loc -> Bool#

(>) :: Loc -> Loc -> Bool#

(>=) :: Loc -> Loc -> Bool#

max :: Loc -> Loc -> Loc#

min :: Loc -> Loc -> Loc#

ShowLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

showsPrec :: Int -> Loc -> ShowS#

show :: Loc -> String#

showList :: [Loc] -> ShowS#

GenericLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepLoc :: Type -> Type#

Methods

from :: Loc -> RepLoc x #

to :: RepLoc x -> Loc#

PprLocSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

Methods

ppr :: Loc -> DocSource#

ppr_list :: [Loc] -> DocSource#

typeRepLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataNameIsSource#

Constructors

Alone 
Applied 
Infix 

typeUniq = IntegerSource#

Uniq is used by GHC to distinguish names from each other.

dataNameSpaceSource#

Constructors

VarName

Variables

DataName

Data constructors

TcClsName

Type constructors and classes; Haskell has them in the same name space for now.

Instances

Instances details
EqNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> NameSpace -> c NameSpace#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c NameSpace#

toConstr :: NameSpace -> Constr#

dataTypeOf :: NameSpace -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c NameSpace) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c NameSpace) #

gmapT :: (forall b. Data b => b -> b) -> NameSpace -> NameSpace#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> NameSpace -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> NameSpace -> r #

gmapQ :: (forall d. Data d => d -> u) -> NameSpace -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> NameSpace -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> NameSpace -> m NameSpace#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> NameSpace -> m NameSpace#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> NameSpace -> m NameSpace#

OrdNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepNameSpace :: Type -> Type#

typeRepNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepNameSpace = D1 ('MetaData "NameSpace" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "VarName" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "DataName" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "TcClsName" 'PrefixI 'False) (U1 :: Type -> Type)))

dataNameFlavourSource#

Constructors

NameS

An unqualified name; dynamically bound

NameQModName

A qualified name; dynamically bound

NameU !Uniq

A unique local name

NameL !Uniq

Local name bound outside of the TH AST

NameGNameSpacePkgNameModName

Global name bound outside of the TH AST: An original name (occurrences only, not binders) Need the namespace too to be sure which thing we are naming

Instances

Instances details
EqNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

DataNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> NameFlavour -> c NameFlavour#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c NameFlavour#

toConstr :: NameFlavour -> Constr#

dataTypeOf :: NameFlavour -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c NameFlavour) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c NameFlavour) #

gmapT :: (forall b. Data b => b -> b) -> NameFlavour -> NameFlavour#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> NameFlavour -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> NameFlavour -> r #

gmapQ :: (forall d. Data d => d -> u) -> NameFlavour -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> NameFlavour -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> NameFlavour -> m NameFlavour#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> NameFlavour -> m NameFlavour#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> NameFlavour -> m NameFlavour#

OrdNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepNameFlavour :: Type -> Type#

typeRepNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

newtypeOccNameSource#

Constructors

OccNameString 

Instances

Instances details
EqOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: OccName -> OccName -> Bool#

(/=) :: OccName -> OccName -> Bool#

DataOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> OccName -> c OccName#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c OccName#

toConstr :: OccName -> Constr#

dataTypeOf :: OccName -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c OccName) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c OccName) #

gmapT :: (forall b. Data b => b -> b) -> OccName -> OccName#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> OccName -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> OccName -> r #

gmapQ :: (forall d. Data d => d -> u) -> OccName -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> OccName -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> OccName -> m OccName#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> OccName -> m OccName#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> OccName -> m OccName#

OrdOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepOccName :: Type -> Type#

Methods

from :: OccName -> RepOccName x #

to :: RepOccName x -> OccName#

typeRepOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepOccName = D1 ('MetaData "OccName" "Language.Haskell.TH.Syntax" "template-haskell" 'True) (C1 ('MetaCons "OccName" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String)))

dataModuleSource#

Obtained from reifyModule and thisModule.

Constructors

ModulePkgNameModName 

Instances

Instances details
EqModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Module -> Module -> Bool#

(/=) :: Module -> Module -> Bool#

DataModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> Module -> c Module#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c Module#

toConstr :: Module -> Constr#

dataTypeOf :: Module -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c Module) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c Module) #

gmapT :: (forall b. Data b => b -> b) -> Module -> Module#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Module -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Module -> r #

gmapQ :: (forall d. Data d => d -> u) -> Module -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> Module -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> Module -> m Module#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Module -> m Module#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Module -> m Module#

OrdModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepModule :: Type -> Type#

Methods

from :: Module -> RepModule x #

to :: RepModule x -> Module#

PprModuleSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

newtypePkgNameSource#

Constructors

PkgNameString 

Instances

Instances details
EqPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: PkgName -> PkgName -> Bool#

(/=) :: PkgName -> PkgName -> Bool#

DataPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> PkgName -> c PkgName#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c PkgName#

toConstr :: PkgName -> Constr#

dataTypeOf :: PkgName -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c PkgName) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c PkgName) #

gmapT :: (forall b. Data b => b -> b) -> PkgName -> PkgName#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> PkgName -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> PkgName -> r #

gmapQ :: (forall d. Data d => d -> u) -> PkgName -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> PkgName -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> PkgName -> m PkgName#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> PkgName -> m PkgName#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> PkgName -> m PkgName#

OrdPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPkgName :: Type -> Type#

Methods

from :: PkgName -> RepPkgName x #

to :: RepPkgName x -> PkgName#

typeRepPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepPkgName = D1 ('MetaData "PkgName" "Language.Haskell.TH.Syntax" "template-haskell" 'True) (C1 ('MetaCons "PkgName" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String)))

newtypeModNameSource#

Constructors

ModNameString 

Instances

Instances details
EqModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: ModName -> ModName -> Bool#

(/=) :: ModName -> ModName -> Bool#

DataModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> ModName -> c ModName#

gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c ModName#

toConstr :: ModName -> Constr#

dataTypeOf :: ModName -> DataType#

dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c ModName) #

dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c ModName) #

gmapT :: (forall b. Data b => b -> b) -> ModName -> ModName#

gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> ModName -> r #

gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> ModName -> r #

gmapQ :: (forall d. Data d => d -> u) -> ModName -> [u] #

gmapQi :: Int -> (forall d. Data d => d -> u) -> ModName -> u #

gmapM :: Monad m => (forall d. Data d => d -> m d) -> ModName -> m ModName#

gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> ModName -> m ModName#

gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> ModName -> m ModName#

OrdModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

ShowModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

GenericModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepModName :: Type -> Type#

Methods

from :: ModName -> RepModName x #

to :: RepModName x -> ModName#

typeRepModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepModName = D1 ('MetaData "ModName" "Language.Haskell.TH.Syntax" "template-haskell" 'True) (C1 ('MetaCons "ModName" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String)))

class (MonadIO m, MonadFail m) => Quasi m whereSource#

Methods

qNewNameSource#

Arguments

:: String 
-> m Name

Fresh names

qReportSource#

Arguments

:: Bool 
-> String 
-> m ()

Report an error (True) or warning (False) ...but carry on; use fail to stop

qRecoverSource#

Arguments

:: m a

the error handler

-> m a

action which may fail

-> m a

Recover from the monadic fail

qLookupName :: Bool -> String -> m (MaybeName) Source#

qReify :: Name -> m InfoSource#

qReifyFixity :: Name -> m (MaybeFixity) Source#

qReifyType :: Name -> m TypeSource#

qReifyInstances :: Name -> [Type] -> m [Dec] Source#

qReifyRoles :: Name -> m [Role] Source#

qReifyAnnotations :: Data a => AnnLookup -> m [a] Source#

qReifyModule :: Module -> m ModuleInfoSource#

qReifyConStrictness :: Name -> m [DecidedStrictness] Source#

qLocation :: m LocSource#

qRunIO :: IO a -> m a Source#

qAddDependentFile :: FilePath -> m () Source#

qAddTempFile :: String -> m FilePathSource#

qAddTopDecls :: [Dec] -> m () Source#

qAddForeignFilePath :: ForeignSrcLang -> String -> m () Source#

qAddModFinalizer :: Q () -> m () Source#

qAddCorePlugin :: String -> m () Source#

qGetQ :: Typeable a => m (Maybe a) Source#

qPutQ :: Typeable a => a -> m () Source#

qIsExtEnabled :: Extension -> m BoolSource#

qExtsEnabled :: m [Extension] Source#

Instances

Instances details
QuasiIOSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

QuasiQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

runQ :: Quasi m => Q a -> m a Source#

report :: Bool -> String -> Q () Source#

Deprecated: Use reportError or reportWarning instead

Report an error (True) or warning (False), but carry on; use fail to stop.

reportError :: String -> Q () Source#

Report an error to the user, but allow the current splice's computation to carry on. To abort the computation, use fail.

reportWarning :: String -> Q () Source#

Report a warning to the user, and carry on.

recoverSource#

Arguments

:: Q a

handler to invoke on failure

-> Q a

computation to run

-> Q a 

Recover from errors raised by reportError or fail.

lookupTypeName :: String -> Q (MaybeName) Source#

Look up the given name in the (type namespace of the) current splice's scope. See Language.Haskell.TH.Syntax for more details.

lookupValueName :: String -> Q (MaybeName) Source#

Look up the given name in the (value namespace of the) current splice's scope. See Language.Haskell.TH.Syntax for more details.

reify :: Name -> QInfoSource#

reify looks up information about the Name.

It is sometimes useful to construct the argument name using lookupTypeName or lookupValueName to ensure that we are reifying from the right namespace. For instance, in this context:

data D = D

which D does reify (mkName "D") return information about? (Answer: D-the-type, but don't rely on it.) To ensure we get information about D-the-value, use lookupValueName:

do Just nm <- lookupValueName "D" reify nm

and to get information about D-the-type, use lookupTypeName.

reifyFixity :: Name -> Q (MaybeFixity) Source#

reifyFixity nm attempts to find a fixity declaration for nm. For example, if the function foo has the fixity declaration infixr 7 foo, then reifyFixity 'foo would return Just (Fixity 7 InfixR). If the function bar does not have a fixity declaration, then reifyFixity 'bar returns Nothing, so you may assume bar has defaultFixity.

reifyType :: Name -> QTypeSource#

reifyType nm attempts to find the type or kind of nm. For example, reifyType 'not returns Bool -> Bool, and reifyType ''Bool returns Type. This works even if there's no explicit signature and the type or kind is inferred.

reifyInstances :: Name -> [Type] -> Q [InstanceDec] Source#

reifyInstances nm tys returns a list of visible instances of nm tys. That is, if nm is the name of a type class, then all instances of this class at the types tys are returned. Alternatively, if nm is the name of a data family or type family, all instances of this family at the types tys are returned.

Note that this is a "shallow" test; the declarations returned merely have instance heads which unify with nm tys, they need not actually be satisfiable.

  • reifyInstances ''Eq [ TupleT 2 `AppT` ConT ''A `AppT` ConT ''B ] contains the instance (Eq a, Eq b) => Eq (a, b) regardless of whether A and B themselves implement Eq
  • reifyInstances ''Show [ VarT (mkName "a") ] produces every available instance of Eq

There is one edge case: reifyInstances ''Typeable tys currently always produces an empty list (no matter what tys are given).

reifyRoles :: Name -> Q [Role] Source#

reifyRoles nm returns the list of roles associated with the parameters of the tycon nm. Fails if nm cannot be found or is not a tycon. The returned list should never contain InferR.

reifyAnnotations :: Data a => AnnLookup -> Q [a] Source#

reifyAnnotations target returns the list of annotations associated with target. Only the annotations that are appropriately typed is returned. So if you have Int and String annotations for the same target, you have to call this function twice.

reifyModule :: Module -> QModuleInfoSource#

reifyModule mod looks up information about module mod. To look up the current module, call this function with the return value of thisModule.

reifyConStrictness :: Name -> Q [DecidedStrictness] Source#

reifyConStrictness nm looks up the strictness information for the fields of the constructor with the name nm. Note that the strictness information that reifyConStrictness returns may not correspond to what is written in the source code. For example, in the following data declaration:

data Pair a = Pair a a 

reifyConStrictness would return [DecidedLazy, DecidedLazy] under most circumstances, but it would return [DecidedStrict, DecidedStrict] if the -XStrictData language extension was enabled.

isInstance :: Name -> [Type] -> QBoolSource#

Is the list of instances returned by reifyInstances nonempty?

location :: QLocSource#

The location at which this computation is spliced.

runIO :: IO a -> Q a Source#

The runIO function lets you run an I/O computation in the Q monad. Take care: you are guaranteed the ordering of calls to runIO within a single Q computation, but not about the order in which splices are run.

Note: for various murky reasons, stdout and stderr handles are not necessarily flushed when the compiler finishes running, so you should flush them yourself.

addDependentFile :: FilePath -> Q () Source#

Record external files that runIO is using (dependent upon). The compiler can then recognize that it should re-compile the Haskell file when an external file changes.

Expects an absolute file path.

Notes:

  • ghc -M does not know about these dependencies - it does not execute TH.
  • The dependency is based on file content, not a modification time

addTempFile :: String -> QFilePathSource#

Obtain a temporary file path with the given suffix. The compiler will delete this file after compilation.

addTopDecls :: [Dec] -> Q () Source#

Add additional top-level declarations. The added declarations will be type checked along with the current declaration group.

addForeignFile :: ForeignSrcLang -> String -> Q () Source#

Deprecated: Use addForeignSource instead

addForeignSource :: ForeignSrcLang -> String -> Q () Source#

Emit a foreign file which will be compiled and linked to the object for the current module. Currently only languages that can be compiled with the C compiler are supported, and the flags passed as part of -optc will be also applied to the C compiler invocation that will compile them.

Note that for non-C languages (for example C++) extern C directives must be used to get symbols that we can access from Haskell.

To get better errors, it is recommended to use #line pragmas when emitting C files, e.g.

{-# LANGUAGE CPP #-} ... addForeignSource LangC $ unlines [ "#line " ++ show (562 + 1) ++ " " ++ show "Language/Haskell/TH/Syntax.hs" , ... ]

addForeignFilePath :: ForeignSrcLang -> FilePath -> Q () Source#

Same as addForeignSource, but expects to receive a path pointing to the foreign file instead of a String of its contents. Consider using this in conjunction with addTempFile.

This is a good alternative to addForeignSource when you are trying to directly link in an object file.

addModFinalizer :: Q () -> Q () Source#

Add a finalizer that will run in the Q monad after the current module has been type checked. This only makes sense when run within a top-level splice.

The finalizer is given the local type environment at the splice point. Thus reify is able to find the local definitions when executed inside the finalizer.

addCorePlugin :: String -> Q () Source#

Adds a core plugin to the compilation pipeline.

addCorePlugin m has almost the same effect as passing -fplugin=m to ghc in the command line. The major difference is that the plugin module m must not belong to the current package. When TH executes, it is too late to tell the compiler that we needed to compile first a plugin module in the current package.

getQ :: Typeable a => Q (Maybe a) Source#

Get state from the Q monad. Note that the state is local to the Haskell module in which the Template Haskell expression is executed.

putQ :: Typeable a => a -> Q () Source#

Replace the state in the Q monad. Note that the state is local to the Haskell module in which the Template Haskell expression is executed.

isExtEnabled :: Extension -> QBoolSource#

Determine whether the given language extension is enabled in the Q monad.

extsEnabled :: Q [Extension] Source#

List all enabled language extensions.

dataToQa :: forall a k q. Data a => (Name -> k) -> (Lit -> Q q) -> (k -> [Q q] -> Q q) -> (forall b. Data b => b -> Maybe (Q q)) -> a -> Q q Source#

dataToQa is an internal utility function for constructing generic conversion functions from types with Data instances to various quasi-quoting representations. See the source of dataToExpQ and dataToPatQ for two example usages: mkCon, mkLit and appQ are overloadable to account for different syntax for expressions and patterns; antiQ allows you to override type-specific cases, a common usage is just const Nothing, which results in no overloading.

dataToExpQ :: Data a => (forall b. Data b => b -> Maybe (QExp)) -> a -> QExpSource#

dataToExpQ converts a value to a 'Q Exp' representation of the same value, in the SYB style. It is generalized to take a function override type-specific cases; see liftData for a more commonly used variant.

liftData :: Data a => a -> QExpSource#

liftData is a variant of lift in the Lift type class which works for any type with a Data instance.

dataToPatQ :: Data a => (forall b. Data b => b -> Maybe (QPat)) -> a -> QPatSource#

dataToPatQ converts a value to a 'Q Pat' representation of the same value, in the SYB style. It takes a function to handle type-specific cases, alternatively, pass const Nothing to get default behavior.

nameBase :: Name -> StringSource#

The name without its module prefix.

Examples

Expand
>>> nameBase ''Data.Either.Either "Either" >>> nameBase (mkName "foo") "foo" >>> nameBase (mkName "Module.foo") "foo" 

nameModule :: Name -> MaybeStringSource#

Module prefix of a name, if it exists.

Examples

Expand
>>> nameModule ''Data.Either.Either Just "Data.Either" >>> nameModule (mkName "foo") Nothing >>> nameModule (mkName "Module.foo") Just "Module" 

namePackage :: Name -> MaybeStringSource#

A name's package, if it exists.

Examples

Expand
>>> namePackage ''Data.Either.Either Just "base" >>> namePackage (mkName "foo") Nothing >>> namePackage (mkName "Module.foo") Nothing 

nameSpace :: Name -> MaybeNameSpaceSource#

Returns whether a name represents an occurrence of a top-level variable (VarName), data constructor (DataName), type constructor, or type class (TcClsName). If we can't be sure, it returns Nothing.

Examples

Expand
>>> nameSpace 'Prelude.id Just VarName >>> nameSpace (mkName "id") Nothing -- only works for top-level variable names >>> nameSpace 'Data.Maybe.Just Just DataName >>> nameSpace ''Data.Maybe.Maybe Just TcClsName >>> nameSpace ''Data.Ord.Ord Just TcClsName 

mkNameU :: String -> Uniq -> NameSource#

Only used internally

mkNameG :: NameSpace -> String -> String -> String -> NameSource#

Used for 'x etc, but not available to the programmer

tupleDataName :: Int -> NameSource#

Tuple data constructor

tupleTypeName :: Int -> NameSource#

Tuple type constructor

unboxedTupleDataName :: Int -> NameSource#

Unboxed tuple data constructor

unboxedTupleTypeName :: Int -> NameSource#

Unboxed tuple type constructor

unboxedSumDataName :: SumAlt -> SumArity -> NameSource#

Unboxed sum data constructor

unboxedSumTypeName :: SumArity -> NameSource#

Unboxed sum type constructor

maxPrecedence :: IntSource#

Highest allowed operator precedence for Fixity constructor (answer: 9)

defaultFixity :: FixitySource#

Default fixity: infixl 9

Language extensions

dataForeignSrcLang#

Foreign formats supported by GHC via TH

Constructors

LangC

C

LangCxx

C++

LangObjc

Objective C

LangObjcxx

Objective C++

LangAsm

Assembly language (.s)

RawObject

Object (.o)

Instances

Instances details
EqForeignSrcLang 
Instance details

Defined in GHC.ForeignSrcLang.Type

ShowForeignSrcLang 
Instance details

Defined in GHC.ForeignSrcLang.Type

GenericForeignSrcLang 
Instance details

Defined in GHC.ForeignSrcLang.Type

Associated Types

typeRepForeignSrcLang :: Type -> Type#

typeRepForeignSrcLang 
Instance details

Defined in GHC.ForeignSrcLang.Type

typeRepForeignSrcLang = D1 ('MetaData "ForeignSrcLang" "GHC.ForeignSrcLang.Type" "ghc-boot-th-8.10.1" 'False) ((C1 ('MetaCons "LangC" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "LangCxx" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "LangObjc" 'PrefixI 'False) (U1 :: Type -> Type))) :+: (C1 ('MetaCons "LangObjcxx" 'PrefixI 'False) (U1 :: Type -> Type) :+: (C1 ('MetaCons "LangAsm" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "RawObject" 'PrefixI 'False) (U1 :: Type -> Type))))
close