template-haskell-2.20.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

dataForeignSource#

Instances

Instances details
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 ForeignSource#

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

toConstr :: Foreign -> ConstrSource#

dataTypeOf :: Foreign -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepForeign :: Type -> TypeSource#

ShowForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprForeignSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepForeignSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataTypeSource#

Constructors

ForallT [TyVarBndrSpecificity] CxtType
forall <vars>. <ctxt> => <type>
ForallVisT [TyVarBndr ()] Type
forall <vars> -> <type>
AppTTypeType
T a b
AppKindTTypeKind
T @k t
SigTTypeKind
t :: k
VarTName
a
ConTName
T
PromotedTName
'T
InfixTTypeNameType
T + T
UInfixTTypeNameType
T + T

See Language.Haskell.TH.Syntax

PromotedInfixTTypeNameType
T :+: T
PromotedUInfixTTypeNameType
T :+: T

See Language.Haskell.TH.Syntax

ParensTType
(T)
TupleTInt

(,), (,,), etc.

UnboxedTupleTInt

(#,#), (#,,#), etc.

UnboxedSumTSumArity

(#|#), (#||#), etc.

ArrowT
->
MulArrowT
%n ->

Generalised arrow type with multiplicity argument

EqualityT
~
ListT
[]
PromotedTupleTInt

'(), '(,), '(,,), etc.

PromotedNilT
'[]
PromotedConsT
'(:)
StarT
*
ConstraintT
Constraint
LitTTyLit

0, 1, 2, etc.

WildCardT
_
ImplicitParamTStringType
?x :: t

Instances

Instances details
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 TypeSource#

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

toConstr :: Type -> ConstrSource#

dataTypeOf :: Type -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepType :: Type -> TypeSource#

Methods

from :: Type -> RepType x Source#

to :: RepType x -> TypeSource#

ShowTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdTypeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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 [TyVarBndrSpecificity]) :*: (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 "PromotedInfixT" '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 "PromotedUInfixT" '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 "MulArrowT" '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)))))))

dataModuleSource#

Obtained from reifyModule and thisModule.

Constructors

ModulePkgNameModName 

Instances

Instances details
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 ModuleSource#

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

toConstr :: Module -> ConstrSource#

dataTypeOf :: Module -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepModule :: Type -> TypeSource#

ShowModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprModuleSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepModuleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeUnlifted = BoolSource#

In PrimTyConI, is the type constructor unlifted?

dataDecidedStrictnessSource#

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

Note that non-unpacked strict fields are assigned DecidedLazy when a bang would be inappropriate, such as the field of a newtype constructor and fields that have an unlifted type.

See reifyConStrictness for more information.

Constructors

DecidedLazy

Field inferred to not have a bang.

DecidedStrict

Field inferred to have a bang.

DecidedUnpack

Field inferred to be unpacked.

Instances

Instances details
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 DecidedStrictnessSource#

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

toConstr :: DecidedStrictness -> ConstrSource#

dataTypeOf :: DecidedStrictness -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDecidedStrictness :: Type -> TypeSource#

ShowDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdDecidedStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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#

SourceStrictness corresponds to strictness annotations found in the source code.

This may not agree with the annotations returned by reifyConStrictness. See reifyConStrictness for more information.

Constructors

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

Instances

Instances details
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 SourceStrictnessSource#

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

toConstr :: SourceStrictness -> ConstrSource#

dataTypeOf :: SourceStrictness -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepSourceStrictness :: Type -> TypeSource#

ShowSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdSourceStrictnessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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#

SourceUnpackedness corresponds to unpack annotations found in the source code.

This may not agree with the annotations returned by reifyConStrictness. See reifyConStrictness for more information.

Constructors

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

Instances

Instances details
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 SourceUnpackednessSource#

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

toConstr :: SourceUnpackedness -> ConstrSource#

dataTypeOf :: SourceUnpackedness -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepSourceUnpackedness :: Type -> TypeSource#

ShowSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdSourceUnpackednessSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

dataFixitySource#

Instances

Instances details
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 FixitySource#

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

toConstr :: Fixity -> ConstrSource#

dataTypeOf :: Fixity -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepFixity :: Type -> TypeSource#

ShowFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdFixitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepFixitySource# 
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.

Multiplicity annotations for data types are currently not supported in Template Haskell (i.e. all fields represented by Template Haskell will be linear).

Constructors

NormalCName [BangType]
C Int a
RecCName [VarBangType]
C { v :: Int, w :: a }
InfixCBangTypeNameBangType
Int :+ a
ForallC [TyVarBndrSpecificity] 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
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 ConSource#

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

toConstr :: Con -> ConstrSource#

dataTypeOf :: Con -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepCon :: Type -> TypeSource#

Methods

from :: Con -> RepCon x Source#

to :: RepCon x -> ConSource#

ShowConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdConSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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 [TyVarBndrSpecificity]) :*: (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))))))

typeStrict = BangSource#

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

newtypeQ a Source#

Constructors

Q 

Fields

Instances

Instances details
MonadFailQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

fail :: String -> Q a Source#

MonadFixQSource#

If the function passed to mfix inspects its argument, the resulting action will throw a FixIOException.

Since: template-haskell-2.17.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

mfix :: (a -> Q a) -> Q a Source#

MonadIOQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

liftIO :: IO a -> Q a Source#

ApplicativeQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

pure :: a -> Q a Source#

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

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

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

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

FunctorQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

MonadQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

return :: a -> Q a Source#

QuasiQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

QuoteQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Monoid a => Monoid (Q a)Source#

Since: template-haskell-2.17.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

mempty :: Q a Source#

mappend :: Q a -> Q a -> Q a Source#

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

Semigroup a => Semigroup (Q a)Source#

Since: template-haskell-2.17.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(<>) :: Q a -> Q a -> Q a Source#

sconcat :: NonEmpty (Q a) -> Q a Source#

stimes :: Integral b => b -> Q a -> Q a Source#

classMonad m => Quote m whereSource#

The Quote class implements the minimal interface which is necessary for desugaring quotations.

  • The Monad m superclass is needed to stitch together the different AST fragments.
  • newName is used when desugaring binding structures such as lambdas to generate fresh names.

Therefore the type of an untyped quotation in GHC is `Quote m => m Exp`

For many years the type of a quotation was fixed to be `Q Exp` but by more precisely specifying the minimal interface it enables the Exp to be extracted purely from the quotation without interacting with Q.

Methods

newName :: String -> m NameSource#

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.

Instances

Instances details
QuoteIOSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

QuoteQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataLocSource#

Instances

Instances details
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 LocSource#

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

toConstr :: Loc -> ConstrSource#

dataTypeOf :: Loc -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepLoc :: Type -> TypeSource#

Methods

from :: Loc -> RepLoc x Source#

to :: RepLoc x -> LocSource#

ShowLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Loc -> Loc -> BoolSource#

(/=) :: Loc -> Loc -> BoolSource#

OrdLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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

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
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 InfoSource#

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

toConstr :: Info -> ConstrSource#

dataTypeOf :: Info -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepInfo :: Type -> TypeSource#

Methods

from :: Info -> RepInfo x Source#

to :: RepInfo x -> InfoSource#

ShowInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: Info -> Info -> BoolSource#

(/=) :: Info -> Info -> BoolSource#

OrdInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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))))))

dataModuleInfoSource#

Obtained from reifyModule in the Q Monad.

Constructors

ModuleInfo [Module]

Contains the import list of the module.

Instances

Instances details
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 ModuleInfoSource#

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

toConstr :: ModuleInfo -> ConstrSource#

dataTypeOf :: ModuleInfo -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepModuleInfo :: Type -> TypeSource#

ShowModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdModuleInfoSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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])))

typeInstanceDec = DecSource#

InstanceDec describes a single instance of a class or type function. It is just a Dec, but guaranteed to be one of the following:

typeParentName = NameSource#

In ClassOpI and DataConI, name of the parent class or type

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:

typeSumArity = IntSource#

In UnboxedSumE, UnboxedSumT, and UnboxedSumP, the total number of SumAlts. For example, (#|#) has a SumArity of 2.

typeArity = IntSource#

In PrimTyConI, arity of the type constructor

dataAnnLookupSource#

Annotation target for reifyAnnotations

Instances

Instances details
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 AnnLookupSource#

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

toConstr :: AnnLookup -> ConstrSource#

dataTypeOf :: AnnLookup -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepAnnLookup :: Type -> TypeSource#

ShowAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdAnnLookupSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

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" ||]) 

Representation-polymorphic since template-haskell-2.16.0.0.

Constructors

TExp 

Fields

  • unType :: Exp

    Underlying untyped Template Haskell expression

newtypeCode m (a :: TYPE (r :: RuntimeRep)) Source#

Constructors

Code 

Fields

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
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 NameSource#

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

toConstr :: Name -> ConstrSource#

dataTypeOf :: Name -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepName :: Type -> TypeSource#

Methods

from :: Name -> RepName x Source#

to :: RepName x -> NameSource#

ShowNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprNameSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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
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 NameSpaceSource#

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

toConstr :: NameSpace -> ConstrSource#

dataTypeOf :: NameSpace -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepNameSpace :: Type -> TypeSource#

ShowNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdNameSpaceSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

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 }
TypeDataDName [TyVarBndr ()] (MaybeKind) [Con]
{ type data T x = A x | B (T x) }
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 }
DefaultD [Type]
{ default (Integer, Double) }
PragmaD

pragmas

Fields

  • Pragma
    { {-# INLINE [1] foo #-} }
DataFamilyD

data families (may also appear in [Dec] of ClassD and InstanceD)

Fields

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 ... }
OpenTypeFamilyD

open type families (may also appear in [Dec] of ClassD and InstanceD)

Fields

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 }
PatSynD

Pattern Synonyms

Fields

  • Name
     
  • PatSynArgs
     
  • PatSynDir
     
  • Pat

    { 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
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 DecSource#

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

toConstr :: Dec -> ConstrSource#

dataTypeOf :: Dec -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDec :: Type -> TypeSource#

Methods

from :: Dec -> RepDec x Source#

to :: RepDec x -> DecSource#

ShowDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdDecSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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 "TypeDataD" '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)) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Con]))) :+: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 "DefaultD" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Type])))))) :+: (((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)))))))

dataClauseSource#

Constructors

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

Instances

Instances details
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 ClauseSource#

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

toConstr :: Clause -> ConstrSource#

dataTypeOf :: Clause -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepClause :: Type -> TypeSource#

ShowClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprClauseSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataBangSource#

Constructors

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

Instances

Instances details
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 BangSource#

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

toConstr :: Bang -> ConstrSource#

dataTypeOf :: Bang -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepBang :: Type -> TypeSource#

Methods

from :: Bang -> RepBang x Source#

to :: RepBang x -> BangSource#

ShowBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprBangSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepBangSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataCallconvSource#

Constructors

CCall 
StdCall 
CApi 
Prim 
JavaScript 

Instances

Instances details
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 CallconvSource#

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

toConstr :: Callconv -> ConstrSource#

dataTypeOf :: Callconv -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepCallconv :: Type -> TypeSource#

ShowCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdCallconvSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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))))

dataSafetySource#

Constructors

Unsafe 
Safe 
Interruptible 

Instances

Instances details
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 SafetySource#

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

toConstr :: Safety -> ConstrSource#

dataTypeOf :: Safety -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepSafety :: Type -> TypeSource#

ShowSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdSafetySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

dataPragmaSource#

Instances

Instances details
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 PragmaSource#

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

toConstr :: Pragma -> ConstrSource#

dataTypeOf :: Pragma -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPragma :: Type -> TypeSource#

ShowPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdPragmaSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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 "OpaqueP" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Name))) :+: (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))))))

dataInlineSource#

Constructors

NoInline 
Inline 
Inlinable 

Instances

Instances details
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 InlineSource#

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

toConstr :: Inline -> ConstrSource#

dataTypeOf :: Inline -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepInline :: Type -> TypeSource#

ShowInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdInlineSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

dataRuleMatchSource#

Constructors

ConLike 
FunLike 

Instances

Instances details
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 RuleMatchSource#

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

toConstr :: RuleMatch -> ConstrSource#

dataTypeOf :: RuleMatch -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepRuleMatch :: Type -> TypeSource#

ShowRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdRuleMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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))

dataPhasesSource#

Instances

Instances details
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 PhasesSource#

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

toConstr :: Phases -> ConstrSource#

dataTypeOf :: Phases -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPhases :: Type -> TypeSource#

ShowPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdPhasesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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))))

dataRuleBndrSource#

Instances

Instances details
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 RuleBndrSource#

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

toConstr :: RuleBndr -> ConstrSource#

dataTypeOf :: RuleBndr -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepRuleBndr :: Type -> TypeSource#

ShowRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepRuleBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataAnnTargetSource#

Instances

Instances details
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 AnnTargetSource#

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

toConstr :: AnnTarget -> ConstrSource#

dataTypeOf :: AnnTarget -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepAnnTarget :: Type -> TypeSource#

ShowAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdAnnTargetSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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))))

dataFunDepSource#

Constructors

FunDep [Name] [Name] 

Instances

Instances details
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 FunDepSource#

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

toConstr :: FunDep -> ConstrSource#

dataTypeOf :: FunDep -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepFunDep :: Type -> TypeSource#

ShowFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprFunDepSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepFunDepSource# 
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
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 TySynEqnSource#

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

toConstr :: TySynEqn -> ConstrSource#

dataTypeOf :: TySynEqn -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepTySynEqn :: Type -> TypeSource#

ShowTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdTySynEqnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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
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 TypeFamilyHeadSource#

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

toConstr :: TypeFamilyHead -> ConstrSource#

dataTypeOf :: TypeFamilyHead -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepTypeFamilyHead :: Type -> TypeSource#

ShowTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepTypeFamilyHeadSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataFixityDirectionSource#

Constructors

InfixL 
InfixR 
InfixN 

Instances

Instances details
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 FixityDirectionSource#

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

toConstr :: FixityDirection -> ConstrSource#

dataTypeOf :: FixityDirection -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepFixityDirection :: Type -> TypeSource#

ShowFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdFixityDirectionSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

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
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 PatSynDirSource#

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

toConstr :: PatSynDir -> ConstrSource#

dataTypeOf :: PatSynDir -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPatSynDir :: Type -> TypeSource#

ShowPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdPatSynDirSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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]))))

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
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 PatSynArgsSource#

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

toConstr :: PatSynArgs -> ConstrSource#

dataTypeOf :: PatSynArgs -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPatSynArgs :: Type -> TypeSource#

ShowPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepPatSynArgsSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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 }
LamCasesE [Clause]
{ \cases 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 (MaybeModName) [Stmt]

{ do { p <- e1; e2 } } or a qualified do if the module name is present

MDoE (MaybeModName) [Stmt]

{ mdo { x <- e1 y; y <- e2 x; } } or a qualified mdo if the module name is present

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 )

GetFieldEExpString

{ exp.field } ( Overloaded Record Dot )

ProjectionE (NonEmptyString)

(.x) or (.x.y) (Record projections)

Instances

Instances details
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 ExpSource#

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

toConstr :: Exp -> ConstrSource#

dataTypeOf :: Exp -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepExp :: Type -> TypeSource#

Methods

from :: Exp -> RepExp x Source#

to :: RepExp x -> ExpSource#

ShowExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdExpSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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 "LamCasesE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Clause])) :+: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 (MaybeModName)) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 [Stmt])) :+:C1 ('MetaCons "MDoE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (MaybeModName)) :*: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))) :+: (C1 ('MetaCons "GetFieldE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0Exp) :*:S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0String)) :+:C1 ('MetaCons "ProjectionE" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: MaybeSymbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 (NonEmptyString))))))))

dataMatchSource#

Constructors

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

Instances

Instances details
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 MatchSource#

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

toConstr :: Match -> ConstrSource#

dataTypeOf :: Match -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepMatch :: Type -> TypeSource#

ShowMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdMatchSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprMatchSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepMatchSource# 
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
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 BodySource#

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

toConstr :: Body -> ConstrSource#

dataTypeOf :: Body -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepBody :: Type -> TypeSource#

Methods

from :: Body -> RepBody x Source#

to :: RepBody x -> BodySource#

ShowBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdBodySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

dataGuardSource#

Constructors

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

Instances

Instances details
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 GuardSource#

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

toConstr :: Guard -> ConstrSource#

dataTypeOf :: Guard -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepGuard :: Type -> TypeSource#

ShowGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdGuardSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepGuardSource# 
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
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 StmtSource#

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

toConstr :: Stmt -> ConstrSource#

dataTypeOf :: Stmt -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepStmt :: Type -> TypeSource#

Methods

from :: Stmt -> RepStmt x Source#

to :: RepStmt x -> StmtSource#

ShowStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprStmtSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepStmtSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataRangeSource#

Instances

Instances details
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 RangeSource#

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

toConstr :: Range -> ConstrSource#

dataTypeOf :: Range -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepRange :: Type -> TypeSource#

ShowRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprRangeSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepRangeSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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
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 LitSource#

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

toConstr :: Lit -> ConstrSource#

dataTypeOf :: Lit -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepLit :: Type -> TypeSource#

Methods

from :: Lit -> RepLit x Source#

to :: RepLit x -> LitSource#

ShowLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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))))))

dataPatSource#

Pattern in Haskell given in {}

Constructors

LitPLit
{ 5 or 'c' }
VarPName
{ x }
TupP [Pat]
{ (p1,p2) }
UnboxedTupP [Pat]
{ (# p1,p2 #) }
UnboxedSumPPatSumAltSumArity
{ (#|p|#) }
ConPName [Type] [Pat]
data T1 = C1 t1 t2; {C1 @ty1 p1 p2} = 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
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 PatSource#

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

toConstr :: Pat -> ConstrSource#

dataTypeOf :: Pat -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPat :: Type -> TypeSource#

Methods

from :: Pat -> RepPat x Source#

to :: RepPat x -> PatSource#

ShowPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdPatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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 [Type]) :*: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)))))))

dataTyVarBndr flag Source#

Constructors

PlainTVName flag
a
KindedTVName flag Kind
(a :: k)

Instances

Instances details
FunctorTyVarBndrSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

fmap :: (a -> b) -> TyVarBndr a -> TyVarBndr b Source#

(<$) :: a -> TyVarBndr b -> TyVarBndr a Source#

Data flag => Data (TyVarBndr flag)Source# 
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 flag -> c (TyVarBndr flag) Source#

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

toConstr :: TyVarBndr flag -> ConstrSource#

dataTypeOf :: TyVarBndr flag -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

Generic (TyVarBndr flag)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRep (TyVarBndr flag) :: Type -> TypeSource#

Methods

from :: TyVarBndr flag -> Rep (TyVarBndr flag) x Source#

to :: Rep (TyVarBndr flag) x -> TyVarBndr flag Source#

Show flag => Show (TyVarBndr flag)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Eq flag => Eq (TyVarBndr flag)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

(==) :: TyVarBndr flag -> TyVarBndr flag -> BoolSource#

(/=) :: TyVarBndr flag -> TyVarBndr flag -> BoolSource#

Ord flag => Ord (TyVarBndr flag)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

compare :: TyVarBndr flag -> TyVarBndr flag -> OrderingSource#

(<) :: TyVarBndr flag -> TyVarBndr flag -> BoolSource#

(<=) :: TyVarBndr flag -> TyVarBndr flag -> BoolSource#

(>) :: TyVarBndr flag -> TyVarBndr flag -> BoolSource#

(>=) :: TyVarBndr flag -> TyVarBndr flag -> BoolSource#

max :: TyVarBndr flag -> TyVarBndr flag -> TyVarBndr flag Source#

min :: TyVarBndr flag -> TyVarBndr flag -> TyVarBndr flag Source#

PprFlag flag => Ppr (TyVarBndr flag)Source# 
Instance details

Defined in Language.Haskell.TH.Ppr

Methods

ppr :: TyVarBndr flag -> DocSource#

ppr_list :: [TyVarBndr flag] -> DocSource#

typeRep (TyVarBndr flag)Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataTyLitSource#

Constructors

NumTyLitInteger
2
StrTyLitString
"Hello"
CharTyLitChar

'C', @since 4.16.0.0

Instances

Instances details
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 TyLitSource#

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

toConstr :: TyLit -> ConstrSource#

dataTypeOf :: TyLit -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepTyLit :: Type -> TypeSource#

ShowTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepTyLitSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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.

typeCxtSource#

Arguments

 = [Pred]
(Eq a, Ord b)

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.

dataRoleSource#

Role annotations

Constructors

NominalR
nominal
RepresentationalR
representational
PhantomR
phantom
InferR
_

Instances

Instances details
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 RoleSource#

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

toConstr :: Role -> ConstrSource#

dataTypeOf :: Role -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepRole :: Type -> TypeSource#

Methods

from :: Role -> RepRole x Source#

to :: RepRole x -> RoleSource#

ShowRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

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

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

OrdRoleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

dataSpecificitySource#

Instances

Instances details
DataSpecificitySource# 
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) -> Specificity -> c SpecificitySource#

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

toConstr :: Specificity -> ConstrSource#

dataTypeOf :: Specificity -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericSpecificitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepSpecificity :: Type -> TypeSource#

ShowSpecificitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqSpecificitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdSpecificitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

PprFlagSpecificitySource# 
Instance details

Defined in Language.Haskell.TH.Ppr

typeRepSpecificitySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepSpecificity = D1 ('MetaData "Specificity" "Language.Haskell.TH.Syntax" "template-haskell" 'False) (C1 ('MetaCons "SpecifiedSpec" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "InferredSpec" 'PrefixI 'False) (U1 :: Type -> Type))

dataFamilyResultSigSource#

Type family result signature

Constructors

NoSig

no signature

KindSigKind
k
TyVarSig (TyVarBndr ())
= r, = (r :: k)

Instances

Instances details
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 FamilyResultSigSource#

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

toConstr :: FamilyResultSig -> ConstrSource#

dataTypeOf :: FamilyResultSig -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepFamilyResultSig :: Type -> TypeSource#

ShowFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdFamilyResultSigSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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) (Rec0 (TyVarBndr ())))))

dataInjectivityAnnSource#

Injectivity annotation

Constructors

InjectivityAnnName [Name] 

Instances

Instances details
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 InjectivityAnnSource#

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

toConstr :: InjectivityAnn -> ConstrSource#

dataTypeOf :: InjectivityAnn -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepInjectivityAnn :: Type -> TypeSource#

ShowInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdInjectivityAnnSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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])))

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.

dataDocLocSource#

A location at which to attach Haddock documentation. Note that adding documentation to a Name defined oustide of the current module will cause an error.

Constructors

ModuleDoc

At the current module's header.

DeclDocName

At a declaration, not necessarily top level.

ArgDocNameInt

At a specific argument of a function, indexed by its position.

InstDocType

At a class or family instance.

Instances

Instances details
DataDocLocSource# 
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) -> DocLoc -> c DocLocSource#

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

toConstr :: DocLoc -> ConstrSource#

dataTypeOf :: DocLoc -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericDocLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDocLoc :: Type -> TypeSource#

ShowDocLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqDocLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdDocLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepDocLocSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataDerivClauseSource#

A single deriving clause at the end of a datatype.

Constructors

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

Instances

Instances details
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 DerivClauseSource#

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

toConstr :: DerivClause -> ConstrSource#

dataTypeOf :: DerivClause -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDerivClause :: Type -> TypeSource#

ShowDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepDerivClauseSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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
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 DerivStrategySource#

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

toConstr :: DerivStrategy -> ConstrSource#

dataTypeOf :: DerivStrategy -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepDerivStrategy :: Type -> TypeSource#

ShowDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdDerivStrategySource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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))))

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 Overlapping and Overlappable, and pick an arbitrary one if multiple choices are available.

Instances

Instances details
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 OverlapSource#

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

toConstr :: Overlap -> ConstrSource#

dataTypeOf :: Overlap -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepOverlap :: Type -> TypeSource#

ShowOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdOverlapSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

typeUniq = IntegerSource#

Uniq is used by GHC to distinguish names from each other.

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
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 NameFlavourSource#

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

toConstr :: NameFlavour -> ConstrSource#

dataTypeOf :: NameFlavour -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepNameFlavour :: Type -> TypeSource#

ShowNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

typeRepNameFlavourSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

dataNameIsSource#

Constructors

Alone 
Applied 
Infix 

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

Instances

Instances details
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 BytesSource#

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

toConstr :: Bytes -> ConstrSource#

dataTypeOf :: Bytes -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepBytes :: Type -> TypeSource#

ShowBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdBytesSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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))))

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#

qGetPackageRoot :: m FilePathSource#

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#

qPutDoc :: DocLoc -> String -> m () Source#

qGetDoc :: DocLoc -> m (MaybeString) Source#

Instances

Instances details
QuasiIOSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

QuasiQSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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

Representation-polymorphic since template-haskell-2.16.0.0.

Minimal complete definition

liftTyped

Methods

lift :: Quote m => t -> m ExpSource#

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

defaultlift :: (r ~ 'BoxedRep 'Lifted, Quote m) => t -> m ExpSource#

liftTyped :: Quote m => t -> Code m t Source#

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

Since: template-haskell-2.16.0.0

Instances

Instances details
LiftAddr#Source#

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

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Addr# -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Addr# -> Code m Addr#Source#

LiftDouble#Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Double# -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Double# -> Code m Double#Source#

LiftFloat#Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Float# -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Float# -> Code m Float#Source#

LiftInt#Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Int# -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Int# -> Code m Int#Source#

LiftByteArraySource#

Since: template-haskell-2.19.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => ByteArray -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => ByteArray -> Code m ByteArraySource#

LiftVoidSource#

Since: template-haskell-2.15.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Void -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Void -> Code m VoidSource#

LiftInt16Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Int16 -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Int16 -> Code m Int16Source#

LiftInt32Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Int32 -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Int32 -> Code m Int32Source#

LiftInt64Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Int64 -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Int64 -> Code m Int64Source#

LiftInt8Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Int8 -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Int8 -> Code m Int8Source#

LiftWord16Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Word16 -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Word16 -> Code m Word16Source#

LiftWord32Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Word32 -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Word32 -> Code m Word32Source#

LiftWord64Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Word64 -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Word64 -> Code m Word64Source#

LiftWord8Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Word8 -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Word8 -> Code m Word8Source#

LiftIntegerSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Integer -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Integer -> Code m IntegerSource#

LiftNaturalSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Natural -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Natural -> Code m NaturalSource#

Lift ()Source# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => () -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => () -> Code m () Source#

LiftBoolSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Bool -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Bool -> Code m BoolSource#

LiftCharSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Char -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Char -> Code m CharSource#

LiftDoubleSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Double -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Double -> Code m DoubleSource#

LiftFloatSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Float -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Float -> Code m FloatSource#

LiftIntSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Int -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Int -> Code m IntSource#

LiftWordSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Word -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Word -> Code m WordSource#

LiftChar#Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Char# -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Char# -> Code m Char#Source#

LiftWord#Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Word# -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Word# -> Code m Word#Source#

Lift (# #)Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# #) -> Code m (# #) Source#

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

Since: template-haskell-2.15.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => NonEmpty a -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => NonEmpty a -> Code m (NonEmpty a) Source#

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

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Ratio a -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Ratio a -> Code m (Ratio a) Source#

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

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Maybe a -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Maybe a -> Code m (Maybe a) Source#

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

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => [a] -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => [a] -> Code m [a] Source#

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

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => Either a b -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => Either a b -> Code m (Either a b) Source#

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

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (a, b) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (a, b) -> Code m (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 :: Quote m => (a, b, c) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (a, b, c) -> Code m (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 :: Quote m => (a, b, c, d) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (a, b, c, d) -> Code m (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 :: Quote m => (a, b, c, d, e) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (a, b, c, d, e) -> Code m (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 :: Quote m => (a, b, c, d, e, f) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (a, b, c, d, e, f) -> Code m (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 :: Quote m => (a, b, c, d, e, f, g) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (a, b, c, d, e, f, g) -> Code m (a, b, c, d, e, f, g) Source#

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

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a #) -> Code m (# a #) Source#

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

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a | b #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a | b #) -> Code m (# a | b #) Source#

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

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a, b #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a, b #) -> Code m (# a, b #) Source#

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

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a | b | c #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a | b | c #) -> Code m (# a | b | c #) Source#

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

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a, b, c #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a, b, c #) -> Code m (# a, b, c #) Source#

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

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a | b | c | d #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a | b | c | d #) -> Code m (# a | b | c | d #) Source#

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

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a, b, c, d #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a, b, c, d #) -> Code m (# a, b, c, d #) 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: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a | b | c | d | e #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a | b | c | d | e #) -> Code m (# a | b | c | d | e #) 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: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a, b, c, d, e #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a, b, c, d, e #) -> Code m (# 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 ('SumRep '[LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep]))Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a | b | c | d | e | f #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a | b | c | d | e | f #) -> Code m (# 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 ('TupleRep '[LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep]))Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a, b, c, d, e, f #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a, b, c, d, e, f #) -> Code m (# 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 ('SumRep '[LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep]))Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a | b | c | d | e | f | g #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a | b | c | d | e | f | g #) -> Code m (# 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 ('TupleRep '[LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep, LiftedRep]))Source#

Since: template-haskell-2.16.0.0

Instance details

Defined in Language.Haskell.TH.Syntax

Methods

lift :: Quote m => (# a, b, c, d, e, f, g #) -> m ExpSource#

liftTyped :: forall (m :: Type -> Type). Quote m => (# a, b, c, d, e, f, g #) -> Code m (# a, b, c, d, e, f, g #) Source#

newtypeModNameSource#

Constructors

ModNameString 

Instances

Instances details
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 ModNameSource#

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

toConstr :: ModName -> ConstrSource#

dataTypeOf :: ModName -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepModName :: Type -> TypeSource#

ShowModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdModNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

newtypePkgNameSource#

Constructors

PkgNameString 

Instances

Instances details
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 PkgNameSource#

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

toConstr :: PkgName -> ConstrSource#

dataTypeOf :: PkgName -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepPkgName :: Type -> TypeSource#

ShowPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdPkgNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

newtypeOccNameSource#

Constructors

OccNameString 

Instances

Instances details
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 OccNameSource#

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

toConstr :: OccName -> ConstrSource#

dataTypeOf :: OccName -> DataTypeSource#

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

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

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

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

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

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

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

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

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

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

GenericOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

Associated Types

typeRepOccName :: Type -> TypeSource#

ShowOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

EqOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

OrdOccNameSource# 
Instance details

Defined in Language.Haskell.TH.Syntax

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)))

typeCharPosSource#

Arguments

 = (Int, Int)

Line and character position

typeStrictType = BangTypeSource#

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

typeVarStrictType = VarBangTypeSource#

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

recoverSource#

Arguments

:: Q a

handler to invoke on failure

-> Q a

computation to run

-> Q a 

Recover from errors raised by reportError or fail.

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.

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.

runQ :: Quasi m => Q a -> m a Source#

reportWarning :: String -> Q () Source#

Report a warning to the user, and carry on.

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.

location :: QLocSource#

The location at which this computation is spliced.

reify :: Name -> QInfoSource#

reify looks up information about the Name. It will fail with a compile error if the Name is not visible. A Name is visible if it is imported or defined in a prior top-level declaration group. See the documentation for newDeclarationGroup for more details.

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.

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.

newDeclarationGroup :: Q [Dec] Source#

Template Haskell is capable of reifying information about types and terms defined in previous declaration groups. Top-level declaration splices break up declaration groups.

For an example, consider this code block. We define a datatype X and then try to call reify on the datatype.

module Check where data X = X deriving Eq $(do info <- reify ''X runIO $ print info ) 

This code fails to compile, noting that X is not available for reification at the site of reify. We can fix this by creating a new declaration group using an empty top-level splice:

data X = X deriving Eq $(pure []) $(do info <- reify ''X runIO $ print info ) 

We provide newDeclarationGroup as a means of documenting this behavior and providing a name for the pattern.

Since top level splices infer the presence of the $( ... ) brackets, we can also write:

data X = X deriving Eq newDeclarationGroup $(do info <- reify ''X runIO $ print info ) 

extsEnabled :: Q [Extension] Source#

List all enabled language extensions.

isExtEnabled :: Extension -> QBoolSource#

Determine whether the given language extension is enabled in the Q monad.

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.

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 all visible instances (see below for "visible") 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).

In principle, the *visible* instances are * all instances defined in a prior top-level declaration group (see docs on newDeclarationGroup), or * all instances defined in any module transitively imported by the module being compiled

However, actually searching all modules transitively below the one being compiled is unreasonably expensive, so reifyInstances will report only the instance for modules that GHC has had some cause to visit during this compilation. This is a shortcoming: reifyInstances might fail to report instances for a type that is otherwise unusued, or instances defined in a different component. You can work around this shortcoming by explicitly importing the modules whose instances you want to be visible. GHC issue #20529 has some discussion around this.

isInstance :: Name -> [Type] -> QBoolSource#

Is the list of instances returned by reifyInstances nonempty?

If you're confused by an instance not being visible despite being defined in the same module and above the splice in question, see the docs for newDeclarationGroup for a possible explanation.

reifyRoles :: Name -> Q [Role] Source#

reifyRoles nm returns the list of roles associated with the parameters (both visible and invisible) of the tycon nm. Fails if nm cannot be found or is not a tycon. The returned list should never contain InferR.

An invisible parameter to a tycon is often a kind parameter. For example, if we have

type Proxy :: forall k. k -> Type data Proxy a = MkProxy 

and reifyRoles Proxy, we will get [NominalR, PhantomR]. The NominalR is the role of the invisible k parameter. Kind parameters are always nominal.

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.

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.

unTypeCode :: forall (r :: RuntimeRep) (a :: TYPE r) m. Quote m => Code m a -> m ExpSource#

Extract the untyped representation from the typed representation

unsafeCodeCoerce :: forall (r :: RuntimeRep) (a :: TYPE r) m. Quote m => m Exp -> Code m a Source#

Unsafely convert an untyped code representation into a typed code representation.

hoistCode :: forall m n (r :: RuntimeRep) (a :: TYPE r). Monad m => (forall x. m x -> n x) -> Code m a -> Code n a Source#

Modify the ambient monad used during code generation. For example, you can use hoistCode to handle a state effect: handleState :: Code (StateT Int Q) a -> Code Q a handleState = hoistCode (flip runState 0)

bindCode :: forall m a (r :: RuntimeRep) (b :: TYPE r). Monad m => m a -> (a -> Code m b) -> Code m b Source#

Variant of (>>=) which allows effectful computations to be injected into code generation.

bindCode_ :: forall m a (r :: RuntimeRep) (b :: TYPE r). Monad m => m a -> Code m b -> Code m b Source#

Variant of (>>) which allows effectful computations to be injected into code generation.

joinCode :: forall m (r :: RuntimeRep) (a :: TYPE r). Monad m => m (Code m a) -> Code m a Source#

A useful combinator for embedding monadic actions into Code myCode :: ... => Code m a myCode = joinCode $ do x <- someSideEffect return (makeCodeWith x)

liftCode :: forall (r :: RuntimeRep) (a :: TYPE r) m. m (TExp a) -> Code m a Source#

Lift a monadic action producing code into the typed Code representation

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") |]

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 

tupleTypeName :: Int -> NameSource#

Tuple type constructor

tupleDataName :: Int -> NameSource#

Tuple data constructor

unboxedTupleTypeName :: Int -> NameSource#

Unboxed tuple type constructor

unboxedTupleDataName :: Int -> NameSource#

Unboxed tuple data constructor

unboxedSumTypeName :: SumArity -> NameSource#

Unboxed sum type constructor

unboxedSumDataName :: SumAlt -> SumArity -> NameSource#

Unboxed sum data constructor

defaultFixity :: FixitySource#

Default fixity: infixl 9

maxPrecedence :: IntSource#

Highest allowed operator precedence for Fixity constructor (answer: 9)

putDoc :: DocLoc -> String -> Q () Source#

Add Haddock documentation to the specified location. This will overwrite any documentation at the location if it already exists. This will reify the specified name, so it must be in scope when you call it. If you want to add documentation to something that you are currently splicing, you can use addModFinalizer e.g.

do let nm = mkName "x" addModFinalizer $ putDoc (DeclDoc nm) "Hello" [d| $(varP nm) = 42 |]

The helper functions withDecDoc and withDecsDoc will do this for you, as will the funD_doc and other _doc combinators. You most likely want to have the -haddock flag turned on when using this. Adding documentation to anything outside of the current module will cause an error.

getDoc :: DocLoc -> Q (MaybeString) Source#

Retreives the Haddock documentation at the specified location, if one exists. It can be used to read documentation on things defined outside of the current module, provided that those modules were compiled with the -haddock flag.

dataToQa :: forall m a k q. (Quote m, Data a) => (Name -> k) -> (Lit -> m q) -> (k -> [m q] -> m q) -> (forall b. Data b => b -> Maybe (m q)) -> a -> m 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 :: (Quote m, Data a) => (forall b. Data b => b -> Maybe (m Exp)) -> a -> m ExpSource#

dataToExpQ converts a value to a 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.

dataToPatQ :: (Quote m, Data a) => (forall b. Data b => b -> Maybe (m Pat)) -> a -> m PatSource#

dataToPatQ converts a value to a 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.

mkNameU :: String -> Uniq -> NameSource#

Only used internally

unTypeQ :: forall (r :: RuntimeRep) (a :: TYPE r) m. Quote m => m (TExp a) -> m ExpSource#

Discard the type annotation and produce a plain Template Haskell expression

Representation-polymorphic since template-haskell-2.16.0.0.

unsafeTExpCoerce :: forall (r :: RuntimeRep) (a :: TYPE r) m. Quote m => m Exp -> m (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.

Representation-polymorphic since template-haskell-2.16.0.0.

getPackageRoot :: QFilePathSource#

Get the package root for the current package which is being compiled. This can be set explicitly with the -package-root flag but is normally just the current working directory.

The motivation for this flag is to provide a principled means to remove the assumption from splices that they will be executed in the directory where the cabal file resides. Projects such as haskell-language-server can't and don't change directory when compiling files but instead set the -package-root flag appropiately.

makeRelativeToProject :: FilePath -> QFilePathSource#

The input is a filepath, which if relative is offset by the package root.

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 (819 + 1) ++ " " ++ show "libraries/template-haskell/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.

sequenceQ :: forall m. Monad m => forall a. [m a] -> m [a] Source#

mkNameG :: NameSpace -> String -> String -> String -> NameSource#

Used for 'x etc, but not available to the programmer

liftData :: (Quote m, Data a) => a -> m ExpSource#

liftData is a variant of lift in the Lift type class which works for any type with a Data instance.

mkNameL :: String -> Uniq -> NameSource#

Only used internally

mkNameQ :: String -> String -> NameSource#

Only used internally

memcmp :: Ptr a -> Ptr b -> CSize -> IOCIntSource#

Language extensions

dataForeignSrcLangSource#

Foreign formats supported by GHC via TH

Constructors

LangC

C

LangCxx

C++

LangObjc

Objective C

LangObjcxx

Objective C++

LangAsm

Assembly language (.s)

LangJs

JavaScript

RawObject

Object (.o)

Instances

Instances details
GenericForeignSrcLang 
Instance details

Defined in GHC.ForeignSrcLang.Type

Associated Types

typeRepForeignSrcLang :: Type -> TypeSource#

ShowForeignSrcLang 
Instance details

Defined in GHC.ForeignSrcLang.Type

EqForeignSrcLang 
Instance details

Defined in GHC.ForeignSrcLang.Type

typeRepForeignSrcLang 
Instance details

Defined in GHC.ForeignSrcLang.Type

typeRepForeignSrcLang = D1 ('MetaData "ForeignSrcLang" "GHC.ForeignSrcLang.Type" "ghc-boot-th-9.6.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 "LangJs" 'PrefixI 'False) (U1 :: Type -> Type) :+:C1 ('MetaCons "RawObject" 'PrefixI 'False) (U1 :: Type -> Type))))

Notes

Unresolved Infix

When implementing antiquotation for quasiquoters, one often wants to parse strings into expressions:

parse :: String -> Maybe Exp

But how should we parse a + b * c? If we don't know the fixities of + and *, we don't know whether to parse it as a + (b * c) or (a + b) * c.

In cases like this, use UInfixE, UInfixP, UInfixT, or PromotedUInfixT, which stand for "unresolved infix expressionpatterntype/promoted constructor", respectively. When the compiler is given a splice containing a tree of UInfixE applications such as

UInfixE (UInfixE e1 op1 e2) op2 (UInfixE e3 op3 e4)

it will look up and the fixities of the relevant operators and reassociate the tree as necessary.

  • trees will not be reassociated across ParensE, ParensP, or ParensT, which are of use for parsing expressions like
(a + b * c) + d * e
  • InfixE, InfixP, InfixT, and PromotedInfixT expressions are never reassociated.
  • The UInfixE constructor doesn't support sections. Sections such as (a *) have no ambiguity, so InfixE suffices. For longer sections such as (a + b * c -), use an InfixE constructor for the outer-most section, and use UInfixE constructors for all other operators:
InfixE Just (UInfixE ...a + b * c...) op Nothing

Sections such as (a + b +) and ((a + b) +) should be rendered into Exps differently:

(+ a + b) ---> InfixE Nothing + (Just $ UInfixE a + b) -- will result in a fixity error if (+) is left-infix (+ (a + b)) ---> InfixE Nothing + (Just $ ParensE $ UInfixE a + b) -- no fixity errors
  • Quoted expressions such as
[| a * b + c |] :: Q Exp [p| a : b : c |] :: Q Pat [t| T + T |] :: Q Type

will never contain UInfixE, UInfixP, UInfixT, PromotedUInfixT, InfixT, 'PromotedInfixT, ParensE, ParensP, or ParensT constructors.

close