module Agda.Syntax.Concrete
(
Expr(..)
, OpApp(..), fromOrdinary
, module Agda.Syntax.Concrete.Name
, appView, AppView(..)
, LamBinding
, LamBinding'(..)
, TypedBindings
, TypedBindings'(..)
, TypedBinding
, TypedBinding'(..)
, RecordAssignment
, RecordAssignments
, FieldAssignment, FieldAssignment'(..), nameFieldA, exprFieldA
, ModuleAssignment(..)
, BoundName(..), mkBoundName_, mkBoundName
, Telescope
, countTelVars
, Declaration(..)
, ModuleApplication(..)
, TypeSignature
, TypeSignatureOrInstanceBlock
, ImportDirective, Using, ImportedName
, Renaming
, AsName(..)
, OpenShortHand(..), RewriteEqn, WithExpr
, LHS(..), Pattern(..), LHSCore(..)
, RHS, RHS'(..), WhereClause, WhereClause'(..), ExprWhere(..)
, Pragma(..)
, Module
, ThingWithFixity(..)
, topLevelModuleName
, spanAllowedBeforeModule
, patternNames, patternQNames
, mapLhsOriginalPattern
)
where
import Prelude hiding (null)
import Control.DeepSeq
import Data.Typeable (Typeable)
import Data.Foldable (Foldable)
import Data.Traversable (Traversable)
import Data.List hiding (null)
import Data.Set (Set)
import Data.Monoid
import Agda.Syntax.Position
import Agda.Syntax.Common
import Agda.Syntax.Fixity
import Agda.Syntax.Notation
import Agda.Syntax.Literal
import Agda.Syntax.Concrete.Name
import qualified Agda.Syntax.Abstract.Name as A
import Agda.Utils.Lens
import Agda.Utils.Null
#include "undefined.h"
import Agda.Utils.Impossible
data OpApp e
= SyntaxBindingLambda Range [LamBinding] e
| Ordinary e
deriving (Typeable, Functor, Foldable, Traversable)
fromOrdinary :: e -> OpApp e -> e
fromOrdinary d (Ordinary e) = e
fromOrdinary d _ = d
data FieldAssignment' a = FieldAssignment { _nameFieldA :: Name, _exprFieldA :: a }
deriving (Typeable, Functor, Foldable, Traversable, Show, Eq)
type FieldAssignment = FieldAssignment' Expr
data ModuleAssignment = ModuleAssignment
{ _qnameModA :: QName
, _exprModA :: [Expr]
, _importDirModA :: ImportDirective
}
deriving (Typeable)
type RecordAssignment = Either FieldAssignment ModuleAssignment
type RecordAssignments = [RecordAssignment]
nameFieldA :: Lens' Name (FieldAssignment' a)
nameFieldA f r = f (_nameFieldA r) <&> \x -> r { _nameFieldA = x }
exprFieldA :: Lens' a (FieldAssignment' a)
exprFieldA f r = f (_exprFieldA r) <&> \x -> r { _exprFieldA = x }
qnameModA :: Lens' QName ModuleAssignment
qnameModA f r = f (_qnameModA r) <&> \x -> r { _qnameModA = x }
exprModA :: Lens' [Expr] ModuleAssignment
exprModA f r = f (_exprModA r) <&> \x -> r { _exprModA = x }
importDirModA :: Lens' ImportDirective ModuleAssignment
importDirModA f r = f (_importDirModA r) <&> \x -> r { _importDirModA = x }
data Expr
= Ident QName
| Lit Literal
| QuestionMark Range (Maybe Nat)
| Underscore Range (Maybe String)
| RawApp Range [Expr]
| App Range Expr (NamedArg Expr)
| OpApp Range QName (Set A.Name)
[NamedArg
(MaybePlaceholder (OpApp Expr))]
| WithApp Range Expr [Expr]
| HiddenArg Range (Named_ Expr)
| InstanceArg Range (Named_ Expr)
| Lam Range [LamBinding] Expr
| AbsurdLam Range Hiding
| ExtendedLam Range [(LHS,RHS,WhereClause,Bool)]
| Fun Range Expr Expr
| Pi Telescope Expr
| Set Range
| Prop Range
| SetN Range Integer
| Rec Range RecordAssignments
| RecUpdate Range Expr [FieldAssignment]
| Let Range [Declaration] Expr
| Paren Range Expr
| Absurd Range
| As Range Name Expr
| Dot Range Expr
| ETel Telescope
| QuoteGoal Range Name Expr
| QuoteContext Range
| Quote Range
| QuoteTerm Range
| Tactic Range Expr [Expr]
| Unquote Range
| DontCare Expr
| Equal Range Expr Expr
deriving (Typeable)
data Pattern
= IdentP QName
| QuoteP Range
| AppP Pattern (NamedArg Pattern)
| RawAppP Range [Pattern]
| OpAppP Range QName (Set A.Name)
[NamedArg Pattern]
| HiddenP Range (Named_ Pattern)
| InstanceP Range (Named_ Pattern)
| ParenP Range Pattern
| WildP Range
| AbsurdP Range
| AsP Range Name Pattern
| DotP Range Expr
| LitP Literal
| RecP Range [FieldAssignment' Pattern]
deriving (Typeable)
type LamBinding = LamBinding' TypedBindings
data LamBinding' a
= DomainFree ArgInfo BoundName
| DomainFull a
deriving (Typeable, Functor, Foldable, Traversable)
type TypedBindings = TypedBindings' TypedBinding
data TypedBindings' a = TypedBindings Range (Arg a)
deriving (Typeable, Functor, Foldable, Traversable)
data BoundName = BName
{ boundName :: Name
, boundLabel :: Name
, bnameFixity :: Fixity'
}
deriving (Typeable)
mkBoundName_ :: Name -> BoundName
mkBoundName_ x = mkBoundName x noFixity'
mkBoundName :: Name -> Fixity' -> BoundName
mkBoundName x f = BName x x f
type TypedBinding = TypedBinding' Expr
data TypedBinding' e
= TBind Range [WithHiding BoundName] e
| TLet Range [Declaration]
deriving (Typeable, Functor, Foldable, Traversable)
type Telescope = [TypedBindings]
countTelVars :: Telescope -> Nat
countTelVars tel =
sum [ case unArg b of
TBind _ xs _ -> genericLength xs
TLet{} -> 0
| TypedBindings _ b <- tel ]
data LHS
= LHS { lhsOriginalPattern :: Pattern
, lhsWithPattern :: [Pattern]
, lhsRewriteEqn :: [RewriteEqn]
, lhsWithExpr :: [WithExpr]
}
| Ellipsis Range [Pattern] [RewriteEqn] [WithExpr]
deriving (Typeable)
type RewriteEqn = Expr
type WithExpr = Expr
data LHSCore
= LHSHead { lhsDefName :: QName
, lhsPats :: [NamedArg Pattern]
}
| LHSProj { lhsDestructor :: QName
, lhsPatsLeft :: [NamedArg Pattern]
, lhsFocus :: NamedArg LHSCore
, lhsPatsRight :: [NamedArg Pattern]
}
deriving (Typeable)
type RHS = RHS' Expr
data RHS' e
= AbsurdRHS
| RHS e
deriving (Typeable, Functor, Foldable, Traversable)
type WhereClause = WhereClause' [Declaration]
data WhereClause' decls
= NoWhere
| AnyWhere decls
| SomeWhere Name decls
deriving (Typeable, Functor, Foldable, Traversable)
data ExprWhere = ExprWhere Expr WhereClause
type ImportDirective = ImportDirective' Name Name
type Using = Using' Name Name
type Renaming = Renaming' Name Name
type ImportedName = ImportedName' Name Name
data AsName = AsName
{ asName :: Name
, asRange :: Range
}
deriving (Typeable, Show)
type TypeSignature = Declaration
type TypeSignatureOrInstanceBlock = Declaration
data Declaration
= TypeSig ArgInfo Name Expr
| Field IsInstance Name (Arg Expr)
| FunClause LHS RHS WhereClause Bool
| DataSig Range Induction Name [LamBinding] Expr
| Data Range Induction Name [LamBinding] (Maybe Expr) [TypeSignatureOrInstanceBlock]
| RecordSig Range Name [LamBinding] Expr
| Record Range Name (Maybe (Ranged Induction)) (Maybe Bool) (Maybe (Name, IsInstance)) [LamBinding] (Maybe Expr) [Declaration]
| Infix Fixity [Name]
| Syntax Name Notation
| PatternSyn Range Name [Arg Name] Pattern
| Mutual Range [Declaration]
| Abstract Range [Declaration]
| Private Range [Declaration]
| InstanceB Range [Declaration]
| Macro Range [Declaration]
| Postulate Range [TypeSignatureOrInstanceBlock]
| Primitive Range [TypeSignature]
| Open Range QName ImportDirective
| Import Range QName (Maybe AsName) !OpenShortHand ImportDirective
| ModuleMacro Range Name ModuleApplication !OpenShortHand ImportDirective
| Module Range QName [TypedBindings] [Declaration]
| UnquoteDecl Range [Name] Expr
| UnquoteDef Range [Name] Expr
| Pragma Pragma
deriving (Typeable)
data ModuleApplication
= SectionApp Range [TypedBindings] Expr
| RecordModuleIFS Range QName
deriving (Typeable)
data OpenShortHand = DoOpen | DontOpen
deriving (Typeable, Eq, Show)
data Pragma
= OptionsPragma Range [String]
| BuiltinPragma Range String Expr
| RewritePragma Range QName
| CompiledDataPragma Range QName String [String]
| CompiledDeclareDataPragma Range QName String
| CompiledTypePragma Range QName String
| CompiledPragma Range QName String
| CompiledExportPragma Range QName String
| CompiledEpicPragma Range QName String
| CompiledJSPragma Range QName String
| CompiledUHCPragma Range QName String
| CompiledDataUHCPragma Range QName String [String]
| HaskellCodePragma Range String
| NoSmashingPragma Range QName
| StaticPragma Range QName
| InlinePragma Range QName
| ImportPragma Range String
| ImportUHCPragma Range String
| ImpossiblePragma Range
| TerminationCheckPragma Range (TerminationCheck Name)
| CatchallPragma Range
| DisplayPragma Range Pattern Expr
| NoPositivityCheckPragma Range
deriving (Typeable)
type Module = ([Pragma], [Declaration])
topLevelModuleName :: Module -> TopLevelModuleName
topLevelModuleName (_, []) = __IMPOSSIBLE__
topLevelModuleName (_, ds) = case spanAllowedBeforeModule ds of
(_, Module _ n _ _ : _) -> toTopLevelModuleName n
_ -> __IMPOSSIBLE__
spanAllowedBeforeModule :: [Declaration] -> ([Declaration], [Declaration])
spanAllowedBeforeModule = span isAllowedBeforeModule
where
isAllowedBeforeModule (Pragma OptionsPragma{}) = True
isAllowedBeforeModule (Private _ ds) = all isAllowedBeforeModule ds
isAllowedBeforeModule Import{} = True
isAllowedBeforeModule ModuleMacro{} = True
isAllowedBeforeModule Open{} = True
isAllowedBeforeModule _ = False
mapLhsOriginalPattern :: (Pattern -> Pattern) -> LHS -> LHS
mapLhsOriginalPattern f lhs@Ellipsis{} = lhs
mapLhsOriginalPattern f lhs@LHS{ lhsOriginalPattern = p } =
lhs { lhsOriginalPattern = f p }
data AppView = AppView Expr [NamedArg Expr]
appView :: Expr -> AppView
appView (App r e1 e2) = vApp (appView e1) e2
where
vApp (AppView e es) arg = AppView e (es ++ [arg])
appView (RawApp _ (e:es)) = AppView e $ map arg es
where
arg (HiddenArg _ e) = setHiding Hidden $ defaultArg e
arg (InstanceArg _ e) = setHiding Instance $ defaultArg e
arg e = defaultArg (unnamed e)
appView e = AppView e []
patternQNames :: Pattern -> [QName]
patternQNames p =
case p of
IdentP x -> [x]
AppP p p' -> concatMap patternQNames [p, namedArg p']
RawAppP _ ps -> concatMap patternQNames ps
OpAppP _ x _ ps -> x : concatMap (patternQNames . namedArg) ps
HiddenP _ (namedPat) -> patternQNames (namedThing namedPat)
ParenP _ p -> patternQNames p
WildP _ -> []
AbsurdP _ -> []
AsP _ x p -> patternQNames p
DotP{} -> []
LitP _ -> []
QuoteP _ -> []
InstanceP _ (namedPat) -> patternQNames (namedThing namedPat)
RecP _ fs -> concatMap (patternQNames . (^. exprFieldA)) fs
patternNames :: Pattern -> [Name]
patternNames = map unqualify . patternQNames
instance Null (WhereClause' a) where
empty = NoWhere
null NoWhere = True
null AnyWhere{} = False
null SomeWhere{} = False
instance LensRelevance TypedBindings where
getRelevance (TypedBindings _ b) = getRelevance b
mapRelevance f (TypedBindings r b) = TypedBindings r $ mapRelevance f b
instance LensHiding TypedBindings where
getHiding (TypedBindings _ b) = getHiding b
mapHiding f (TypedBindings r b) = TypedBindings r $ mapHiding f b
instance LensHiding LamBinding where
getHiding (DomainFree ai _) = getHiding ai
getHiding (DomainFull a) = getHiding a
mapHiding f (DomainFree ai x) = DomainFree (mapHiding f ai) x
mapHiding f (DomainFull a) = DomainFull $ mapHiding f a
instance HasRange e => HasRange (OpApp e) where
getRange e = case e of
Ordinary e -> getRange e
SyntaxBindingLambda r _ _ -> r
instance HasRange Expr where
getRange e =
case e of
Ident x -> getRange x
Lit x -> getRange x
QuestionMark r _ -> r
Underscore r _ -> r
App r _ _ -> r
RawApp r _ -> r
OpApp r _ _ _ -> r
WithApp r _ _ -> r
Lam r _ _ -> r
AbsurdLam r _ -> r
ExtendedLam r _ -> r
Fun r _ _ -> r
Pi b e -> fuseRange b e
Set r -> r
Prop r -> r
SetN r _ -> r
Let r _ _ -> r
Paren r _ -> r
As r _ _ -> r
Dot r _ -> r
Absurd r -> r
HiddenArg r _ -> r
InstanceArg r _ -> r
Rec r _ -> r
RecUpdate r _ _ -> r
ETel tel -> getRange tel
QuoteGoal r _ _ -> r
QuoteContext r -> r
Quote r -> r
QuoteTerm r -> r
Unquote r -> r
Tactic r _ _ -> r
DontCare{} -> noRange
Equal r _ _ -> r
instance HasRange TypedBindings where
getRange (TypedBindings r _) = r
instance HasRange TypedBinding where
getRange (TBind r _ _) = r
getRange (TLet r _) = r
instance HasRange LamBinding where
getRange (DomainFree _ x) = getRange x
getRange (DomainFull b) = getRange b
instance HasRange BoundName where
getRange = getRange . boundName
instance HasRange WhereClause where
getRange NoWhere = noRange
getRange (AnyWhere ds) = getRange ds
getRange (SomeWhere _ ds) = getRange ds
instance HasRange ModuleApplication where
getRange (SectionApp r _ _) = r
getRange (RecordModuleIFS r _) = r
instance HasRange a => HasRange (FieldAssignment' a) where
getRange (FieldAssignment a b) = fuseRange a b
instance HasRange ModuleAssignment where
getRange (ModuleAssignment a b c) = fuseRange a b `fuseRange` c
instance HasRange Declaration where
getRange (TypeSig _ x t) = fuseRange x t
getRange (Field _ x t) = fuseRange x t
getRange (FunClause lhs rhs wh _) = fuseRange lhs rhs `fuseRange` wh
getRange (DataSig r _ _ _ _) = r
getRange (Data r _ _ _ _ _) = r
getRange (RecordSig r _ _ _) = r
getRange (Record r _ _ _ _ _ _ _) = r
getRange (Mutual r _) = r
getRange (Abstract r _) = r
getRange (Open r _ _) = r
getRange (ModuleMacro r _ _ _ _) = r
getRange (Import r _ _ _ _) = r
getRange (InstanceB r _) = r
getRange (Macro r _) = r
getRange (Private r _) = r
getRange (Postulate r _) = r
getRange (Primitive r _) = r
getRange (Module r _ _ _) = r
getRange (Infix f _) = getRange f
getRange (Syntax n _) = getRange n
getRange (PatternSyn r _ _ _) = r
getRange (UnquoteDecl r _ _) = r
getRange (UnquoteDef r _ _) = r
getRange (Pragma p) = getRange p
instance HasRange LHS where
getRange (LHS p ps eqns ws) = fuseRange p (fuseRange ps (eqns ++ ws))
getRange (Ellipsis r _ _ _) = r
instance HasRange LHSCore where
getRange (LHSHead f ps) = fuseRange f ps
getRange (LHSProj d ps1 lhscore ps2) = d `fuseRange` ps1 `fuseRange` lhscore `fuseRange` ps2
instance HasRange RHS where
getRange AbsurdRHS = noRange
getRange (RHS e) = getRange e
instance HasRange Pragma where
getRange (OptionsPragma r _) = r
getRange (BuiltinPragma r _ _) = r
getRange (RewritePragma r _) = r
getRange (CompiledDataPragma r _ _ _) = r
getRange (CompiledDeclareDataPragma r _ _) = r
getRange (CompiledTypePragma r _ _) = r
getRange (CompiledPragma r _ _) = r
getRange (CompiledExportPragma r _ _) = r
getRange (CompiledEpicPragma r _ _) = r
getRange (CompiledJSPragma r _ _) = r
getRange (CompiledUHCPragma r _ _) = r
getRange (CompiledDataUHCPragma r _ _ _) = r
getRange (HaskellCodePragma r _) = r
getRange (NoSmashingPragma r _) = r
getRange (StaticPragma r _) = r
getRange (InlinePragma r _) = r
getRange (ImportPragma r _) = r
getRange (ImportUHCPragma r _) = r
getRange (ImpossiblePragma r) = r
getRange (TerminationCheckPragma r _) = r
getRange (CatchallPragma r) = r
getRange (DisplayPragma r _ _) = r
getRange (NoPositivityCheckPragma r) = r
instance HasRange AsName where
getRange a = getRange (asRange a, asName a)
instance HasRange Pattern where
getRange (IdentP x) = getRange x
getRange (AppP p q) = fuseRange p q
getRange (OpAppP r _ _ _) = r
getRange (RawAppP r _) = r
getRange (ParenP r _) = r
getRange (WildP r) = r
getRange (AsP r _ _) = r
getRange (AbsurdP r) = r
getRange (LitP l) = getRange l
getRange (QuoteP r) = r
getRange (HiddenP r _) = r
getRange (InstanceP r _) = r
getRange (DotP r _) = r
getRange (RecP r _) = r
instance SetRange TypedBindings where
setRange r (TypedBindings _ b) = TypedBindings r b
instance SetRange Pattern where
setRange r (IdentP x) = IdentP (setRange r x)
setRange r (AppP p q) = AppP (setRange r p) (setRange r q)
setRange r (OpAppP _ x ns ps) = OpAppP r x ns ps
setRange r (RawAppP _ ps) = RawAppP r ps
setRange r (ParenP _ p) = ParenP r p
setRange r (WildP _) = WildP r
setRange r (AsP _ x p) = AsP r (setRange r x) p
setRange r (AbsurdP _) = AbsurdP r
setRange r (LitP l) = LitP (setRange r l)
setRange r (QuoteP _) = QuoteP r
setRange r (HiddenP _ p) = HiddenP r p
setRange r (InstanceP _ p) = InstanceP r p
setRange r (DotP _ e) = DotP r e
setRange r (RecP _ fs) = RecP r fs
instance KillRange a => KillRange (FieldAssignment' a) where
killRange (FieldAssignment a b) = killRange2 FieldAssignment a b
instance KillRange ModuleAssignment where
killRange (ModuleAssignment a b c) = killRange3 ModuleAssignment a b c
instance KillRange AsName where
killRange (AsName n _) = killRange1 (flip AsName noRange) n
instance KillRange BoundName where
killRange (BName n l f) = killRange3 BName n l f
instance KillRange Declaration where
killRange (TypeSig i n e) = killRange2 (TypeSig i) n e
killRange (Field i n a) = killRange2 (Field i) n a
killRange (FunClause l r w ca) = killRange4 FunClause l r w ca
killRange (DataSig _ i n l e) = killRange4 (DataSig noRange) i n l e
killRange (Data _ i n l e c) = killRange4 (Data noRange i) n l e c
killRange (RecordSig _ n l e) = killRange3 (RecordSig noRange) n l e
killRange (Record _ n mi mb mn k e d)= killRange7 (Record noRange) n mi mb mn k e d
killRange (Infix f n) = killRange2 Infix f n
killRange (Syntax n no) = killRange1 (\n -> Syntax n no) n
killRange (PatternSyn _ n ns p) = killRange3 (PatternSyn noRange) n ns p
killRange (Mutual _ d) = killRange1 (Mutual noRange) d
killRange (Abstract _ d) = killRange1 (Abstract noRange) d
killRange (Private _ d) = killRange1 (Private noRange) d
killRange (InstanceB _ d) = killRange1 (InstanceB noRange) d
killRange (Macro _ d) = killRange1 (Macro noRange) d
killRange (Postulate _ t) = killRange1 (Postulate noRange) t
killRange (Primitive _ t) = killRange1 (Primitive noRange) t
killRange (Open _ q i) = killRange2 (Open noRange) q i
killRange (Import _ q a o i) = killRange3 (\q a -> Import noRange q a o) q a i
killRange (ModuleMacro _ n m o i) = killRange3 (\n m -> ModuleMacro noRange n m o) n m i
killRange (Module _ q t d) = killRange3 (Module noRange) q t d
killRange (UnquoteDecl _ x t) = killRange2 (UnquoteDecl noRange) x t
killRange (UnquoteDef _ x t) = killRange2 (UnquoteDef noRange) x t
killRange (Pragma p) = killRange1 Pragma p
instance KillRange Expr where
killRange (Ident q) = killRange1 Ident q
killRange (Lit l) = killRange1 Lit l
killRange (QuestionMark _ n) = QuestionMark noRange n
killRange (Underscore _ n) = Underscore noRange n
killRange (RawApp _ e) = killRange1 (RawApp noRange) e
killRange (App _ e a) = killRange2 (App noRange) e a
killRange (OpApp _ n ns o) = killRange3 (OpApp noRange) n ns o
killRange (WithApp _ e es) = killRange2 (WithApp noRange) e es
killRange (HiddenArg _ n) = killRange1 (HiddenArg noRange) n
killRange (InstanceArg _ n) = killRange1 (InstanceArg noRange) n
killRange (Lam _ l e) = killRange2 (Lam noRange) l e
killRange (AbsurdLam _ h) = killRange1 (AbsurdLam noRange) h
killRange (ExtendedLam _ lrw) = killRange1 (ExtendedLam noRange) lrw
killRange (Fun _ e1 e2) = killRange2 (Fun noRange) e1 e2
killRange (Pi t e) = killRange2 Pi t e
killRange (Set _) = Set noRange
killRange (Prop _) = Prop noRange
killRange (SetN _ n) = SetN noRange n
killRange (Rec _ ne) = killRange1 (Rec noRange) ne
killRange (RecUpdate _ e ne) = killRange2 (RecUpdate noRange) e ne
killRange (Let _ d e) = killRange2 (Let noRange) d e
killRange (Paren _ e) = killRange1 (Paren noRange) e
killRange (Absurd _) = Absurd noRange
killRange (As _ n e) = killRange2 (As noRange) n e
killRange (Dot _ e) = killRange1 (Dot noRange) e
killRange (ETel t) = killRange1 ETel t
killRange (QuoteGoal _ n e) = killRange2 (QuoteGoal noRange) n e
killRange (QuoteContext _) = QuoteContext noRange
killRange (Quote _) = Quote noRange
killRange (QuoteTerm _) = QuoteTerm noRange
killRange (Unquote _) = Unquote noRange
killRange (Tactic _ t es) = killRange2 (Tactic noRange) t es
killRange (DontCare e) = killRange1 DontCare e
killRange (Equal _ x y) = Equal noRange x y
instance KillRange LamBinding where
killRange (DomainFree i b) = killRange2 DomainFree i b
killRange (DomainFull t) = killRange1 DomainFull t
instance KillRange LHS where
killRange (LHS p ps r w) = killRange4 LHS p ps r w
killRange (Ellipsis _ p r w) = killRange3 (Ellipsis noRange) p r w
instance KillRange ModuleApplication where
killRange (SectionApp _ t e) = killRange2 (SectionApp noRange) t e
killRange (RecordModuleIFS _ q) = killRange1 (RecordModuleIFS noRange) q
instance KillRange e => KillRange (OpApp e) where
killRange (SyntaxBindingLambda _ l e) = killRange2 (SyntaxBindingLambda noRange) l e
killRange (Ordinary e) = killRange1 Ordinary e
instance KillRange Pattern where
killRange (IdentP q) = killRange1 IdentP q
killRange (AppP p n) = killRange2 AppP p n
killRange (RawAppP _ p) = killRange1 (RawAppP noRange) p
killRange (OpAppP _ n ns p) = killRange3 (OpAppP noRange) n ns p
killRange (HiddenP _ n) = killRange1 (HiddenP noRange) n
killRange (InstanceP _ n) = killRange1 (InstanceP noRange) n
killRange (ParenP _ p) = killRange1 (ParenP noRange) p
killRange (WildP _) = WildP noRange
killRange (AbsurdP _) = AbsurdP noRange
killRange (AsP _ n p) = killRange2 (AsP noRange) n p
killRange (DotP _ e) = killRange1 (DotP noRange) e
killRange (LitP l) = killRange1 LitP l
killRange (QuoteP _) = QuoteP noRange
killRange (RecP _ fs) = killRange1 (RecP noRange) fs
instance KillRange Pragma where
killRange (OptionsPragma _ s) = OptionsPragma noRange s
killRange (BuiltinPragma _ s e) = killRange1 (BuiltinPragma noRange s) e
killRange (RewritePragma _ q) = killRange1 (RewritePragma noRange) q
killRange (CompiledDataPragma _ q s ss) = killRange1 (\q -> CompiledDataPragma noRange q s ss) q
killRange (CompiledDeclareDataPragma _ q s) = killRange1 (\q -> CompiledDeclareDataPragma noRange q s) q
killRange (CompiledTypePragma _ q s) = killRange1 (\q -> CompiledTypePragma noRange q s) q
killRange (CompiledPragma _ q s) = killRange1 (\q -> CompiledPragma noRange q s) q
killRange (CompiledExportPragma _ q s) = killRange1 (\q -> CompiledExportPragma noRange q s) q
killRange (CompiledEpicPragma _ q s) = killRange1 (\q -> CompiledEpicPragma noRange q s) q
killRange (CompiledJSPragma _ q s) = killRange1 (\q -> CompiledJSPragma noRange q s) q
killRange (CompiledUHCPragma _ q s) = killRange1 (\q -> CompiledUHCPragma noRange q s) q
killRange (CompiledDataUHCPragma _ q s ss) = killRange1 (\q -> CompiledDataUHCPragma noRange q s ss) q
killRange (HaskellCodePragma _ s) = HaskellCodePragma noRange s
killRange (NoSmashingPragma _ q) = killRange1 (NoSmashingPragma noRange) q
killRange (StaticPragma _ q) = killRange1 (StaticPragma noRange) q
killRange (InlinePragma _ q) = killRange1 (InlinePragma noRange) q
killRange (ImportPragma _ s) = ImportPragma noRange s
killRange (ImportUHCPragma _ s) = ImportUHCPragma noRange s
killRange (ImpossiblePragma _) = ImpossiblePragma noRange
killRange (TerminationCheckPragma _ t) = TerminationCheckPragma noRange (killRange t)
killRange (CatchallPragma _) = CatchallPragma noRange
killRange (DisplayPragma _ lhs rhs) = killRange2 (DisplayPragma noRange) lhs rhs
killRange (NoPositivityCheckPragma _) = NoPositivityCheckPragma noRange
instance KillRange RHS where
killRange AbsurdRHS = AbsurdRHS
killRange (RHS e) = killRange1 RHS e
instance KillRange TypedBinding where
killRange (TBind _ b e) = killRange2 (TBind noRange) b e
killRange (TLet r ds) = killRange2 TLet r ds
instance KillRange TypedBindings where
killRange (TypedBindings _ t) = killRange1 (TypedBindings noRange) t
instance KillRange WhereClause where
killRange NoWhere = NoWhere
killRange (AnyWhere d) = killRange1 AnyWhere d
killRange (SomeWhere n d) = killRange2 SomeWhere n d
instance NFData Expr where
rnf (Ident a) = rnf a
rnf (Lit a) = rnf a
rnf (QuestionMark _ a) = rnf a
rnf (Underscore _ a) = rnf a
rnf (RawApp _ a) = rnf a
rnf (App _ a b) = rnf a `seq` rnf b
rnf (OpApp _ a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (WithApp _ a b) = rnf a `seq` rnf b
rnf (HiddenArg _ a) = rnf a
rnf (InstanceArg _ a) = rnf a
rnf (Lam _ a b) = rnf a `seq` rnf b
rnf (AbsurdLam _ a) = rnf a
rnf (ExtendedLam _ a) = rnf a
rnf (Fun _ a b) = rnf a `seq` rnf b
rnf (Pi a b) = rnf a `seq` rnf b
rnf (Set _) = ()
rnf (Prop _) = ()
rnf (SetN _ a) = rnf a
rnf (Rec _ a) = rnf a
rnf (RecUpdate _ a b) = rnf a `seq` rnf b
rnf (Let _ a b) = rnf a `seq` rnf b
rnf (Paren _ a) = rnf a
rnf (Absurd _) = ()
rnf (As _ a b) = rnf a `seq` rnf b
rnf (Dot _ a) = rnf a
rnf (ETel a) = rnf a
rnf (QuoteGoal _ a b) = rnf a `seq` rnf b
rnf (QuoteContext _) = ()
rnf (Quote _) = ()
rnf (QuoteTerm _) = ()
rnf (Tactic _ a b) = rnf a `seq` rnf b
rnf (Unquote _) = ()
rnf (DontCare a) = rnf a
rnf (Equal _ a b) = rnf a `seq` rnf b
instance NFData Pattern where
rnf (IdentP a) = rnf a
rnf (QuoteP _) = ()
rnf (AppP a b) = rnf a `seq` rnf b
rnf (RawAppP _ a) = rnf a
rnf (OpAppP _ a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (HiddenP _ a) = rnf a
rnf (InstanceP _ a) = rnf a
rnf (ParenP _ a) = rnf a
rnf (WildP _) = ()
rnf (AbsurdP _) = ()
rnf (AsP _ a b) = rnf a `seq` rnf b
rnf (DotP _ a) = rnf a
rnf (LitP a) = rnf a
rnf (RecP _ a) = rnf a
instance NFData Declaration where
rnf (TypeSig a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (Field a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (FunClause a b c d) = rnf a `seq` rnf b `seq` rnf c `seq` rnf d
rnf (DataSig _ a b c d) = rnf a `seq` rnf b `seq` rnf c `seq` rnf d
rnf (Data _ a b c d e) = rnf a `seq` rnf b `seq` rnf c `seq` rnf d `seq` rnf e
rnf (RecordSig _ a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (Record _ a b c d e f g) = rnf a `seq` rnf b `seq` rnf c `seq` rnf d `seq` rnf e `seq` rnf f `seq` rnf g
rnf (Infix a b) = rnf a `seq` rnf b
rnf (Syntax a b) = rnf a `seq` rnf b
rnf (PatternSyn _ a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (Mutual _ a) = rnf a
rnf (Abstract _ a) = rnf a
rnf (Private _ a) = rnf a
rnf (InstanceB _ a) = rnf a
rnf (Macro _ a) = rnf a
rnf (Postulate _ a) = rnf a
rnf (Primitive _ a) = rnf a
rnf (Open _ a b) = rnf a `seq` rnf b
rnf (Import _ a b _ c) = rnf a `seq` rnf b `seq` rnf c
rnf (ModuleMacro _ a b _ c) = rnf a `seq` rnf b `seq` rnf c
rnf (Module _ a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (UnquoteDecl _ a b) = rnf a `seq` rnf b
rnf (UnquoteDef _ a b) = rnf a `seq` rnf b
rnf (Pragma a) = rnf a
instance NFData Pragma where
rnf (OptionsPragma _ a) = rnf a
rnf (BuiltinPragma _ a b) = rnf a `seq` rnf b
rnf (RewritePragma _ a) = rnf a
rnf (CompiledDataPragma _ a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (CompiledDeclareDataPragma _ a b) = rnf a `seq` rnf b
rnf (CompiledTypePragma _ a b) = rnf a `seq` rnf b
rnf (CompiledPragma _ a b) = rnf a `seq` rnf b
rnf (CompiledExportPragma _ a b) = rnf a `seq` rnf b
rnf (CompiledEpicPragma _ a b) = rnf a `seq` rnf b
rnf (CompiledJSPragma _ a b) = rnf a `seq` rnf b
rnf (CompiledUHCPragma _ a b) = rnf a `seq` rnf b
rnf (CompiledDataUHCPragma _ a b c) = rnf a `seq` rnf b `seq` rnf c
rnf (HaskellCodePragma _ s) = rnf s
rnf (NoSmashingPragma _ a) = rnf a
rnf (StaticPragma _ a) = rnf a
rnf (InlinePragma _ a) = rnf a
rnf (ImportPragma _ a) = rnf a
rnf (ImportUHCPragma _ a) = rnf a
rnf (ImpossiblePragma _) = ()
rnf (TerminationCheckPragma _ a) = rnf a
rnf (CatchallPragma _) = ()
rnf (DisplayPragma _ a b) = rnf a `seq` rnf b
rnf (NoPositivityCheckPragma _) = ()
instance NFData a => NFData (TypedBindings' a) where
rnf (TypedBindings _ a) = rnf a
instance NFData AsName where
rnf (AsName a _) = rnf a
instance NFData a => NFData (TypedBinding' a) where
rnf (TBind _ a b) = rnf a `seq` rnf b
rnf (TLet _ a) = rnf a
instance NFData ModuleApplication where
rnf (SectionApp _ a b) = rnf a `seq` rnf b
rnf (RecordModuleIFS _ a) = rnf a
instance NFData a => NFData (OpApp a) where
rnf (SyntaxBindingLambda _ a b) = rnf a `seq` rnf b
rnf (Ordinary a) = rnf a
instance NFData LHS where
rnf (LHS a b c d) = rnf a `seq` rnf b `seq` rnf c `seq` rnf d
rnf (Ellipsis _ a b c) = rnf a `seq` rnf b `seq` rnf c
instance NFData a => NFData (FieldAssignment' a) where
rnf (FieldAssignment a b) = rnf a `seq` rnf b
instance NFData ModuleAssignment where
rnf (ModuleAssignment a b c) = rnf a `seq` rnf b `seq` rnf c
instance NFData a => NFData (WhereClause' a) where
rnf NoWhere = ()
rnf (AnyWhere a) = rnf a
rnf (SomeWhere a b) = rnf a `seq` rnf b
instance NFData a => NFData (LamBinding' a) where
rnf (DomainFree a b) = rnf a `seq` rnf b
rnf (DomainFull a) = rnf a
instance NFData BoundName where
rnf (BName a b c) = rnf a `seq` rnf b `seq` rnf c
instance NFData a => NFData (RHS' a) where
rnf AbsurdRHS = ()
rnf (RHS a) = rnf a