module Language.Haskell.Tools.AST.Exprs where
import Language.Haskell.Tools.AST.Ann
import Language.Haskell.Tools.AST.Base
import Language.Haskell.Tools.AST.Literals
import Language.Haskell.Tools.AST.Types
import Language.Haskell.Tools.AST.Patterns
import Language.Haskell.Tools.AST.Stmts
import Language.Haskell.Tools.AST.TH
import Language.Haskell.Tools.AST.Binds (LocalBind, LocalBinds, RhsGuard)
data Expr a
= Var { _exprName :: Ann Name a
}
| Lit { _exprLit :: Ann Literal a
}
| InfixApp { _exprLhs :: Ann Expr a
, _exprOperator :: Ann Operator a
, _exprRhs :: Ann Expr a
}
| PrefixApp { _exprOperator :: Ann Operator a
, _exprRhs :: Ann Expr a
}
| App { _exprFun :: Ann Expr a
, _exprArg :: Ann Expr a
}
| Lambda { _exprBindings :: AnnList Pattern a
, _exprInner :: Ann Expr a
}
| Let { _exprFunBind :: AnnList LocalBind a
, _exprInner :: Ann Expr a
}
| If { _exprCond :: Ann Expr a
, _exprThen :: Ann Expr a
, _exprElse :: Ann Expr a
}
| MultiIf { _exprIfAlts :: AnnList GuardedCaseRhs a
}
| Case { _exprCase :: Ann Expr a
, _exprAlts :: AnnList Alt a
}
| Do { _doKind :: Ann DoKind a
, _exprStmts :: AnnList Stmt a
}
| Tuple { _tupleElems :: AnnList Expr a
}
| UnboxedTuple { _tupleElems :: AnnList Expr a
}
| TupleSection { _tupleSectionElems :: AnnList TupSecElem a
}
| UnboxedTupSec { _tupleSectionElems :: AnnList TupSecElem a
}
| List { _listElems :: AnnList Expr a
}
| ParArray { _listElems :: AnnList Expr a
}
| Paren { _exprInner :: Ann Expr a
}
| LeftSection { _exprLhs :: Ann Expr a
, _exprOperator :: Ann Operator a
}
| RightSection { _exprOperator :: Ann Operator a
, _exprRhs :: Ann Expr a
}
| RecCon { _exprRecName :: Ann Name a
, _exprRecFields :: AnnList FieldUpdate a
}
| RecUpdate { _exprInner :: Ann Expr a
, _exprRecFields :: AnnList FieldUpdate a
}
| Enum { _enumFrom :: Ann Expr a
, _enumThen :: AnnMaybe Expr a
, _enumTo :: AnnMaybe Expr a
}
| ParArrayEnum { _enumFrom :: Ann Expr a
, _enumThen :: AnnMaybe Expr a
, _enumToFix :: Ann Expr a
}
| ListComp { _compExpr :: Ann Expr a
, _compBody :: AnnList ListCompBody a
}
| ParArrayComp { _compExpr :: Ann Expr a
, _compBody :: AnnList ListCompBody a
}
| TypeSig { _exprInner :: Ann Expr a
, _exprSig :: Ann Type a
}
| ExplTypeApp { _exprInner :: Ann Expr a
, _exprType :: Ann Type a
}
| VarQuote { _quotedName :: Ann Name a
}
| TypeQuote { _quotedName :: Ann Name a
}
| BracketExpr { _bracket :: Ann Bracket a
}
| Splice { _innerExpr :: Ann Splice a
}
| QuasiQuoteExpr { _exprQQ :: Ann QuasiQuote a
}
| ExprPragma { _exprPragma :: Ann ExprPragma a
}
| Proc { _procPattern :: Ann Pattern a
, _procExpr :: Ann Cmd a
}
| ArrowApp { _exprLhs :: Ann Expr a
, _arrowAppl :: Ann ArrowAppl a
, _exprRhs :: Ann Expr a
}
| LamCase { _exprAlts :: AnnList Alt a
}
| StaticPtr { _exprInner :: Ann Expr a
}
data FieldUpdate a
= NormalFieldUpdate { _fieldName :: Ann Name a
, _fieldValue :: Ann Expr a
}
| FieldPun { _fieldUpdateName :: Ann Name a
}
| FieldWildcard
data TupSecElem a
= Present { _tupSecExpr :: Ann Expr a
}
| Missing
data Alt' expr a
= Alt { _altPattern :: Ann Pattern a
, _altRhs :: Ann (CaseRhs' expr) a
, _altBinds :: AnnMaybe LocalBinds a
}
type Alt = Alt' Expr
type CmdAlt = Alt' Cmd
data CaseRhs' expr a
= UnguardedCaseRhs { _rhsCaseExpr :: Ann expr a
}
| GuardedCaseRhss { _rhsCaseGuards :: AnnList (GuardedCaseRhs' expr) a
}
type CaseRhs = CaseRhs' Expr
type CmdCaseRhs = CaseRhs' Cmd
data GuardedCaseRhs' expr a
= GuardedCaseRhs { _caseGuardStmts :: AnnList RhsGuard a
, _caseGuardExpr :: Ann expr a
}
type GuardedCaseRhs = GuardedCaseRhs' Expr
type CmdGuardedCaseRhs = GuardedCaseRhs' Cmd
data ExprPragma a
= CorePragma { _pragmaStr :: Ann StringNode a
}
| SccPragma { _pragmaStr :: Ann StringNode a
}
| GeneratedPragma { _pragmaSrcRange :: Ann SourceRange a
}
data SourceRange a
= SourceRange { _srFileName :: Ann StringNode a
, _srFromLine :: Ann Number a
, _srFromCol :: Ann Number a
, _srToLine :: Ann Number a
, _srToCol :: Ann Number a
}
data Number a
= Number { _numberInteger :: Integer
}
data Cmd a
= ArrowAppCmd { _cmdLhs :: Ann Expr a
, _cmdArrowOp :: Ann ArrowAppl a
, _cmdRhs :: Ann Expr a
}
| ArrowFormCmd { _cmdExpr :: Ann Expr a
, _cmdInnerCmds :: AnnList Cmd a
}
| AppCmd { _cmdInnerCmd :: Ann Cmd a
, _cmdApplied :: Ann Expr a
}
| InfixCmd { _cmdLeftCmd :: Ann Cmd a
, _cmdOperator :: Ann Name a
, _cmdRightCmd :: Ann Cmd a
}
| LambdaCmd { _cmdBindings :: AnnList Pattern a
, _cmdInner :: Ann Cmd a
}
| ParenCmd { _cmdInner :: Ann Cmd a
}
| CaseCmd { _cmdExpr :: Ann Expr a
, _cmdAlts :: AnnList CmdAlt a
}
| IfCmd { _cmdExpr :: Ann Expr a
, _cmdThen :: Ann Cmd a
, _cmdElse :: Ann Cmd a
}
| LetCmd { _cmdBinds :: AnnList LocalBind a
, _cmdInner :: Ann Cmd a
}
| DoCmd { _cmdStmts :: AnnList (Stmt' Cmd) a
}