-- Hoogle documentation, generated by Haddock -- See Hoogle, http://www.haskell.org/hoogle/ -- | Manipulating Haskell source: abstract syntax, lexer, parser, and pretty-printer -- -- Haskell-Source with Extensions (HSE, haskell-src-exts) is a standalone -- parser for Haskell. In addition to standard Haskell, all extensions -- implemented in GHC are supported. -- -- Apart from these standard extensions, it also handles regular patterns -- as per the HaRP extension as well as HSX-style embedded XML syntax. @package haskell-src-exts @version 1.18.0 -- | This module defines the list of recognized modular features of -- Haskell, most often (sloppily) referred to as "extensions". -- -- Closely mimicking the Language.Haskell.Extension module from the Cabal -- library, this package also includes functionality for "computing" -- languages as sets of features. Also, we make no promise not to add -- extensions not yet recognized by Cabal. module Language.Haskell.Exts.Extension data Language -- | The Haskell 98 language as defined by the Haskell 98 report. -- http://haskell.org/onlinereport/ Haskell98 :: Language -- | The Haskell 2010 language as defined by the Haskell 2010 report. -- http://www.haskell.org/onlinereport/haskell2010 Haskell2010 :: Language -- | The minimal language resulting from disabling all recognized -- extensions - including ones that are part of all known language -- definitions e.g. MonomorphismRestriction. HaskellAllDisabled :: Language -- | An unknown language, identified by its name. UnknownLanguage :: String -> Language knownLanguages :: [Language] classifyLanguage :: String -> Language prettyLanguage :: Language -> String -- | This represents language extensions beyond a base Language -- definition (such as Haskell98) that are supported by some -- implementations, usually in some special mode. data Extension -- | Enable a known extension EnableExtension :: KnownExtension -> Extension -- | Disable a known extension DisableExtension :: KnownExtension -> Extension -- | An unknown extension, identified by the name of its LANGUAGE -- pragma. UnknownExtension :: String -> Extension data KnownExtension -- |
-- import "network" Network.Socket --PackageImports :: KnownExtension LambdaCase :: KnownExtension -- |
-- import safe Network.Socket --SafeImports :: KnownExtension -- |
-- DHApp -- () -- (DHApp -- () (DHead () (Ident () "C")) (UnkindedVar () (Ident () "a"))) -- (UnkindedVar () (Ident () "b")) ---- -- (where the annotation type l is instantiated with -- ()) -- -- class (a :< b) c is represented as -- --
-- DHApp -- () -- (DHParen -- () -- (DHApp -- () -- (DHInfix () (UnkindedVar () (Ident () "a")) (Symbol () ":<")) -- (UnkindedVar () (Ident () "b")))) -- (UnkindedVar () (Ident () "c")) --data DeclHead l -- | type or class name DHead :: l -> (Name l) -> DeclHead l -- | infix application of the type/class name to the left operand DHInfix :: l -> (TyVarBind l) -> (Name l) -> DeclHead l -- | parenthesized declaration head DHParen :: l -> (DeclHead l) -> DeclHead l -- | application to one more type variable DHApp :: l -> (DeclHead l) -> (TyVarBind l) -> DeclHead l -- | The instance declaration rule, which is, roughly, the part of the -- instance declaration before the where keyword. -- -- Example: instance Ord a => Ord (Maybe a) is represented as -- --
-- IRule -- () -- Nothing -- (Just -- (CxSingle -- () -- (ClassA -- () (UnQual () (Ident () "Ord")) [ TyVar () (Ident () "a") ]))) -- (IHApp -- () -- (IHCon () (UnQual () (Ident () "Ord"))) -- (TyParen -- () -- (TyApp -- () -- (TyCon () (UnQual () (Ident () "Maybe"))) -- (TyVar () (Ident () "a"))))) ---- -- An optional explicit forall after instance is supported: -- instance forall a . Ord a => Ord (Maybe a) where becomes -- --
-- IRule -- () -- (Just [ UnkindedVar () (Ident () "a") ]) -- ... --data InstRule l IRule :: l -> (Maybe [TyVarBind l]) -> (Maybe (Context l)) -> (InstHead l) -> InstRule l IParen :: l -> (InstRule l) -> InstRule l -- | The instance head. The split between rule/head allow us to represent -- instance (Bounded a => Bounded [a]) where faithfully. -- -- The structure of InstHead follows one of DeclHead. -- -- For example, instance C (Maybe a) Int where is represented as -- --
-- IHApp -- () -- (IHApp -- () -- (IHCon () (UnQual () (Ident () "C"))) -- (TyParen -- () -- (TyApp -- () -- (TyCon () (UnQual () (Ident () "Maybe"))) -- (TyVar () (Ident () "a"))))) -- (TyCon () (UnQual () (Ident () "Int"))))) --data InstHead l -- | type or class name IHCon :: l -> (QName l) -> InstHead l -- | infix application of the type/class name to the left operand IHInfix :: l -> (Type l) -> (QName l) -> InstHead l -- | parenthesized instance head IHParen :: l -> (InstHead l) -> InstHead l -- | application to one more type IHApp :: l -> (InstHead l) -> (Type l) -> InstHead l -- | A binding group inside a let or where clause. data Binds l -- | An ordinary binding group BDecls :: l -> [Decl l] -> Binds l -- | A binding group for implicit parameters IPBinds :: l -> [IPBind l] -> Binds l -- | A binding of an implicit parameter. data IPBind l IPBind :: l -> (IPName l) -> (Exp l) -> IPBind l data PatternSynDirection l -- | A unidirectional pattern synonym with "<-" Unidirectional :: PatternSynDirection l -- | A bidirectional pattern synonym with "=" ImplicitBidirectional :: PatternSynDirection l -- | A birectional pattern synonym with the construction specified. ExplicitBidirectional :: l -> [Decl l] -> PatternSynDirection l -- | Injectivity info for injective type families data InjectivityInfo l InjectivityInfo :: l -> (Name l) -> [Name l] -> InjectivityInfo l data ResultSig l KindSig :: l -> (Kind l) -> ResultSig l TyVarSig :: l -> (TyVarBind l) -> ResultSig l -- | Declarations inside a class declaration. data ClassDecl l -- | ordinary declaration ClsDecl :: l -> (Decl l) -> ClassDecl l -- | declaration of an associated data type ClsDataFam :: l -> (Maybe (Context l)) -> (DeclHead l) -> (Maybe (ResultSig l)) -> ClassDecl l -- | declaration of an associated type synonym ClsTyFam :: l -> (DeclHead l) -> (Maybe (ResultSig l)) -> (Maybe (InjectivityInfo l)) -> ClassDecl l -- | default choice for an associated type synonym ClsTyDef :: l -> (TypeEqn l) -> ClassDecl l -- | default signature ClsDefSig :: l -> (Name l) -> (Type l) -> ClassDecl l -- | Declarations inside an instance declaration. data InstDecl l -- | ordinary declaration InsDecl :: l -> (Decl l) -> InstDecl l -- | an associated type definition InsType :: l -> (Type l) -> (Type l) -> InstDecl l -- | an associated data type implementation InsData :: l -> (DataOrNew l) -> (Type l) -> [QualConDecl l] -> (Maybe (Deriving l)) -> InstDecl l -- | an associated data type implemented using GADT style InsGData :: l -> (DataOrNew l) -> (Type l) -> (Maybe (Kind l)) -> [GadtDecl l] -> (Maybe (Deriving l)) -> InstDecl l -- | A deriving clause following a data type declaration. data Deriving l Deriving :: l -> [InstRule l] -> Deriving l -- | A flag stating whether a declaration is a data or newtype declaration. data DataOrNew l DataType :: l -> DataOrNew l NewType :: l -> DataOrNew l -- | Declaration of an ordinary data constructor. data ConDecl l -- | ordinary data constructor ConDecl :: l -> (Name l) -> [Type l] -> ConDecl l -- | infix data constructor InfixConDecl :: l -> (Type l) -> (Name l) -> (Type l) -> ConDecl l -- | record constructor RecDecl :: l -> (Name l) -> [FieldDecl l] -> ConDecl l -- | Declaration of a (list of) named field(s). data FieldDecl l FieldDecl :: l -> [Name l] -> (Type l) -> FieldDecl l -- | A single constructor declaration within a data type declaration, which -- may have an existential quantification binding. data QualConDecl l QualConDecl :: l -> (Maybe [TyVarBind l]) -> (Maybe (Context l)) -> (ConDecl l) -> QualConDecl l -- | A single constructor declaration in a GADT data type declaration. -- -- If the GADT is declared using the record syntax, e.g. -- --
-- data Ty where
-- TCon :: { field1 :: Int, field2 :: Bool } -> Ty
--
--
-- then the fields are stored as a list of FieldDecls, and the
-- final type (Ty in the above example) is stored in the last
-- Type field.
--
-- If the GADT is declared using the ordinary syntax, e.g.
--
-- -- data Ty where -- TCon :: Int -> Bool -> Ty ---- -- then Maybe [FieldDecl l] is Nothing, and -- the whole constructor's type (such as Int -> Bool -> -- Ty) is stored in the last Type field. data GadtDecl l GadtDecl :: l -> (Name l) -> (Maybe [FieldDecl l]) -> (Type l) -> GadtDecl l -- | The type of a constructor argument or field, optionally including a -- strictness annotation. data BangType l -- | strict component, marked with "!" BangedTy :: l -> BangType l -- | lazy component, marked with "~" LazyTy :: l -> BangType l -- | No strictness information NoStrictAnnot :: l -> BangType l data Unpackedness l Unpack :: l -> Unpackedness l NoUnpack :: l -> Unpackedness l NoUnpackPragma :: l -> Unpackedness l -- | Clauses of a function binding. data Match l -- | A clause defined with prefix notation, i.e. the function name followed -- by its argument patterns, the right-hand side and an optional where -- clause. Match :: l -> (Name l) -> [Pat l] -> (Rhs l) -> (Maybe (Binds l)) -> Match l -- | A clause defined with infix notation, i.e. first its first argument -- pattern, then the function name, then its following argument(s), the -- right-hand side and an optional where clause. Note that there can be -- more than two arguments to a function declared infix, hence the list -- of pattern arguments. InfixMatch :: l -> (Pat l) -> (Name l) -> [Pat l] -> (Rhs l) -> (Maybe (Binds l)) -> Match l -- | The right hand side of a function binding, pattern binding, or a case -- alternative. data Rhs l -- | unguarded right hand side (exp) UnGuardedRhs :: l -> (Exp l) -> Rhs l -- | guarded right hand side (gdrhs) GuardedRhss :: l -> [GuardedRhs l] -> Rhs l -- | A guarded right hand side | stmts = -- exp, or | stmts -> exp for -- case alternatives. The guard is a series of statements when using -- pattern guards, otherwise it will be a single qualifier expression. data GuardedRhs l GuardedRhs :: l -> [Stmt l] -> (Exp l) -> GuardedRhs l -- | A context is a set of assertions data Context l CxSingle :: l -> (Asst l) -> Context l CxTuple :: l -> [Asst l] -> Context l CxEmpty :: l -> Context l -- | A functional dependency, given on the form l1 l2 ... ln -> r2 r3 .. -- rn data FunDep l FunDep :: l -> [Name l] -> [Name l] -> FunDep l -- | Class assertions. In Haskell 98, the argument would be a tyvar, -- but this definition allows multiple parameters, and allows them to be -- types. Also extended with support for implicit parameters and -- equality constraints. data Asst l -- | ordinary class assertion ClassA :: l -> (QName l) -> [Type l] -> Asst l -- | constraint kind assertion, Dict :: cxt a => Dict cxt AppA :: l -> (Name l) -> [Type l] -> Asst l -- | class assertion where the class name is given infix InfixA :: l -> (Type l) -> (QName l) -> (Type l) -> Asst l -- | implicit parameter assertion IParam :: l -> (IPName l) -> (Type l) -> Asst l -- | type equality constraint EqualP :: l -> (Type l) -> (Type l) -> Asst l -- | parenthesised class assertion ParenA :: l -> (Asst l) -> Asst l -- | Context Wildcard WildCardA :: l -> (Maybe (Name l)) -> Asst l -- | A type qualified with a context. An unqualified type has an empty -- context. data Type l -- | qualified type TyForall :: l -> (Maybe [TyVarBind l]) -> (Maybe (Context l)) -> (Type l) -> Type l -- | function type TyFun :: l -> (Type l) -> (Type l) -> Type l -- | tuple type, possibly boxed TyTuple :: l -> Boxed -> [Type l] -> Type l -- | list syntax, e.g. [a], as opposed to [] a TyList :: l -> (Type l) -> Type l -- | parallel array syntax, e.g. [:a:] TyParArray :: l -> (Type l) -> Type l -- | application of a type constructor TyApp :: l -> (Type l) -> (Type l) -> Type l -- | type variable TyVar :: l -> (Name l) -> Type l -- | named type or type constructor TyCon :: l -> (QName l) -> Type l -- | type surrounded by parentheses TyParen :: l -> (Type l) -> Type l -- | infix type constructor TyInfix :: l -> (Type l) -> (QName l) -> (Type l) -> Type l -- | type with explicit kind signature TyKind :: l -> (Type l) -> (Kind l) -> Type l -- | 'K, a promoted data type (-XDataKinds). TyPromoted :: l -> (Promoted l) -> Type l -- | type equality predicate enabled by ConstraintKinds TyEquals :: l -> (Type l) -> (Type l) -> Type l -- | template haskell splice type TySplice :: l -> (Splice l) -> Type l -- | Strict type marked with "!" or type marked with UNPACK -- pragma. TyBang :: l -> (BangType l) -> (Unpackedness l) -> (Type l) -> Type l -- | Either an anonymous of named type wildcard TyWildCard :: l -> (Maybe (Name l)) -> Type l -- |
-- [$name| string |] --TyQuasiQuote :: l -> String -> String -> Type l -- | Flag denoting whether a tuple is boxed or unboxed. data Boxed Boxed :: Boxed Unboxed :: Boxed -- | An explicit kind annotation. data Kind l -- | *, the kind of types KindStar :: l -> Kind l -- | ->, the kind of a type constructor KindFn :: l -> (Kind l) -> (Kind l) -> Kind l -- | a parenthesised kind KindParen :: l -> (Kind l) -> Kind l -- | k, a kind variable (-XPolyKinds) KindVar :: l -> (QName l) -> Kind l -- |
-- k1 k2 --KindApp :: l -> (Kind l) -> (Kind l) -> Kind l -- | '(k1,k2,k3), a promoted tuple KindTuple :: l -> [Kind l] -> Kind l -- | '[k1], a promoted list literal KindList :: l -> (Kind l) -> Kind l -- | A type variable declaration, optionally with an explicit kind -- annotation. data TyVarBind l -- | variable binding with kind annotation KindedVar :: l -> (Name l) -> (Kind l) -> TyVarBind l -- | ordinary variable binding UnkindedVar :: l -> (Name l) -> TyVarBind l -- | Bools here are True if there was a leading quote which may be left -- out. For example '[k1,k2] means the same thing as -- [k1,k2]. data Promoted l -- | parsed value and raw string PromotedInteger :: l -> Integer -> String -> Promoted l -- | parsed value and raw string PromotedString :: l -> String -> String -> Promoted l PromotedCon :: l -> Bool -> (QName l) -> Promoted l PromotedList :: l -> Bool -> [Type l] -> Promoted l PromotedTuple :: l -> [Type l] -> Promoted l PromotedUnit :: l -> Promoted l -- | A type equation as found in closed type families. data TypeEqn l TypeEqn :: l -> (Type l) -> (Type l) -> TypeEqn l -- | Haskell expressions. data Exp l -- | variable Var :: l -> (QName l) -> Exp l -- | Overloaded label #foo OverloadedLabel :: l -> String -> Exp l -- | implicit parameter variable IPVar :: l -> (IPName l) -> Exp l -- | data constructor Con :: l -> (QName l) -> Exp l -- | literal constant Lit :: l -> (Literal l) -> Exp l -- | infix application InfixApp :: l -> (Exp l) -> (QOp l) -> (Exp l) -> Exp l -- | ordinary application App :: l -> (Exp l) -> (Exp l) -> Exp l -- | negation expression -exp (unary minus) NegApp :: l -> (Exp l) -> Exp l -- | lambda expression Lambda :: l -> [Pat l] -> (Exp l) -> Exp l -- | local declarations with let ... in ... Let :: l -> (Binds l) -> (Exp l) -> Exp l -- | if exp then exp else -- exp If :: l -> (Exp l) -> (Exp l) -> (Exp l) -> Exp l -- | if | stmts -> exp ... MultiIf :: l -> [GuardedRhs l] -> Exp l -- | case exp of alts Case :: l -> (Exp l) -> [Alt l] -> Exp l -- | do-expression: the last statement in the list should be an -- expression. Do :: l -> [Stmt l] -> Exp l -- | mdo-expression MDo :: l -> [Stmt l] -> Exp l -- | tuple expression Tuple :: l -> Boxed -> [Exp l] -> Exp l -- | tuple section expression, e.g. (,,3) TupleSection :: l -> Boxed -> [Maybe (Exp l)] -> Exp l -- | list expression List :: l -> [Exp l] -> Exp l -- | parallel array expression ParArray :: l -> [Exp l] -> Exp l -- | parenthesised expression Paren :: l -> (Exp l) -> Exp l -- | left section (exp qop) LeftSection :: l -> (Exp l) -> (QOp l) -> Exp l -- | right section (qop exp) RightSection :: l -> (QOp l) -> (Exp l) -> Exp l -- | record construction expression RecConstr :: l -> (QName l) -> [FieldUpdate l] -> Exp l -- | record update expression RecUpdate :: l -> (Exp l) -> [FieldUpdate l] -> Exp l -- | unbounded arithmetic sequence, incrementing by 1: [from ..] EnumFrom :: l -> (Exp l) -> Exp l -- | bounded arithmetic sequence, incrementing by 1 [from .. to] EnumFromTo :: l -> (Exp l) -> (Exp l) -> Exp l -- | unbounded arithmetic sequence, with first two elements given -- [from, then ..] EnumFromThen :: l -> (Exp l) -> (Exp l) -> Exp l -- | bounded arithmetic sequence, with first two elements given [from, -- then .. to] EnumFromThenTo :: l -> (Exp l) -> (Exp l) -> (Exp l) -> Exp l -- | Parallel array bounded arithmetic sequence, incrementing by 1 -- [:from .. to:] ParArrayFromTo :: l -> (Exp l) -> (Exp l) -> Exp l -- | bounded arithmetic sequence, with first two elements given [:from, -- then .. to:] ParArrayFromThenTo :: l -> (Exp l) -> (Exp l) -> (Exp l) -> Exp l -- | ordinary list comprehension ListComp :: l -> (Exp l) -> [QualStmt l] -> Exp l -- | parallel list comprehension ParComp :: l -> (Exp l) -> [[QualStmt l]] -> Exp l -- | parallel array comprehension ParArrayComp :: l -> (Exp l) -> [[QualStmt l]] -> Exp l -- | expression with explicit type signature ExpTypeSig :: l -> (Exp l) -> (Type l) -> Exp l -- | 'x for template haskell reifying of expressions VarQuote :: l -> (QName l) -> Exp l -- | ''T for template haskell reifying of types TypQuote :: l -> (QName l) -> Exp l -- | template haskell bracket expression BracketExp :: l -> (Bracket l) -> Exp l -- | template haskell splice expression SpliceExp :: l -> (Splice l) -> Exp l -- | quasi-quotaion: [$name| string |] QuasiQuote :: l -> String -> String -> Exp l -- | Visible type application TypeApp :: l -> (Type l) -> Exp l -- | xml element, with attributes and children XTag :: l -> (XName l) -> [XAttr l] -> (Maybe (Exp l)) -> [Exp l] -> Exp l -- | empty xml element, with attributes XETag :: l -> (XName l) -> [XAttr l] -> (Maybe (Exp l)) -> Exp l -- | PCDATA child element XPcdata :: l -> String -> Exp l -- | escaped haskell expression inside xml XExpTag :: l -> (Exp l) -> Exp l -- | children of an xml element XChildTag :: l -> [Exp l] -> Exp l -- | CORE pragma CorePragma :: l -> String -> (Exp l) -> Exp l -- | SCC pragma SCCPragma :: l -> String -> (Exp l) -> Exp l -- | GENERATED pragma GenPragma :: l -> String -> (Int, Int) -> (Int, Int) -> (Exp l) -> Exp l -- | arrows proc: proc pat -> exp Proc :: l -> (Pat l) -> (Exp l) -> Exp l -- | arrow application (from left): exp -< exp LeftArrApp :: l -> (Exp l) -> (Exp l) -> Exp l -- | arrow application (from right): exp >- exp RightArrApp :: l -> (Exp l) -> (Exp l) -> Exp l -- | higher-order arrow application (from left): exp -- -<< exp LeftArrHighApp :: l -> (Exp l) -> (Exp l) -> Exp l -- | higher-order arrow application (from right): exp -- >>- exp RightArrHighApp :: l -> (Exp l) -> (Exp l) -> Exp l -- | case alts LCase :: l -> [Alt l] -> Exp l -- | Expression hole ExprHole :: l -> Exp l -- | A statement, representing both a stmt in a -- do-expression, an ordinary qual in a list -- comprehension, as well as a stmt in a pattern guard. data Stmt l -- | a generator: pat <- exp Generator :: l -> (Pat l) -> (Exp l) -> Stmt l -- | an exp by itself: in a do-expression, an action whose -- result is discarded; in a list comprehension and pattern guard, a -- guard expression Qualifier :: l -> (Exp l) -> Stmt l -- | local bindings LetStmt :: l -> (Binds l) -> Stmt l -- | a recursive binding group for arrows RecStmt :: l -> [Stmt l] -> Stmt l -- | A general transqual in a list comprehension, which could -- potentially be a transform of the kind enabled by TransformListComp. data QualStmt l -- | an ordinary statement QualStmt :: l -> (Stmt l) -> QualStmt l -- | then exp ThenTrans :: l -> (Exp l) -> QualStmt l -- | then exp by exp ThenBy :: l -> (Exp l) -> (Exp l) -> QualStmt l -- | then group by exp GroupBy :: l -> (Exp l) -> QualStmt l -- | then group using exp GroupUsing :: l -> (Exp l) -> QualStmt l -- | then group by exp using -- exp GroupByUsing :: l -> (Exp l) -> (Exp l) -> QualStmt l -- | An fbind in a labeled construction or update expression. data FieldUpdate l -- | ordinary label-expresion pair FieldUpdate :: l -> (QName l) -> (Exp l) -> FieldUpdate l -- | record field pun FieldPun :: l -> (QName l) -> FieldUpdate l -- | record field wildcard FieldWildcard :: l -> FieldUpdate l -- | An alt alternative in a case expression. data Alt l Alt :: l -> (Pat l) -> (Rhs l) -> (Maybe (Binds l)) -> Alt l -- | An xml attribute, which is a name-expression pair. data XAttr l XAttr :: l -> (XName l) -> (Exp l) -> XAttr l -- | A pattern, to be matched against a value. data Pat l -- | variable PVar :: l -> (Name l) -> Pat l -- | literal constant PLit :: l -> (Sign l) -> (Literal l) -> Pat l -- | n+k pattern PNPlusK :: l -> (Name l) -> Integer -> Pat l -- | pattern with an infix data constructor PInfixApp :: l -> (Pat l) -> (QName l) -> (Pat l) -> Pat l -- | data constructor and argument patterns PApp :: l -> (QName l) -> [Pat l] -> Pat l -- | tuple pattern PTuple :: l -> Boxed -> [Pat l] -> Pat l -- | list pattern PList :: l -> [Pat l] -> Pat l -- | parenthesized pattern PParen :: l -> (Pat l) -> Pat l -- | labelled pattern, record style PRec :: l -> (QName l) -> [PatField l] -> Pat l -- | @-pattern PAsPat :: l -> (Name l) -> (Pat l) -> Pat l -- | wildcard pattern: _ PWildCard :: l -> Pat l -- | irrefutable pattern: ~pat PIrrPat :: l -> (Pat l) -> Pat l -- | pattern with type signature PatTypeSig :: l -> (Pat l) -> (Type l) -> Pat l -- | view patterns of the form (exp -> pat) PViewPat :: l -> (Exp l) -> (Pat l) -> Pat l -- | regular list pattern PRPat :: l -> [RPat l] -> Pat l -- | XML element pattern PXTag :: l -> (XName l) -> [PXAttr l] -> (Maybe (Pat l)) -> [Pat l] -> Pat l -- | XML singleton element pattern PXETag :: l -> (XName l) -> [PXAttr l] -> (Maybe (Pat l)) -> Pat l -- | XML PCDATA pattern PXPcdata :: l -> String -> Pat l -- | XML embedded pattern PXPatTag :: l -> (Pat l) -> Pat l -- | XML regular list pattern PXRPats :: l -> [RPat l] -> Pat l -- | quasi quote pattern: [$name| string |] PQuasiQuote :: l -> String -> String -> Pat l -- | strict (bang) pattern: f !x = ... PBangPat :: l -> (Pat l) -> Pat l -- | An fpat in a labeled record pattern. data PatField l -- | ordinary label-pattern pair PFieldPat :: l -> (QName l) -> (Pat l) -> PatField l -- | record field pun PFieldPun :: l -> (QName l) -> PatField l -- | record field wildcard PFieldWildcard :: l -> PatField l -- | An XML attribute in a pattern. data PXAttr l PXAttr :: l -> (XName l) -> (Pat l) -> PXAttr l -- | An entity in a regular pattern. data RPat l -- | operator pattern, e.g. pat* RPOp :: l -> (RPat l) -> (RPatOp l) -> RPat l -- | choice pattern, e.g. (1 | 2) RPEither :: l -> (RPat l) -> (RPat l) -> RPat l -- | sequence pattern, e.g. (| 1, 2, 3 |) RPSeq :: l -> [RPat l] -> RPat l -- | guarded pattern, e.g. (| p | p < 3 |) RPGuard :: l -> (Pat l) -> [Stmt l] -> RPat l -- | non-linear variable binding, e.g. (foo@:(1 | 2))* RPCAs :: l -> (Name l) -> (RPat l) -> RPat l -- | linear variable binding, e.g. foo@(1 | 2) RPAs :: l -> (Name l) -> (RPat l) -> RPat l -- | parenthesised pattern, e.g. (2*) RPParen :: l -> (RPat l) -> RPat l -- | an ordinary pattern RPPat :: l -> (Pat l) -> RPat l -- | A regular pattern operator. data RPatOp l -- | * = 0 or more RPStar :: l -> RPatOp l -- | *! = 0 or more, greedy RPStarG :: l -> RPatOp l -- | + = 1 or more RPPlus :: l -> RPatOp l -- | +! = 1 or more, greedy RPPlusG :: l -> RPatOp l -- | ? = 0 or 1 RPOpt :: l -> RPatOp l -- | ?! = 0 or 1, greedy RPOptG :: l -> RPatOp l -- | literal Values of this type hold the abstract value of the -- literal, along with the precise string representation used. For -- example, 10, 0o12 and 0xa have the same -- value representation, but each carry a different string -- representation. data Literal l -- | character literal Char :: l -> Char -> String -> Literal l -- | string literal String :: l -> String -> String -> Literal l -- | integer literal Int :: l -> Integer -> String -> Literal l -- | floating point literal Frac :: l -> Rational -> String -> Literal l -- | unboxed integer literal PrimInt :: l -> Integer -> String -> Literal l -- | unboxed word literal PrimWord :: l -> Integer -> String -> Literal l -- | unboxed float literal PrimFloat :: l -> Rational -> String -> Literal l -- | unboxed double literal PrimDouble :: l -> Rational -> String -> Literal l -- | unboxed character literal PrimChar :: l -> Char -> String -> Literal l -- | unboxed string literal PrimString :: l -> String -> String -> Literal l -- | An indication whether a literal pattern has been negated or not. data Sign l Signless :: l -> Sign l Negative :: l -> Sign l -- | The name of a Haskell module. data ModuleName l ModuleName :: l -> String -> ModuleName l -- | This type is used to represent qualified variables, and also qualified -- constructors. data QName l -- | name qualified with a module name Qual :: l -> (ModuleName l) -> (Name l) -> QName l -- | unqualified local name UnQual :: l -> (Name l) -> QName l -- | built-in constructor with special syntax Special :: l -> (SpecialCon l) -> QName l -- | This type is used to represent variables, and also constructors. data Name l -- | varid or conid. Ident :: l -> String -> Name l -- | varsym or consym Symbol :: l -> String -> Name l -- | Possibly qualified infix operators (qop), appearing in -- expressions. data QOp l -- | variable operator (qvarop) QVarOp :: l -> (QName l) -> QOp l -- | constructor operator (qconop) QConOp :: l -> (QName l) -> QOp l -- | Operators appearing in infix declarations are never -- qualified. data Op l -- | variable operator (varop) VarOp :: l -> (Name l) -> Op l -- | constructor operator (conop) ConOp :: l -> (Name l) -> Op l -- | Constructors with special syntax. These names are never qualified, and -- always refer to builtin type or data constructors. data SpecialCon l -- | unit type and data constructor () UnitCon :: l -> SpecialCon l -- | list type constructor [] ListCon :: l -> SpecialCon l -- | function type constructor -> FunCon :: l -> SpecialCon l -- | n-ary tuple type and data constructors (,) etc, -- possibly boxed (#,#) TupleCon :: l -> Boxed -> Int -> SpecialCon l -- | list data constructor (:) Cons :: l -> SpecialCon l -- | unboxed singleton tuple constructor (# #) UnboxedSingleCon :: l -> SpecialCon l -- | A name (cname) of a component of a class or data type in an -- import or export specification. data CName l -- | name of a method or field VarName :: l -> (Name l) -> CName l -- | name of a data constructor ConName :: l -> (Name l) -> CName l -- | An implicit parameter name. data IPName l -- | ?ident, non-linear implicit parameter IPDup :: l -> String -> IPName l -- | %ident, linear implicit parameter IPLin :: l -> String -> IPName l -- | The name of an xml element or attribute, possibly qualified with a -- namespace. data XName l XName :: l -> String -> XName l XDomName :: l -> String -> String -> XName l data Role l Nominal :: l -> Role l Representational :: l -> Role l Phantom :: l -> Role l RoleWildcard :: l -> Role l -- | A template haskell bracket expression. data Bracket l -- | expression bracket: [| ... |] ExpBracket :: l -> (Exp l) -> Bracket l -- | pattern bracket: [p| ... |] PatBracket :: l -> (Pat l) -> Bracket l -- | type bracket: [t| ... |] TypeBracket :: l -> (Type l) -> Bracket l -- | declaration bracket: [d| ... |] DeclBracket :: l -> [Decl l] -> Bracket l -- | A template haskell splice expression data Splice l -- | variable splice: $var IdSplice :: l -> String -> Splice l -- | parenthesised expression splice: $(exp) ParenSplice :: l -> (Exp l) -> Splice l -- | The safety of a foreign function call. data Safety l -- | unsafe PlayRisky :: l -> Safety l -- | safe (False) or threadsafe (True) PlaySafe :: l -> Bool -> Safety l -- | interruptible PlayInterruptible :: l -> Safety l -- | The calling convention of a foreign function call. data CallConv l StdCall :: l -> CallConv l CCall :: l -> CallConv l CPlusPlus :: l -> CallConv l DotNet :: l -> CallConv l Jvm :: l -> CallConv l Js :: l -> CallConv l JavaScript :: l -> CallConv l CApi :: l -> CallConv l -- | A top level options pragma, preceding the module header. data ModulePragma l -- | LANGUAGE pragma LanguagePragma :: l -> [Name l] -> ModulePragma l -- | OPTIONS pragma, possibly qualified with a tool, e.g. OPTIONS_GHC OptionsPragma :: l -> (Maybe Tool) -> String -> ModulePragma l -- | ANN pragma with module scope AnnModulePragma :: l -> (Annotation l) -> ModulePragma l -- | Recognised tools for OPTIONS pragmas. data Tool GHC :: Tool HUGS :: Tool NHC98 :: Tool YHC :: Tool HADDOCK :: Tool UnknownTool :: String -> Tool -- | Recognised overlaps for overlap pragmas. data Overlap l -- | NO_OVERLAP pragma NoOverlap :: l -> Overlap l -- | OVERLAP pragma Overlap :: l -> Overlap l -- | INCOHERENT pragma Incoherent :: l -> Overlap l -- | The body of a RULES pragma. data Rule l Rule :: l -> String -> (Maybe (Activation l)) -> (Maybe [RuleVar l]) -> (Exp l) -> (Exp l) -> Rule l -- | Variables used in a RULES pragma, optionally annotated with types data RuleVar l RuleVar :: l -> (Name l) -> RuleVar l TypedRuleVar :: l -> (Name l) -> (Type l) -> RuleVar l -- | Activation clause of a RULES pragma. data Activation l ActiveFrom :: l -> Int -> Activation l ActiveUntil :: l -> Int -> Activation l -- | An annotation through an ANN pragma. data Annotation l -- | An annotation for a declared name. Ann :: l -> (Name l) -> (Exp l) -> Annotation l -- | An annotation for a declared type. TypeAnn :: l -> (Name l) -> (Exp l) -> Annotation l -- | An annotation for the defining module. ModuleAnn :: l -> (Exp l) -> Annotation l -- | A boolean formula for MINIMAL pragmas. data BooleanFormula l -- | A variable. VarFormula :: l -> (Name l) -> BooleanFormula l -- | And boolean formulas. AndFormula :: l -> [BooleanFormula l] -> BooleanFormula l -- | Or boolean formulas. OrFormula :: l -> [BooleanFormula l] -> BooleanFormula l -- | Parenthesized boolean formulas. ParenFormula :: l -> (BooleanFormula l) -> BooleanFormula l prelude_mod :: l -> ModuleName l main_mod :: l -> ModuleName l main_name :: l -> Name l unit_con_name :: l -> QName l tuple_con_name :: l -> Boxed -> Int -> QName l list_cons_name :: l -> QName l unboxed_singleton_con_name :: l -> QName l unit_con :: l -> Exp l tuple_con :: l -> Boxed -> Int -> Exp l unboxed_singleton_con :: l -> Exp l as_name :: l -> Name l qualified_name :: l -> Name l hiding_name :: l -> Name l minus_name :: l -> Name l bang_name :: l -> Name l dot_name :: l -> Name l star_name :: l -> Name l export_name :: l -> Name l safe_name :: l -> Name l unsafe_name :: l -> Name l interruptible_name :: l -> Name l threadsafe_name :: l -> Name l stdcall_name :: l -> Name l ccall_name :: l -> Name l cplusplus_name :: l -> Name l dotnet_name :: l -> Name l jvm_name :: l -> Name l js_name :: l -> Name l javascript_name :: l -> Name l capi_name :: l -> Name l forall_name :: l -> Name l family_name :: l -> Name l role_name :: l -> Name l unit_tycon_name :: l -> QName l fun_tycon_name :: l -> QName l list_tycon_name :: l -> QName l tuple_tycon_name :: l -> Boxed -> Int -> QName l unboxed_singleton_tycon_name :: l -> QName l unit_tycon :: l -> Type l fun_tycon :: l -> Type l list_tycon :: l -> Type l tuple_tycon :: l -> Boxed -> Int -> Type l unboxed_singleton_tycon :: l -> Type l -- | AST nodes are annotated, and this class allows manipulation of the -- annotations. class Functor ast => Annotated ast -- | Retrieve the annotation of an AST node. ann :: Annotated ast => ast l -> l -- | Change the annotation of an AST node. Note that only the annotation of -- the node itself is affected, and not the annotations of any child -- nodes. if all nodes in the AST tree are to be affected, use -- fmap. amap :: Annotated ast => (l -> l) -> ast l -> ast l -- | Test if two AST elements are equal modulo annotations. (=~=) :: (Annotated a, Eq (a ())) => a l1 -> a l2 -> Bool instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Module l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Module instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Module instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Module instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Module l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Module l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Module l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Module l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ModulePragma l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ModulePragma instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ModulePragma instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ModulePragma instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ModulePragma l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ModulePragma l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ModulePragma l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ModulePragma l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.PXAttr l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.PXAttr instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.PXAttr instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.PXAttr instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.PXAttr l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.PXAttr l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.PXAttr l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.PXAttr l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.XAttr l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.XAttr instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.XAttr instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.XAttr instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.XAttr l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.XAttr l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.XAttr l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.XAttr l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.PatternSynDirection l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.PatternSynDirection instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.PatternSynDirection instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.PatternSynDirection instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.PatternSynDirection l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.PatternSynDirection l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.PatternSynDirection l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.PatternSynDirection l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Annotation l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Annotation instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Annotation instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Annotation instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Annotation l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Annotation l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Annotation l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Annotation l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.IPBind l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.IPBind instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.IPBind instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.IPBind instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.IPBind l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.IPBind l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.IPBind l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.IPBind l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Binds l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Binds instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Binds instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Binds instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Binds l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Binds l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Binds l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Binds l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Match l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Match instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Match instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Match instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Match l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Match l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Match l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Match l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.TypeEqn l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.TypeEqn instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.TypeEqn instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.TypeEqn instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.TypeEqn l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.TypeEqn l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.TypeEqn l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.TypeEqn l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ClassDecl l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ClassDecl instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ClassDecl instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ClassDecl instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ClassDecl l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ClassDecl l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ClassDecl l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ClassDecl l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.InstHead l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.InstHead instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.InstHead instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.InstHead instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.InstHead l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.InstHead l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.InstHead l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.InstHead l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.InstRule l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.InstRule instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.InstRule instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.InstRule instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.InstRule l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.InstRule l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.InstRule l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.InstRule l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Deriving l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Deriving instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Deriving instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Deriving instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Deriving l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Deriving l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Deriving l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Deriving l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ConDecl l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ConDecl instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ConDecl instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ConDecl instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ConDecl l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ConDecl l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ConDecl l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ConDecl l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.QualConDecl l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.QualConDecl instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.QualConDecl instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.QualConDecl instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.QualConDecl l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.QualConDecl l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.QualConDecl l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.QualConDecl l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.FieldDecl l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.FieldDecl instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.FieldDecl instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.FieldDecl instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.FieldDecl l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.FieldDecl l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.FieldDecl l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.FieldDecl l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.GadtDecl l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.GadtDecl instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.GadtDecl instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.GadtDecl instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.GadtDecl l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.GadtDecl l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.GadtDecl l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.GadtDecl l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.InstDecl l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.InstDecl instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.InstDecl instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.InstDecl instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.InstDecl l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.InstDecl l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.InstDecl l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.InstDecl l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.GuardedRhs l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.GuardedRhs instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.GuardedRhs instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.GuardedRhs instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.GuardedRhs l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.GuardedRhs l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.GuardedRhs l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.GuardedRhs l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Rhs l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Rhs instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Rhs instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Rhs instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Rhs l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Rhs l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Rhs l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Rhs l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.RuleVar l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.RuleVar instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.RuleVar instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.RuleVar instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.RuleVar l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.RuleVar l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.RuleVar l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.RuleVar l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Rule l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Rule instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Rule instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Rule instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Rule l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Rule l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Rule l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Rule l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Decl l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Decl instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Decl instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Decl instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Decl l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Decl l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Decl l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Decl l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Promoted l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Promoted instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Promoted instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Promoted instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Promoted l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Promoted l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Promoted l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Promoted l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Asst l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Asst instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Asst instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Asst instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Asst l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Asst l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Asst l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Asst l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Context l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Context instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Context instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Context instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Context l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Context l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Context l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Context l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Type l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Type instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Type instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Type instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Type l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Type l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Type l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Type l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Bracket l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Bracket instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Bracket instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Bracket instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Bracket l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Bracket l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Bracket l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Bracket l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Splice l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Splice instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Splice instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Splice instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Splice l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Splice l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Splice l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Splice l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.QualStmt l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.QualStmt instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.QualStmt instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.QualStmt instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.QualStmt l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.QualStmt l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.QualStmt l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.QualStmt l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.FieldUpdate l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.FieldUpdate instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.FieldUpdate instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.FieldUpdate instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.FieldUpdate l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.FieldUpdate l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.FieldUpdate l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.FieldUpdate l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Exp l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Exp instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Exp instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Exp instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Exp l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Exp l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Exp l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Exp l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Stmt l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Stmt instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Stmt instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Stmt instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Stmt l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Stmt l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Stmt l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Stmt l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.RPat l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.RPat instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.RPat instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.RPat instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.RPat l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.RPat l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.RPat l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.RPat l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.PatField l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.PatField instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.PatField instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.PatField instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.PatField l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.PatField l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.PatField l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.PatField l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Pat l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Pat instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Pat instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Pat instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Pat l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Pat l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Pat l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Pat l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Alt l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Alt instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Alt instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Alt instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Alt l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Alt l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Alt l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Alt l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.RPatOp l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.RPatOp instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.RPatOp instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.RPatOp instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.RPatOp l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.RPatOp l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.RPatOp l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.RPatOp l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ModuleHead l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ModuleHead instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ModuleHead instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ModuleHead instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ModuleHead l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ModuleHead l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ModuleHead l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ModuleHead l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.WarningText l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.WarningText instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.WarningText instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.WarningText instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.WarningText l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.WarningText l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.WarningText l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.WarningText l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Activation l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Activation instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Activation instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Activation instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Activation l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Activation l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Activation l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Activation l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Overlap l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Overlap instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Overlap instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Overlap instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Overlap l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Overlap l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Overlap l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Overlap l) instance GHC.Generics.Generic Language.Haskell.Exts.Syntax.Tool instance Data.Data.Data Language.Haskell.Exts.Syntax.Tool instance GHC.Show.Show Language.Haskell.Exts.Syntax.Tool instance GHC.Classes.Ord Language.Haskell.Exts.Syntax.Tool instance GHC.Classes.Eq Language.Haskell.Exts.Syntax.Tool instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.CallConv l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.CallConv instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.CallConv instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.CallConv instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.CallConv l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.CallConv l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.CallConv l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.CallConv l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Safety l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Safety instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Safety instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Safety instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Safety l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Safety l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Safety l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Safety l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.XName l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.XName instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.XName instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.XName instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.XName l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.XName l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.XName l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.XName l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Sign l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Sign instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Sign instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Sign instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Sign l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Sign l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Sign l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Sign l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Literal l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Literal instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Literal instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Literal instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Literal l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Literal l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Literal l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Literal l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.FunDep l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.FunDep instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.FunDep instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.FunDep instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.FunDep l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.FunDep l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.FunDep l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.FunDep l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ResultSig l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ResultSig instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ResultSig instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ResultSig instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ResultSig l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ResultSig l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ResultSig l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ResultSig l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.DeclHead l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.DeclHead instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.DeclHead instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.DeclHead instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.DeclHead l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.DeclHead l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.DeclHead l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.DeclHead l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.TyVarBind l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.TyVarBind instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.TyVarBind instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.TyVarBind instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.TyVarBind l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.TyVarBind l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.TyVarBind l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.TyVarBind l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Kind l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Kind instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Kind instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Kind instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Kind l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Kind l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Kind l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Kind l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.QOp l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.QOp instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.QOp instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.QOp instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.QOp l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.QOp l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.QOp l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.QOp l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ExportSpecList l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ExportSpecList instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ExportSpecList instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ExportSpecList instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ExportSpecList l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ExportSpecList l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ExportSpecList l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ExportSpecList l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ExportSpec l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ExportSpec instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ExportSpec instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ExportSpec instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ExportSpec l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ExportSpec l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ExportSpec l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ExportSpec l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.QName l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.QName instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.QName instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.QName instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.QName l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.QName l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.QName l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.QName l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.SpecialCon l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.SpecialCon instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.SpecialCon instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.SpecialCon instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.SpecialCon l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.SpecialCon l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.SpecialCon l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.SpecialCon l) instance GHC.Generics.Generic Language.Haskell.Exts.Syntax.Boxed instance Data.Data.Data Language.Haskell.Exts.Syntax.Boxed instance GHC.Show.Show Language.Haskell.Exts.Syntax.Boxed instance GHC.Classes.Ord Language.Haskell.Exts.Syntax.Boxed instance GHC.Classes.Eq Language.Haskell.Exts.Syntax.Boxed instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Unpackedness l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Unpackedness instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Unpackedness instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Unpackedness instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Unpackedness l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Unpackedness l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Unpackedness l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Unpackedness l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.BangType l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.BangType instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.BangType instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.BangType instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.BangType l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.BangType l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.BangType l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.BangType l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.InjectivityInfo l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.InjectivityInfo instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.InjectivityInfo instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.InjectivityInfo instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.InjectivityInfo l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.InjectivityInfo l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.InjectivityInfo l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.InjectivityInfo l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.DataOrNew l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.DataOrNew instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.DataOrNew instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.DataOrNew instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.DataOrNew l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.DataOrNew l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.DataOrNew l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.DataOrNew l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Role l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Role instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Role instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Role instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Role l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Role l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Role l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Role l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.BooleanFormula l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.BooleanFormula instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.BooleanFormula instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.BooleanFormula instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.BooleanFormula l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.BooleanFormula l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.BooleanFormula l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.BooleanFormula l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Assoc l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Assoc instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Assoc instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Assoc instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Assoc l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Assoc l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Assoc l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Assoc l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ImportDecl l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ImportDecl instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ImportDecl instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ImportDecl instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ImportDecl l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ImportDecl l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ImportDecl l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ImportDecl l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ImportSpecList l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ImportSpecList instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ImportSpecList instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ImportSpecList instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ImportSpecList l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ImportSpecList l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ImportSpecList l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ImportSpecList l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ImportSpec l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ImportSpec instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ImportSpec instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ImportSpec instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ImportSpec l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ImportSpec l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ImportSpec l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ImportSpec l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Namespace l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Namespace instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Namespace instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Namespace instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Namespace l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Namespace l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Namespace l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Namespace l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.EWildcard l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.EWildcard instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.EWildcard instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.EWildcard instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.EWildcard l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.EWildcard l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.EWildcard l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.EWildcard l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.CName l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.CName instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.CName instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.CName instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.CName l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.CName l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.CName l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.CName l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Op l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Op instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Op instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Op instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Op l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Op l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Op l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Op l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.IPName l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.IPName instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.IPName instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.IPName instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.IPName l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.IPName l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.IPName l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.IPName l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.Name l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.Name instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.Name instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.Name instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.Name l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.Name l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.Name l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.Name l) instance GHC.Generics.Generic (Language.Haskell.Exts.Syntax.ModuleName l) instance GHC.Base.Functor Language.Haskell.Exts.Syntax.ModuleName instance Data.Traversable.Traversable Language.Haskell.Exts.Syntax.ModuleName instance Data.Foldable.Foldable Language.Haskell.Exts.Syntax.ModuleName instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Syntax.ModuleName l) instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Syntax.ModuleName l) instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Syntax.ModuleName l) instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Syntax.ModuleName l) instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ModuleName instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.SpecialCon instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.QName instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Name instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.IPName instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.QOp instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Op instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.CName instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Module instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ModuleHead instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ExportSpecList instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ExportSpec instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.EWildcard instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Namespace instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ImportDecl instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ImportSpecList instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ImportSpec instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Assoc instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Deriving instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.TypeEqn instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.InjectivityInfo instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ResultSig instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Decl instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Role instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Annotation instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.BooleanFormula instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.DataOrNew instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.DeclHead instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.InstRule instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.InstHead instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Binds instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.IPBind instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Match instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.QualConDecl instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ConDecl instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.FieldDecl instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.GadtDecl instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ClassDecl instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.InstDecl instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.BangType instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Unpackedness instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Rhs instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.GuardedRhs instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Type instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.TyVarBind instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Kind instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.FunDep instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Context instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Asst instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Literal instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Sign instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Exp instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.XName instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.XAttr instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Bracket instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Splice instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Safety instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.CallConv instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.ModulePragma instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Overlap instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Activation instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Rule instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.RuleVar instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.WarningText instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Pat instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.PXAttr instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.RPatOp instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.RPat instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.PatField instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Stmt instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.QualStmt instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.FieldUpdate instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Alt instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.Syntax.Promoted -- | This module contains combinators to use when building Haskell source -- trees programmatically, as opposed to parsing them from a string. The -- contents here are quite experimental and will likely receive a lot of -- attention when the rest has stabilised. module Language.Haskell.Exts.Build -- | An identifier with the given string as its name. The string should be -- a valid Haskell identifier. name :: String -> Name () -- | A symbol identifier. The string should be a valid Haskell symbol -- identifier. sym :: String -> Name () -- | A local variable as expression. var :: Name () -> Exp () -- | Use the given identifier as an operator. op :: Name () -> QOp () -- | A qualified variable as expression. qvar :: ModuleName () -> Name () -> Exp () -- | A pattern variable. pvar :: Name () -> Pat () -- | Application of expressions by juxtaposition. app :: Exp () -> Exp () -> Exp () -- | Apply an operator infix. infixApp :: Exp () -> QOp () -> Exp () -> Exp () -- | Apply a function to a list of arguments. appFun :: Exp () -> [Exp ()] -> Exp () -- | A constructor pattern, with argument patterns. pApp :: Name () -> [Pat ()] -> Pat () -- | A tuple expression. tuple :: [Exp ()] -> Exp () -- | A tuple pattern. pTuple :: [Pat ()] -> Pat () -- | A tuple expression consisting of variables only. varTuple :: [Name ()] -> Exp () -- | A tuple pattern consisting of variables only. pvarTuple :: [Name ()] -> Pat () -- | A function with a given name. function :: String -> Exp () -- | A literal string expression. strE :: String -> Exp () -- | A literal character expression. charE :: Char -> Exp () -- | A literal integer expression. intE :: Integer -> Exp () -- | A literal string pattern. strP :: String -> Pat () -- | A literal character pattern. charP :: Char -> Pat () -- | A literal integer pattern. intP :: Integer -> Pat () -- | A do block formed by the given statements. The last statement in the -- list should be a Qualifier expression. doE :: [Stmt ()] -> Exp () -- | Lambda abstraction, given a list of argument patterns and an -- expression body. lamE :: [Pat ()] -> Exp () -> Exp () -- | A let ... in block. letE :: [Decl ()] -> Exp () -> Exp () -- | A case expression. caseE :: Exp () -> [Alt ()] -> Exp () -- | An unguarded alternative in a case expression. alt :: Pat () -> Exp () -> Alt () -- | An alternative with a single guard in a case expression. altGW :: Pat () -> [Stmt ()] -> Exp () -> Binds () -> Alt () -- | A list expression. listE :: [Exp ()] -> Exp () -- | The empty list expression. eList :: Exp () -- | The empty list pattern. peList :: Pat () -- | Put parentheses around an expression. paren :: Exp () -> Exp () -- | Put parentheses around a pattern. pParen :: Pat () -> Pat () -- | A qualifier expression statement. qualStmt :: Exp () -> Stmt () -- | A generator statement: pat <- exp genStmt :: Pat () -> Exp () -> Stmt () -- | A let binding group as a statement. letStmt :: [Decl ()] -> Stmt () -- | Hoist a set of declarations to a binding group. binds :: [Decl ()] -> Binds () -- | An empty binding group. noBinds :: Maybe (Binds ()) -- | The wildcard pattern: _ wildcard :: Pat () -- | Generate k names by appending numbers 1 through k to a given string. genNames :: String -> Int -> [Name ()] -- | A function with a single clause sfun :: Name () -> [Name ()] -> (Rhs ()) -> Maybe (Binds ()) -> Decl () -- | A function with a single clause, a single argument, no guards and no -- where declarations simpleFun :: Name () -> Name () -> Exp () -> Decl () -- | A pattern bind where the pattern is a variable, and where there are no -- guards and no 'where' clause. patBind :: Pat () -> Exp () -> Decl () -- | A pattern bind where the pattern is a variable, and where there are no -- guards, but with a 'where' clause. patBindWhere :: Pat () -> Exp () -> [Decl ()] -> Decl () -- | Bind an identifier to an expression. nameBind :: Name () -> Exp () -> Decl () -- | Apply function of a given name to a list of arguments. metaFunction :: String -> [Exp ()] -> Exp () -- | Apply a constructor of a given name to a list of pattern arguments, -- forming a constructor pattern. metaConPat :: String -> [Pat ()] -> Pat () -- | Fixity information to give the parser so that infix operators can be -- parsed properly. module Language.Haskell.Exts.Fixity -- | Operator fixities are represented by their associativity (left, right -- or none) and their precedence (0-9). data Fixity Fixity :: (Assoc ()) -> Int -> (QName ()) -> Fixity infix_ :: Int -> [String] -> [Fixity] infixl_ :: Int -> [String] -> [Fixity] infixr_ :: Int -> [String] -> [Fixity] -- | All fixities defined in the Prelude. preludeFixities :: [Fixity] -- | All fixities defined in the base package. -- -- Note that the +++ operator appears in both Control.Arrows and -- Text.ParserCombinators.ReadP. The listed precedence for +++ -- in this list is that of Control.Arrows. baseFixities :: [Fixity] -- | All AST elements that may include expressions which in turn may need -- fixity tweaking will be instances of this class. class AppFixity ast -- | Tweak any expressions in the element to account for the fixities -- given. Assumes that all operator expressions are fully left -- associative chains to begin with. applyFixities :: (AppFixity ast, Monad m) => [Fixity] -> ast SrcSpanInfo -> m (ast SrcSpanInfo) instance Data.Data.Data Language.Haskell.Exts.Fixity.Fixity instance GHC.Show.Show Language.Haskell.Exts.Fixity.Fixity instance GHC.Classes.Ord Language.Haskell.Exts.Fixity.Fixity instance GHC.Classes.Eq Language.Haskell.Exts.Fixity.Fixity instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Exp instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Pat instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Module instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Decl instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.PatternSynDirection instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Annotation instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.ClassDecl instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.InstDecl instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Match instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Rhs instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.GuardedRhs instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.PatField instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.RPat instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.PXAttr instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Stmt instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Binds instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.IPBind instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.FieldUpdate instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Alt instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.QualStmt instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Bracket instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.Splice instance Language.Haskell.Exts.Fixity.AppFixity Language.Haskell.Exts.Syntax.XAttr -- | This module processes comments along with an annotated AST, to be able -- to associate Haddock comments with the actual item they refer to. -- -- Example: -- --
-- let
-- parse1Result :: ParseResult (Module SrcSpanInfo,[Comment])
-- parse1Result =
-- parseFileContentsWithComments
-- (defaultParseMode { parseFilename = file })
-- contents
-- withC :: ParseResult (Module (SrcSpanInfo,[Comment]))
-- withC = case parse1Result of
-- ParseOk res -> ParseOk $ associateHaddock res
-- ParseFailed sloc msg -> ParseFailed sloc msg
--
--
-- In this code sample, parse1Result is what you get when you parse a
-- file: a Module annotated wth SrcSpanInfo, and a list of
-- comments After passing the result to associateHaddock, you get
-- a Module annotated with both a SrcSpanInfo and the list
-- of Comment related to the specific AST node.
module Language.Haskell.Exts.Comments
-- | Associates an AST with Source Span Information with relevant Haddock
-- comments
associateHaddock :: (Annotated ast, Traversable ast) => (ast SrcSpanInfo, [Comment]) -> ast (SrcSpanInfo, [Comment])
-- | A Haskell comment. The Bool is True if the comment is
-- multi-line, i.e. {- -}.
data Comment
Comment :: Bool -> SrcSpan -> String -> Comment
-- | An unknown pragma.
data UnknownPragma
UnknownPragma :: SrcSpan -> String -> UnknownPragma
instance Data.Data.Data Language.Haskell.Exts.Comments.UnknownPragma
instance GHC.Show.Show Language.Haskell.Exts.Comments.UnknownPragma
instance GHC.Classes.Eq Language.Haskell.Exts.Comments.UnknownPragma
instance Data.Data.Data Language.Haskell.Exts.Comments.Comment
instance GHC.Show.Show Language.Haskell.Exts.Comments.Comment
instance GHC.Classes.Eq Language.Haskell.Exts.Comments.Comment
-- | Exact-printer for Haskell abstract syntax. The input is a
-- (semi-concrete) abstract syntax tree, annotated with exact source
-- information to enable printing the tree exactly as it was parsed.
module Language.Haskell.Exts.ExactPrint
-- | Print an AST exactly as specified by the annotations on the nodes in
-- the tree.
exactPrint :: (ExactP ast) => ast SrcSpanInfo -> [Comment] -> String
class Annotated ast => ExactP ast
instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.ExactPrint.GuardedAlt l)
instance GHC.Base.Functor Language.Haskell.Exts.ExactPrint.GuardedAlt
instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.ExactPrint.GuardedAlts l)
instance GHC.Base.Functor Language.Haskell.Exts.ExactPrint.GuardedAlts
instance GHC.Base.Functor Language.Haskell.Exts.ExactPrint.EP
instance GHC.Base.Applicative Language.Haskell.Exts.ExactPrint.EP
instance GHC.Base.Monad Language.Haskell.Exts.ExactPrint.EP
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Literal
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Sign
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ModuleName
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.SpecialCon
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.QName
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Name
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.IPName
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.QOp
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Op
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.CName
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Namespace
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ExportSpec
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ExportSpecList
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ImportSpecList
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ImportSpec
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ImportDecl
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Module
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ModuleHead
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ModulePragma
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.WarningText
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Assoc
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.DataOrNew
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.TypeEqn
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.InjectivityInfo
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ResultSig
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Decl
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Role
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Annotation
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.BooleanFormula
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.DeclHead
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.InstRule
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.InstHead
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.TyVarBind
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Kind
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Type
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Promoted
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Context
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Asst
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Deriving
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ClassDecl
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.InstDecl
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.FunDep
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.QualConDecl
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.ConDecl
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.GadtDecl
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.BangType
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Unpackedness
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Splice
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Exp
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.FieldUpdate
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Stmt
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.QualStmt
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Bracket
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.XAttr
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Alt
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Match
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Rhs
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.GuardedRhs
instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.ExactPrint.GuardedAlts
instance Language.Haskell.Exts.Syntax.Annotated Language.Haskell.Exts.ExactPrint.GuardedAlt
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.ExactPrint.GuardedAlts
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.ExactPrint.GuardedAlt
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Pat
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.PatField
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.RPat
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.RPatOp
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.PXAttr
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.XName
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Binds
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.CallConv
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Safety
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Rule
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.RuleVar
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Overlap
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.Activation
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.FieldDecl
instance Language.Haskell.Exts.ExactPrint.ExactP Language.Haskell.Exts.Syntax.IPBind
-- | Lexer for Haskell with extensions.
module Language.Haskell.Exts.Lexer
-- | Lex a string into a list of Haskell 2010 source tokens.
lexTokenStream :: String -> ParseResult [Loc Token]
-- | Lex a string into a list of Haskell source tokens, using an explicit
-- mode.
lexTokenStreamWithMode :: ParseMode -> String -> ParseResult [Loc Token]
data Token
VarId :: String -> Token
LabelVarId :: String -> Token
QVarId :: (String, String) -> Token
IDupVarId :: (String) -> Token
ILinVarId :: (String) -> Token
ConId :: String -> Token
QConId :: (String, String) -> Token
DVarId :: [String] -> Token
VarSym :: String -> Token
ConSym :: String -> Token
QVarSym :: (String, String) -> Token
QConSym :: (String, String) -> Token
IntTok :: (Integer, String) -> Token
FloatTok :: (Rational, String) -> Token
Character :: (Char, String) -> Token
StringTok :: (String, String) -> Token
IntTokHash :: (Integer, String) -> Token
WordTokHash :: (Integer, String) -> Token
FloatTokHash :: (Rational, String) -> Token
DoubleTokHash :: (Rational, String) -> Token
CharacterHash :: (Char, String) -> Token
StringHash :: (String, String) -> Token
LeftParen :: Token
RightParen :: Token
LeftHashParen :: Token
RightHashParen :: Token
SemiColon :: Token
LeftCurly :: Token
RightCurly :: Token
VRightCurly :: Token
LeftSquare :: Token
RightSquare :: Token
ParArrayLeftSquare :: Token
ParArrayRightSquare :: Token
Comma :: Token
Underscore :: Token
BackQuote :: Token
Dot :: Token
DotDot :: Token
Colon :: Token
QuoteColon :: Token
DoubleColon :: Token
Equals :: Token
Backslash :: Token
Bar :: Token
LeftArrow :: Token
RightArrow :: Token
At :: Token
TApp :: Token
Tilde :: Token
DoubleArrow :: Token
Minus :: Token
Exclamation :: Token
Star :: Token
LeftArrowTail :: Token
RightArrowTail :: Token
LeftDblArrowTail :: Token
RightDblArrowTail :: Token
THExpQuote :: Token
THPatQuote :: Token
THDecQuote :: Token
THTypQuote :: Token
THCloseQuote :: Token
-- | ]
THIdEscape :: (String) -> Token
THParenEscape :: Token
THVarQuote :: Token
THTyQuote :: Token
THQuasiQuote :: (String, String) -> Token
RPGuardOpen :: Token
RPGuardClose :: Token
-- | )
RPCAt :: Token
XCodeTagOpen :: Token
XCodeTagClose :: Token
XStdTagOpen :: Token
XStdTagClose :: Token
XCloseTagOpen :: Token
XEmptyTagClose :: Token
XChildTagOpen :: Token
XPCDATA :: String -> Token
XRPatOpen :: Token
XRPatClose :: Token
PragmaEnd :: Token
RULES :: Token
INLINE :: Bool -> Token
INLINE_CONLIKE :: Token
SPECIALISE :: Token
SPECIALISE_INLINE :: Bool -> Token
SOURCE :: Token
DEPRECATED :: Token
WARNING :: Token
SCC :: Token
GENERATED :: Token
CORE :: Token
UNPACK :: Token
NOUNPACK :: Token
OPTIONS :: (Maybe String, String) -> Token
LANGUAGE :: Token
ANN :: Token
MINIMAL :: Token
NO_OVERLAP :: Token
OVERLAP :: Token
INCOHERENT :: Token
KW_As :: Token
KW_By :: Token
KW_Case :: Token
KW_Class :: Token
KW_Data :: Token
KW_Default :: Token
KW_Deriving :: Token
KW_Do :: Token
KW_MDo :: Token
KW_Else :: Token
KW_Family :: Token
KW_Forall :: Token
KW_Group :: Token
KW_Hiding :: Token
KW_If :: Token
KW_Import :: Token
KW_In :: Token
KW_Infix :: Token
KW_InfixL :: Token
KW_InfixR :: Token
KW_Instance :: Token
KW_Let :: Token
KW_Module :: Token
KW_NewType :: Token
KW_Of :: Token
KW_Proc :: Token
KW_Rec :: Token
KW_Role :: Token
KW_Then :: Token
KW_Type :: Token
KW_Using :: Token
KW_Where :: Token
KW_Qualified :: Token
KW_Pattern :: Token
KW_Foreign :: Token
KW_Export :: Token
KW_Safe :: Token
KW_Unsafe :: Token
KW_Threadsafe :: Token
KW_Interruptible :: Token
KW_StdCall :: Token
KW_CCall :: Token
KW_CPlusPlus :: Token
KW_DotNet :: Token
KW_Jvm :: Token
KW_Js :: Token
KW_JavaScript :: Token
KW_CApi :: Token
EOF :: Token
-- | An entity located in the source.
data Loc a
Loc :: SrcSpan -> a -> Loc a
[loc] :: Loc a -> SrcSpan
[unLoc] :: Loc a -> a
showToken :: Token -> String
-- | Pretty printer for Haskell with extensions.
module Language.Haskell.Exts.Pretty
-- | Things that can be pretty-printed, including all the syntactic objects
-- in Language.Haskell.Exts.Syntax and
-- Language.Haskell.Exts.Annotated.Syntax.
class Pretty a where pretty = prettyPrec 0 prettyPrec _ = pretty
-- | render the document with a given mode. renderWithMode :: PPHsMode
-- -> Doc -> String renderWithMode = renderStyleMode P.style
--
-- render the document with defaultMode. render :: Doc ->
-- String render = renderWithMode defaultMode
--
-- pretty-print with a given style and mode.
prettyPrintStyleMode :: Pretty a => Style -> PPHsMode -> a -> String
-- | pretty-print with the default style and a given mode.
prettyPrintWithMode :: Pretty a => PPHsMode -> a -> String
-- | pretty-print with the default style and defaultMode.
prettyPrint :: Pretty a => a -> String
-- | A rendering style. Allows us to specify constraints to choose among
-- the many different rendering options.
data Style :: *
Style :: Mode -> Int -> Float -> Style
-- | The rendering mode.
[mode] :: Style -> Mode
-- | Maximum length of a line, in characters.
[lineLength] :: Style -> Int
-- | Ratio of line length to ribbon length. A ribbon refers to the
-- characters on a line excluding indentation. So a
-- lineLength of 100, with a ribbonsPerLine of 2.0
-- would only allow up to 50 characters of ribbon to be displayed on a
-- line, while allowing it to be indented up to 50 characters.
[ribbonsPerLine] :: Style -> Float
-- | The default style (mode=PageMode, lineLength=100,
-- ribbonsPerLine=1.5).
style :: Style
-- | Rendering mode.
data Mode :: *
-- | Normal rendering (lineLength and ribbonsPerLine
-- respected').
PageMode :: Mode
-- | With zig-zag cuts.
ZigZagMode :: Mode
-- | No indentation, infinitely long lines (lineLength ignored), but
-- explicit new lines, i.e., text "one" $$ text "two", are
-- respected.
LeftMode :: Mode
-- | All on one line, lineLength ignored and explicit new lines
-- ($$) are turned into spaces.
OneLineMode :: Mode
-- | Pretty-printing parameters.
--
-- Note: the onsideIndent must be positive and less than
-- all other indents.
data PPHsMode
PPHsMode :: Indent -> Indent -> Indent -> Indent -> Indent -> Indent -> Indent -> Bool -> PPLayout -> Bool -> PPHsMode
-- | indentation of a class or instance
[classIndent] :: PPHsMode -> Indent
-- | indentation of a do-expression
[doIndent] :: PPHsMode -> Indent
-- | indentation of the body of a case expression
[multiIfIndent] :: PPHsMode -> Indent
-- | indentation of the body of a multi-if expression
[caseIndent] :: PPHsMode -> Indent
-- | indentation of the declarations in a let expression
[letIndent] :: PPHsMode -> Indent
-- | indentation of the declarations in a where clause
[whereIndent] :: PPHsMode -> Indent
-- | indentation added for continuation lines that would otherwise be
-- offside
[onsideIndent] :: PPHsMode -> Indent
-- | blank lines between statements?
[spacing] :: PPHsMode -> Bool
-- | Pretty-printing style to use
[layout] :: PPHsMode -> PPLayout
-- | add GHC-style LINE pragmas to output?
[linePragmas] :: PPHsMode -> Bool
type Indent = Int
-- | Varieties of layout we can use.
data PPLayout
-- | classical layout
PPOffsideRule :: PPLayout
-- | classical layout made explicit
PPSemiColon :: PPLayout
-- | inline decls, with newlines between them
PPInLine :: PPLayout
-- | everything on a single line
PPNoLayout :: PPLayout
-- | The default mode: pretty-print using the offside rule and sensible
-- defaults.
defaultMode :: PPHsMode
-- | pretty-print with the default style and defaultMode.
prettyPrim :: Pretty a => a -> Doc
-- | pretty-print with the default style and a given mode.
prettyPrimWithMode :: Pretty a => PPHsMode -> a -> Doc
instance GHC.Classes.Eq Language.Haskell.Exts.Pretty.PPLayout
instance GHC.Base.Functor (Language.Haskell.Exts.Pretty.DocM s)
instance GHC.Base.Applicative (Language.Haskell.Exts.Pretty.DocM s)
instance GHC.Base.Monad (Language.Haskell.Exts.Pretty.DocM s)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ModuleHead l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ExportSpecList l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ModuleName l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Namespace l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ExportSpec l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ImportDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ImportSpecList l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ImportSpec l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.TypeEqn l)
instance Language.Haskell.Exts.Pretty.PrettyDeclLike (Language.Haskell.Exts.Syntax.Decl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.InjectivityInfo l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ResultSig l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Decl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.InstRule l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.InstHead l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Annotation l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.BooleanFormula l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Role l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.DataOrNew l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Assoc l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Match l)
instance Language.Haskell.Exts.Pretty.PrettyDeclLike (Language.Haskell.Exts.Syntax.ClassDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ClassDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.DeclHead l)
instance Language.Haskell.Exts.Pretty.PrettyDeclLike (Language.Haskell.Exts.Syntax.InstDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.InstDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Safety l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.CallConv l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Rule l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Activation l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Overlap l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.RuleVar l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ModulePragma l)
instance Language.Haskell.Exts.Pretty.Pretty Language.Haskell.Exts.Syntax.Tool
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.QualConDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.GadtDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.ConDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.FieldDecl l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.BangType l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Unpackedness l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Deriving l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Type l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Promoted l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.TyVarBind l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Kind l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.FunDep l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Rhs l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.GuardedRhs l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Pretty.GuardedAlts l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Pretty.GuardedAlt l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Literal l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Exp l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.XAttr l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.XName l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Bracket l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Splice l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Pat l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.PXAttr l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.PatField l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.RPat l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.RPatOp l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Alt l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Stmt l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.QualStmt l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.FieldUpdate l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.QOp l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.QName l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Op l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Name l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.IPName l)
instance Language.Haskell.Exts.Pretty.PrettyDeclLike (Language.Haskell.Exts.Syntax.IPBind l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.IPBind l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.CName l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.SpecialCon l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Context l)
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Asst l)
instance Language.Haskell.Exts.Pretty.Pretty Language.Haskell.Exts.SrcLoc.SrcLoc
instance Language.Haskell.Exts.Pretty.Pretty Language.Haskell.Exts.SrcLoc.SrcSpan
instance Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.Syntax.Module pos)
instance Language.Haskell.Exts.SrcLoc.SrcInfo loc => Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.ParseSyntax.PExp loc)
instance Language.Haskell.Exts.SrcLoc.SrcInfo loc => Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.ParseSyntax.PFieldUpdate loc)
instance Language.Haskell.Exts.SrcLoc.SrcInfo loc => Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.ParseSyntax.ParseXAttr loc)
instance Language.Haskell.Exts.SrcLoc.SrcInfo loc => Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.ParseSyntax.PContext loc)
instance Language.Haskell.Exts.SrcLoc.SrcInfo loc => Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.ParseSyntax.PAsst loc)
instance Language.Haskell.Exts.SrcLoc.SrcInfo loc => Language.Haskell.Exts.Pretty.Pretty (Language.Haskell.Exts.ParseSyntax.PType loc)
-- | Annotated parser for Haskell with extensions.
module Language.Haskell.Exts.Parser
-- | Class providing function for parsing at many different types.
--
-- Note that for convenience of implementation, the default methods have
-- definitions equivalent to undefined. The minimal definition is
-- all of the visible methods.
class Parseable ast where parse = parseWithMode defaultParseMode parseWithMode mode = runParserWithMode mode . parser $ fixities mode parseWithComments mode = runParserWithModeComments mode . parser $ fixities mode
-- | Parse a string with default mode.
parse :: Parseable ast => String -> ParseResult ast
-- | Parse a string with an explicit ParseMode.
parseWithMode :: Parseable ast => ParseMode -> String -> ParseResult ast
-- | Parse a string with an explicit ParseMode, returning all
-- comments along with the AST.
parseWithComments :: Parseable ast => ParseMode -> String -> ParseResult (ast, [Comment])
-- | Static parameters governing a parse. Note that the various parse
-- functions in Language.Haskell.Exts.Parser never look at
-- LANGUAGE pragmas, regardless of what the
-- ignoreLanguagePragmas flag is set to. Only the various
-- parseFile functions in Language.Haskell.Exts will act
-- on it, when set to False.
data ParseMode
ParseMode :: String -> Language -> [Extension] -> Bool -> Bool -> Maybe [Fixity] -> Bool -> ParseMode
-- | original name of the file being parsed
[parseFilename] :: ParseMode -> String
-- | base language (e.g. Haskell98, Haskell2010)
[baseLanguage] :: ParseMode -> Language
-- | list of extensions enabled for parsing
[extensions] :: ParseMode -> [Extension]
-- | if True, the parser won't care about further extensions in
-- LANGUAGE pragmas in source files
[ignoreLanguagePragmas] :: ParseMode -> Bool
-- | if True, the parser won't read line position information from
-- LINE pragmas in source files
[ignoreLinePragmas] :: ParseMode -> Bool
-- | list of fixities to be aware of
[fixities] :: ParseMode -> Maybe [Fixity]
-- | Checks whether functions have a consistent arity
[ignoreFunctionArity] :: ParseMode -> Bool
-- | Default parameters for a parse. The default is an unknown filename, no
-- extensions (i.e. Haskell 98), don't ignore LANGUAGE pragmas, do ignore
-- LINE pragmas, and be aware of fixities from the Prelude.
defaultParseMode :: ParseMode
-- | The result of a parse.
data ParseResult a
-- | The parse succeeded, yielding a value.
ParseOk :: a -> ParseResult a
-- | The parse failed at the specified source location, with an error
-- message.
ParseFailed :: SrcLoc -> String -> ParseResult a
-- | Retrieve the result of a successful parse, throwing an error if the
-- parse is actually not successful.
fromParseResult :: ParseResult a -> a
-- | Parse of a string, which should contain a complete Haskell module,
-- using defaultParseMode.
parseModule :: String -> ParseResult (Module SrcSpanInfo)
-- | Parse of a string containing a complete Haskell module, using an
-- explicit ParseMode.
parseModuleWithMode :: ParseMode -> String -> ParseResult (Module SrcSpanInfo)
-- | Parse of a string containing a complete Haskell module, using an
-- explicit ParseMode, retaining comments.
parseModuleWithComments :: ParseMode -> String -> ParseResult (Module SrcSpanInfo, [Comment])
-- | Parse of a string containing a Haskell expression, using
-- defaultParseMode.
parseExp :: String -> ParseResult (Exp SrcSpanInfo)
-- | Parse of a string containing a Haskell expression, using an explicit
-- ParseMode.
parseExpWithMode :: ParseMode -> String -> ParseResult (Exp SrcSpanInfo)
-- | Parse of a string containing a complete Haskell module, using an
-- explicit ParseMode, retaining comments.
parseExpWithComments :: ParseMode -> String -> ParseResult (Exp SrcSpanInfo, [Comment])
-- | Parse of a string containing a Haskell statement, using
-- defaultParseMode.
parseStmt :: String -> ParseResult (Stmt SrcSpanInfo)
-- | Parse of a string containing a Haskell type, using an explicit
-- ParseMode.
parseStmtWithMode :: ParseMode -> String -> ParseResult (Stmt SrcSpanInfo)
-- | Parse of a string containing a complete Haskell module, using an
-- explicit ParseMode, retaining comments.
parseStmtWithComments :: ParseMode -> String -> ParseResult (Stmt SrcSpanInfo, [Comment])
-- | Parse of a string containing a Haskell pattern, using
-- defaultParseMode.
parsePat :: String -> ParseResult (Pat SrcSpanInfo)
-- | Parse of a string containing a Haskell pattern, using an explicit
-- ParseMode.
parsePatWithMode :: ParseMode -> String -> ParseResult (Pat SrcSpanInfo)
-- | Parse of a string containing a complete Haskell module, using an
-- explicit ParseMode, retaining comments.
parsePatWithComments :: ParseMode -> String -> ParseResult (Pat SrcSpanInfo, [Comment])
-- | Parse of a string containing a Haskell top-level declaration, using
-- defaultParseMode.
parseDecl :: String -> ParseResult (Decl SrcSpanInfo)
-- | Parse of a string containing a Haskell top-level declaration, using an
-- explicit ParseMode.
parseDeclWithMode :: ParseMode -> String -> ParseResult (Decl SrcSpanInfo)
-- | Parse of a string containing a complete Haskell module, using an
-- explicit ParseMode, retaining comments.
parseDeclWithComments :: ParseMode -> String -> ParseResult (Decl SrcSpanInfo, [Comment])
-- | Parse of a string containing a Haskell type, using
-- defaultParseMode.
parseType :: String -> ParseResult (Type SrcSpanInfo)
-- | Parse of a string containing a Haskell type, using an explicit
-- ParseMode.
parseTypeWithMode :: ParseMode -> String -> ParseResult (Type SrcSpanInfo)
-- | Parse of a string containing a complete Haskell module, using an
-- explicit ParseMode, retaining comments.
parseTypeWithComments :: ParseMode -> String -> ParseResult (Type SrcSpanInfo, [Comment])
-- | Parse of a string containing a Haskell statement, using
-- defaultParseMode.
parseImportDecl :: String -> ParseResult (ImportDecl SrcSpanInfo)
-- | Parse of a string containing a Haskell type, using an explicit
-- ParseMode.
parseImportDeclWithMode :: ParseMode -> String -> ParseResult (ImportDecl SrcSpanInfo)
-- | Parse of a string containing a complete Haskell module, using an
-- explicit ParseMode, retaining comments.
parseImportDeclWithComments :: ParseMode -> String -> ParseResult (ImportDecl SrcSpanInfo, [Comment])
-- | Instances of Parseable for NonGreedy a will only
-- consume the input until a is fully parsed. This means that
-- parse errors that come later in the input will be ignored. It's also
-- more efficient, as it's fully lazy in the remainder of the input:
--
--
-- >>> parse (unlines ("module A where" : "main =" : repeat "blah")) :: ParseResult PragmasAndModuleHead
-- ParseOk (NonGreedy {unNonGreedy = PragmasAndModuleHead [] (ModuleName "A",Nothing,Nothing)})
--
--
-- (this example uses the simplified AST)
newtype NonGreedy a
NonGreedy :: a -> NonGreedy a
[unNonGreedy] :: NonGreedy a -> a
-- | ListOf a stores lists of the AST type a, along with
-- a SrcSpanInfo, in order to provide Parseable instances
-- for lists. These instances are provided when the type is used as a
-- list in the syntax, and the same delimiters are used in all of its
-- usages. Some exceptions are made:
data ListOf a
ListOf :: SrcSpanInfo -> [a] -> ListOf a
unListOf :: ListOf a -> [a]
-- | Non-greedy parse of a string starting with a series of top-level
-- option pragmas.
getTopPragmas :: String -> ParseResult [ModulePragma SrcSpanInfo]
-- | Type intended to be used with Parseable, with instances that
-- implement a non-greedy parse of the module name, including top-level
-- pragmas. This means that a parse error that comes after the module
-- header won't be returned. If the Maybe value is Nothing,
-- then this means that there was no module header.
data PragmasAndModuleName l
PragmasAndModuleName :: l -> [ModulePragma l] -> (Maybe (ModuleName l)) -> PragmasAndModuleName l
data PragmasAndModuleHead l
PragmasAndModuleHead :: l -> [ModulePragma l] -> (Maybe (ModuleHead l)) -> PragmasAndModuleHead l
data ModuleHeadAndImports l
ModuleHeadAndImports :: l -> [ModulePragma l] -> (Maybe (ModuleHead l)) -> [ImportDecl l] -> ModuleHeadAndImports l
instance GHC.Base.Functor Language.Haskell.Exts.Parser.ListOf
instance Data.Data.Data a => Data.Data.Data (Language.Haskell.Exts.Parser.ListOf a)
instance GHC.Show.Show a => GHC.Show.Show (Language.Haskell.Exts.Parser.ListOf a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Language.Haskell.Exts.Parser.ListOf a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Language.Haskell.Exts.Parser.ListOf a)
instance Data.Data.Data a => Data.Data.Data (Language.Haskell.Exts.Parser.NonGreedy a)
instance GHC.Show.Show a => GHC.Show.Show (Language.Haskell.Exts.Parser.NonGreedy a)
instance GHC.Classes.Ord a => GHC.Classes.Ord (Language.Haskell.Exts.Parser.NonGreedy a)
instance GHC.Classes.Eq a => GHC.Classes.Eq (Language.Haskell.Exts.Parser.NonGreedy a)
instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Parser.ModuleHeadAndImports l)
instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Parser.ModuleHeadAndImports l)
instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Parser.ModuleHeadAndImports l)
instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Parser.ModuleHeadAndImports l)
instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Parser.PragmasAndModuleHead l)
instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Parser.PragmasAndModuleHead l)
instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Parser.PragmasAndModuleHead l)
instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Parser.PragmasAndModuleHead l)
instance Data.Data.Data l => Data.Data.Data (Language.Haskell.Exts.Parser.PragmasAndModuleName l)
instance GHC.Show.Show l => GHC.Show.Show (Language.Haskell.Exts.Parser.PragmasAndModuleName l)
instance GHC.Classes.Ord l => GHC.Classes.Ord (Language.Haskell.Exts.Parser.PragmasAndModuleName l)
instance GHC.Classes.Eq l => GHC.Classes.Eq (Language.Haskell.Exts.Parser.PragmasAndModuleName l)
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Syntax.Decl Language.Haskell.Exts.SrcLoc.SrcSpanInfo)
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Syntax.Exp Language.Haskell.Exts.SrcLoc.SrcSpanInfo)
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Syntax.Module Language.Haskell.Exts.SrcLoc.SrcSpanInfo)
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Syntax.Pat Language.Haskell.Exts.SrcLoc.SrcSpanInfo)
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Syntax.Stmt Language.Haskell.Exts.SrcLoc.SrcSpanInfo)
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Syntax.Type Language.Haskell.Exts.SrcLoc.SrcSpanInfo)
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Syntax.ImportDecl Language.Haskell.Exts.SrcLoc.SrcSpanInfo)
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Parser.NonGreedy (Language.Haskell.Exts.Parser.ListOf (Language.Haskell.Exts.Syntax.ModulePragma Language.Haskell.Exts.SrcLoc.SrcSpanInfo)))
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Parser.NonGreedy (Language.Haskell.Exts.Parser.PragmasAndModuleName Language.Haskell.Exts.SrcLoc.SrcSpanInfo))
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Parser.NonGreedy (Language.Haskell.Exts.Parser.PragmasAndModuleHead Language.Haskell.Exts.SrcLoc.SrcSpanInfo))
instance Language.Haskell.Exts.ParseMonad.Parseable (Language.Haskell.Exts.Parser.NonGreedy (Language.Haskell.Exts.Parser.ModuleHeadAndImports Language.Haskell.Exts.SrcLoc.SrcSpanInfo))
instance GHC.Base.Functor Language.Haskell.Exts.Parser.NonGreedy
-- | An umbrella module for the various functionality of the package. Also
-- provides some convenient functionality for dealing directly with
-- source files.
module Language.Haskell.Exts
-- | Parse a source file on disk, using the default parse mode.
parseFile :: FilePath -> IO (ParseResult (Module SrcSpanInfo))
-- | Parse a source file on disk, supplying a custom parse mode.
parseFileWithMode :: ParseMode -> FilePath -> IO (ParseResult (Module SrcSpanInfo))
-- | Parse a source file on disk, with an extra set of extensions to know
-- about on top of what the file itself declares.
parseFileWithExts :: [Extension] -> FilePath -> IO (ParseResult (Module SrcSpanInfo))
parseFileWithComments :: ParseMode -> FilePath -> IO (ParseResult (Module SrcSpanInfo, [Comment]))
-- | Parse a source file on disk, supplying a custom parse mode, and
-- retaining comments as well as unknown pragmas.
parseFileWithCommentsAndPragmas :: ParseMode -> FilePath -> IO (ParseResult (Module SrcSpanInfo, [Comment], [UnknownPragma]))
-- | Parse a source file from a string using the default parse mode.
parseFileContents :: String -> ParseResult (Module SrcSpanInfo)
-- | Parse a source file from a string using a custom parse mode.
parseFileContentsWithMode :: ParseMode -> String -> ParseResult (Module SrcSpanInfo)
-- | Parse a source file from a string, with an extra set of extensions to
-- know about on top of what the file itself declares.
parseFileContentsWithExts :: [Extension] -> String -> ParseResult (Module SrcSpanInfo)
parseFileContentsWithComments :: ParseMode -> String -> ParseResult (Module SrcSpanInfo, [Comment])
-- | Gather the extensions declared in LANGUAGE pragmas at the top of the
-- file. Returns Nothing if the parse of the pragmas fails.
readExtensions :: String -> Maybe (Maybe Language, [Extension])